# 定义一个字符串 hello = "Hello"; # "Hello"是str类的实例,输出True print('"Hello"是否是str类的实例: ', isinstance(hello, str)) # "Hello"是object类的子类的实例,输出True print('"Hello"是否是object类的实例: ', isinstance(hello, object)) # str是object类的子类,输出True print('str是否是object类的子类: ', issubclass(str, object)) # "Hello"不是tuple类及其子类的实例,输出False print('"Hello"是否是tuple类的实例: ', isinstance(hello, tuple)) # str不是tuple类的子类,输出False print('str是否是tuple类的子类: ', issubclass(str, tuple)) # 定义一个列表 my_list = [2, 4] # [2, 4]是list类的实例,输出True print('[2, 4]是否是list类的实例: ', isinstance(my_list, list)) # [2, 4]是object类的子类的实例,输出True print('[2, 4]是否是object类及其子类的实例: ', isinstance(my_list, object)) # list是object类的子类,输出True print('list是否是object类的子类: ', issubclass(list, object)) # [2, 4]不是tuple类及其子类的实例,输出False print('[2, 4]是否是tuple类及其子类的实例: ', isinstance([2, 4], tuple)) # list不是tuple类的子类,输出False print('list是否是tuple类的子类: ', issubclass(list, tuple))通过上面程序可以看出,issubclass() 和 isinstance() 两个函数的用法差不多,区别只是 issubclass() 的第一个参数是类名,而 isinstance() 的第一个参数是变量,这也与两个函数的意义对应:issubclass 用于判断是否为子类,而 isinstance() 用于判断是否为该类或子类的实例。
data = (20, 'fkit') print('data是否为列表或元组: ', isinstance(data, (list, tuple))) # True # str不是list或者tuple的子类,输出False print('str是否为list或tuple的子类: ', issubclass(str, (list, tuple))) # str是list或tuple或object的子类,输出True print('str是否为list或tuple或object的子类 ', issubclass(str, (list, tuple, object)))
class A: pass class B: pass class C(A, B): pass print('类A的所有父类:', A.__bases__) print('类B的所有父类:', B.__bases__) print('类C的所有父类:', C.__bases__)运行上面程序,可以看到如下运行结果:
类A的所有父类: (<class 'object'>,)
类B的所有父类: (<class 'object'>,)
类C的所有父类: (<class '__main__.A'>, <class '__main__.B'>)
print('类A的所有子类:', A.__subclasses__()) print('类B的所有子类:', B.__subclasses__())运行上面代码,可以看到如下输出结果:
类A的所有子类: [<class '__main__.C'>]
类B的所有子类: [<class '__main__.C'>]
本文链接:http://task.lmcjl.com/news/7331.html