一、三个内置函数

1、issubclass(a, b)  判断a类是否是b类的子类

class Foo:
pass

class Zi(Foo):
pass

class Sun(Zi):
pass
print(issubclass(Zi,Foo)) #True
print(issubclass(Zi,Sun)) # False

issubclass

 1 class Foo:
2 pass
3
4 class Zi(Foo):
5 pass
6
7 class Sun(Zi):
8 pass
9 print(issubclass(Zi,Foo)) #True
10 print(issubclass(Zi,Sun)) # False

2、type(对象)   返回该对象的数据类型,精确识别(即不向上兼容)

class Animal:
pass

class Cat(Animal):
pass

class BosiCat(Cat):
pass

c = Cat()
b = BosiCat()
print(type(c)) #<class '__main__.Cat'> 会准确说出c是一种Cat,不会说c是一种Animal

type

 1 class Animal:
2 pass
3
4 class Cat(Animal):
5 pass
6
7 class BosiCat(Cat):
8 pass
9
10 c = Cat()
11 b = BosiCat()
12 print(type(c)) #<class '__main__.Cat'> 会准确说出c是一种Cat,不会说c是一种Animal

3、isinstance(对象,类)   判断xx对象是否是xxx类 (向上兼容)

class Animal:
pass

class Cat(Animal):
pass

class BosiCat(Cat):
pass

c = Cat()
b = BosiCat()

print(isinstance(c , Cat)) #判断c 是否是一种Cat
print(isinstance(c,Animal)) #判断c 是否是一种Animal
print(isinstance(c,BosiCat))

结果:
True
True
False

isinstace

class Animal:
pass class Cat(Animal):
pass class BosiCat(Cat):
pass c = Cat()
b = BosiCat() print(isinstance(c , Cat)) #判断c 是否是一种Cat
print(isinstance(c,Animal)) #判断c 是否是一种Animal
print(isinstance(c,BosiCat)) 结果:
True
True
False

二、判断函数与方法

python官方定义:

函数function —— A series of statements which returns some value to a caller. It can also be passed zero or more arguments which may be used in the execution of the body.

方法method —— A function which is defined inside a class body. If called as an attribute of an instance of that class, the method will get the instance object as its first argument (which is usually called self).

从定义看,函数就相当于一个数学公式,它不与其他东西相互关联,传递相应的参数就能用。而方法是,定义在类内部的函数,并且这个函数和类或类的实例对象有某种关联,访问时会自动传递一个参数作为第一参数。

简单来说:

函数没和类或对象进行绑定;

方法和类或对象有绑定

# 区分函数和方法:

def func():
pass
print(func) # <function func at 0x10646ee18> 函数
class Foo:

def chi(self):
print("我是吃")
f = Foo()
print(f.chi) # <bound method Foo.chi of <__main__.Foo object at
0x10f688550>> 方法

函数和方法

 1 def func():
2 pass
3 print(func) # <function func at 0x10646ee18> 函数
4 class Foo:
5
6 def chi(self):
7 print("我是吃")
8 f = Foo()
9 print(f.chi) # <bound method Foo.chi of <__main__.Foo object at
10 0x10f688550>> 方法

class Foo:
def chi(self):
print("我是吃")
@staticmethod
def static_method():
pass
@classmethod
def class_method(cls):
pass

f = Foo()

print(f.chi) # <bound method Foo.chi of <__main__.Foo object at
0x10f688550>>

print(Foo.chi) # <function Foo.chi at 0x10e24a488>
print(Foo.static_method) # <function Foo.static_method at 0x10b5fe620>
print(Foo.class_method) # bound method Foo.class_method of <class
'__main__.Foo'>>

print(f.static_method) # <function Foo.static_method at 0x10e1c0620>
print(f.class_method) #<bound method Foo.class_method of <class
'__main__.Foo'>>

函数和方法

 1 class Foo:
2 def chi(self):
3 print("我是吃")
4 @staticmethod
5 def static_method():
6 pass
7 @classmethod
8 def class_method(cls):
9 pass
10
11 f = Foo()
12
13 print(f.chi) # <bound method Foo.chi of <__main__.Foo object at
14 0x10f688550>>
15
16 print(Foo.chi) # <function Foo.chi at 0x10e24a488>
17 print(Foo.static_method) # <function Foo.static_method at 0x10b5fe620>
18 print(Foo.class_method) # bound method Foo.class_method of <class
19 '__main__.Foo'>>
20
21 print(f.static_method) # <function Foo.static_method at 0x10e1c0620>
22 print(f.class_method) #<bound method Foo.class_method of <class
23 '__main__.Foo'>>

结论:

1. 类方法. 不论任何情况, 都是方法.

2. 静态方法, 不论任何情况. 都是函数

3. 实例方法, 如果是实例访问. 就是方法. 如果是类名访问就是函数.

#官方判断方法:

通过types模块引入MethodType  FunctionType 来判断

from types import FunctionType, MethodType

class Car:
def run(self): # 实例方法
print("我是车, 我会跑")

@staticmethod
def cul():
print("我会计算")

@classmethod
def jump(cls):
print("我会jump")

c = Car()

实例方法:
# 1. 用对象.方法 方法
# 2. 类名.方法 函数
c = Car()
print(isinstance(c.run, FunctionType)) # False
print(isinstance(Car.run, FunctionType)) # True
print(isinstance(c.run, MethodType)) # True
print(isinstance(Car.run, MethodType)) # False

# 静态方法 都是函数
print(isinstance(c.cul, FunctionType)) # True
print(isinstance(Car.cul, FunctionType)) # True
print(isinstance(c.cul, MethodType)) # False
print(isinstance(Car.cul, MethodType)) # False

# 类方法都是方法
print(isinstance(c.jump, FunctionType)) # False
print(isinstance(Car.jump, FunctionType)) # False
print(isinstance(c.jump, MethodType)) # True
print(isinstance(Car.jump, MethodType)) # True

判断

 1 from types import FunctionType, MethodType
2
3 class Car:
4 def run(self): # 实例方法
5 print("我是车, 我会跑")
6
7 @staticmethod
8 def cul():
9 print("我会计算")
10
11 @classmethod
12 def jump(cls):
13 print("我会jump")
14
15 c = Car()
16
17 实例方法:
18 # 1. 用对象.方法 方法
19 # 2. 类名.方法 函数
20 c = Car()
21 print(isinstance(c.run, FunctionType)) # False
22 print(isinstance(Car.run, FunctionType)) # True
23 print(isinstance(c.run, MethodType)) # True
24 print(isinstance(Car.run, MethodType)) # False
25
26 # 静态方法 都是函数
27 print(isinstance(c.cul, FunctionType)) # True
28 print(isinstance(Car.cul, FunctionType)) # True
29 print(isinstance(c.cul, MethodType)) # False
30 print(isinstance(Car.cul, MethodType)) # False
31
32 # 类方法都是方法
33 print(isinstance(c.jump, FunctionType)) # False
34 print(isinstance(Car.jump, FunctionType)) # False
35 print(isinstance(c.jump, MethodType)) # True
36 print(isinstance(Car.jump, MethodType)) # True

三、反射(重点)

关于反射, 其实一共有4个函数:

1. hasattr(obj, str)   判断obj中是否包含str成员

2. getattr(obj,str)    从obj中获取str成员

3. setattr(obj, str, value)     把obj中的str成员设置成value      这里的value可以是值, 也可以是函数或者方法

4. delattr(obj, str) 把obj中的str成员删除掉

注意:

obj可以是模块,类,实例对象

以上操作都是在内存中进行的, 并不会影响你的源代码,但是在同一个py文件中,你通过反射修改了类,是会影响到其他对象的。

 1 #反射用到的四个函数,常用的是hasattr 和getattr
2 # setattr(a,b,c) a是要操作的对象,b是操作对象中的成员字符串形式,c是修改的值
3 # getattr(a,b) 有返回值,返回值形式a.b a是要操作的对象,b是操作对象中的成员字符串形式
4 #delattr(a,b) a是要操作的对象,b是操作对象中的成员字符串形式
5 #hasatter(a,b) a是要操作的对象,b是操作对象中的成员字符串形式
6
7 class Car:
8
9 def __init__(self,color,pai,price):
10 self.color = color
11 self.pai = pai
12 self.price= price
13
14 def fly(self):
15 print('我的车会飞')
16
17 c = Car('blue','丰田','18888')
18 f = getattr(Car,"fly") #操作对象是类,返回值相当于Car.fly
19 print(f) #<function Car.fly at 0x0000000001EA9D08> 这里是函数,没有和类绑定,所以需要下面手动传值
20 f(c) # f是函数,没有和类绑定,所以需要手动传值Car.fly(c) ,它是等价于c.fly()的
21
22 #delattr(Car,"fly") #操作的是类,把类中fly方法删除了
23 #c.fly() #报错,没有fly
24
25 c2 =Car("yellow","bmw",20000)
26
27 def fly():
28 print("通过对象c修改fly方法")
29
30 setattr(c,"fly",fly) #并没有改变类中的内容,相当于在当前对象中创建了一个fly方法,一个对象是不可能有修改类的权限的
31 c.fly() #通过对象c修改fly方法
32 c2.fly() #我的车会飞
33 c3 = Car("blue","奔驰",88888)
34 c3.fly() #我的车会飞
35 setattr(Car,'fly',lambda self:print('通过类名,修改fly方法')) #通过类名修改fly方法
36 c.fly() #通过对象c修改fly方法
37 c2.fly() #通过类名,修改fly方法
38 c3.fly() #通过类名,修改fly方法
39 c4 = Car("red","悍马",66666)
40 c4.fly() #通过类名,修改fly方法
 

python学习12-反射 判断函数与方法(转载)的更多相关文章

  1. python记录_day18 反射 判断函数与方法

    一.三个内置函数 1.issubclass(a, b)  判断a类是否是b类的子类 class Foo: pass class Zi(Foo): pass class Sun(Zi): pass pr ...

  2. python学习交流 - 内置函数使用方法和应用举例

    内置函数 python提供了68个内置函数,在使用过程中用户不再需要定义函数来实现内置函数支持的功能.更重要的是内置函数的算法是经过python作者优化的,并且部分是使用c语言实现,通常来说使用内置函 ...

  3. Python学习笔记之常用函数及说明

    Python学习笔记之常用函数及说明 俗话说"好记性不如烂笔头",老祖宗们几千年总结出来的东西还是有些道理的,所以,常用的东西也要记下来,不记不知道,一记吓一跳,乖乖,函数咋这么多 ...

  4. python学习日记(基础数据类型及其方法01)

    数字 int 主要是用于计算的,常用的方法有一种 #既十进制数值用二进制表示时,最少使用的位数i = 3#3的ASCII为:0000 0011,即两位 s = i.bit_length() print ...

  5. 【转】Python的hasattr() getattr() setattr() 函数使用方法详解

    Python的hasattr() getattr() setattr() 函数使用方法详解 hasattr(object, name)判断一个对象里面是否有name属性或者name方法,返回BOOL值 ...

  6. Go - 反射中 函数 和 方法 的调用 - v.Call()

    上一篇文章 说到了 Golang 中的反射的一些基本规则,重点就是文章中最后的三点,但是这篇文章并没有说如何在反射中调用函数和方法,这就是接下来要说的. 反射中调用 函数 众所周知,Golang 中的 ...

  7. Python学习之---Python中的内置函数(方法)(更新中。。。)

    add(item)   #将item添加到s中,如果item已经在s中,则无任何效果 break        #退出循环,不会再运行循环中余下的代码 bool()     #将参数转换为布尔型 by ...

  8. python 面向对象之反射及内置方法

    面向对象之反射及内置方法 一.静态方法(staticmethod)和类方法(classmethod) 类方法:有个默认参数cls,并且可以直接用类名去调用,可以与类属性交互(也就是可以使用类属性) 静 ...

  9. python面向对象之反射和内置方法

    一.静态方法(staticmethod)和类方法(classmethod) 类方法:有个默认参数cls,并且可以直接用类名去调用,可以与类属性交互(也就是可以使用类属性) 静态方法:让类里的方法直接被 ...

随机推荐

  1. Responsive设计——meta标签

    media-queries.js(http://code.google.com/p/css3-mediaqueries-js/) respond.js(https://github.com/scott ...

  2. (一)在HTML页面中实现一个简单的Tab

    在HTML页面中实现一个简单的Tab 为了充分利用有限的HTML页面空间,经常会采用类似与TabControl的效果通过切换来显示更多的内容.本文将采用一种最为简单的方法来实现类似如Tab页切换的效果 ...

  3. [LintCode笔记了解一下]39.恢复旋转排序数组

    思路: 1.需要O(n)的事件复杂度,所以多次循环不考虑 2.四步翻转法 -第一步,找到数组里最小的那个数字,因为是旋转排序数组,所以只要找到某个位置arr[i]>arr[i+1]的话,就找到了 ...

  4. 洛谷P2420 让我们异或吧(树链剖分)

    题目描述异或是一种神奇的运算,大部分人把它总结成不进位加法. 在生活中…xor运算也很常见.比如,对于一个问题的回答,是为1,否为0.那么: (A是否是男生 )xor( B是否是男生)=A和B是否能够 ...

  5. CMake使用技巧

    前面有提到使用CMake.很多朋友提到也用过一下,没感觉它有什么好用,不知道怎么用之类. 我必要来说明一下. CMake的语法比较差,不是很优美,不是它不能用一个更好的语法,而是有一个关键优势:简单. ...

  6. HTML5+CSS3网站设计教程 (张晓景,胡克) [iso]

    <HTML5+CSS3网站设计教程>系统地讲解了CSS的基础理论和实际运用技术,并结合多个案例讲解了采用CSS与层布局相结合制作网页的方法,在详细讲解各个案例的制作中,不仅介绍了CSS样式 ...

  7. 【转】C# String 与 Char[] 数组 相互转换

    源地址:http://blog.csdn.net/razilfelix/article/details/52289663 string 转换成 Char[] string ss = "abc ...

  8. maven设置------settings.xml文件学习

    https://blog.csdn.net/tomato__/article/details/13025187 快速预览 maven的配置文件为settings.xml,在下面路径中可以找到这个文件, ...

  9. 八大排序算法的python实现(八)简单选择排序

    代码: #coding:utf-8 #author:徐卜灵 # L = [6, 3, 2, 32, 5, 4] def Select_sort(L): for i in range(0,len(L)) ...

  10. 「模拟赛20190327」 第二题 DP+决策单调性优化

    题目描述 小火车虽然很穷,但是他还是得送礼物给妹子,所以他前往了二次元寻找不需要钱的礼物. 小火车准备玩玩二次元的游戏,游戏当然是在一个二维网格中展开的,网格大小是\(n\times m\)的,某些格 ...