在python的类中,除了常规的一些自定义函数调用之外还有一些内置函数或方法,大多数情况下不会用到,但是为了更好的学习到python类的原理也需要对其有一定的了解,下面我们一起来看一下都具体包含了那些内容。

1 静态方法

  @staticmethod 本质为装饰器,可以理解为:名义归类管理,但实际上在静态方法里访问不了类或示例中的任何属性,相当于装饰成了类的高级工具包。

2 类方法

  @classmethod 本质为装饰器,只能访问类变量,不能访问示例变量。

__Author__ = "Panda-J"

class Person(object):
name = "Shuaige"
def __init__(self,name):
self.name = name
print("this is %s name"%name)
@classmethod
def Test_method(self):
print("%s is this name."%self.name)
Person.Test_method()
Person("Meinv")

3 属性方法

  @property 本质为装饰器,把一个方法变成一个静态属性,不能在后面加括号进行调用。如果必须传参数进行调用的话必须引入一个相同名字的函数,并加上@[name].setter装饰器中进行参数传递。属性方法是无法进行删除。删除用@[name].deleter中使用del命令才能删除

@property
def eat(self):
print("I love eat",self.__food)
@eat.setter
def eat(self,food):
print("set food :",food)
self.__food = food
@eat.deleter
def eat(self):
del self.__food
print("删完了")
p.eat#此处不需要加括号进行调用
p.eat="baozi"#将“baozi”传进了__food中,调用了@eat.setter函数
p.eat

  

4 特殊成员方法

  __doc__:储存类下用于注释该类的用法的内容。

class Person(object):
'''这是描述人类基本信息的类'''
print(p.__doc__)

  __module__:表示当前操作的对象在哪个模块中;__class__:表示当前操作的对象在哪个类中。

  __init__:构造方法,通过创造对象时,自动执行

  __del__:析构方法,当对象在内存中释放的时候将自动执行析构方法。

  __call__:可调用函数,使该对象具有可调用的功能。即相当于是该类可以使用两个括号进行引用,执行call中的语句:Person()()

class Person(object):
def __call__(self, *args, **kwargs):
print("your are great",args,kwargs,"thanks for your hardworking")
p = Person("Jiang")
p("Jiang","Lirui")

  __dict__:调用前表示该类所具有的所有属性。调用后表示该示例所具有的属性

print(Person.__dict__)
p = Person("Jiang")
print(p.__dict__)

  __str__:返回一个值而不是地址

    def __str__(self):
print("<welcome>",self.name)
print(p)

  __getitem__\__setitem__\__delitem__:此类方法最大的好处就在于可以将一个实例封装(伪装)成一个字典,用户调用和字典的方式完全一样,可以在类中加入限制调用以及更多的操作方法,丰富“字典”的使用方法。

    def __getitem__(self, item):
print("this running getitem %s progress"%item)
return self.data.get(item)
def __setitem__(self, key, value):
self.data[key] = value
def __delitem__(self, key):
del self.data[key]
p = Person("Jiang")
p["look"] = "perfomanced"
p["smell"] = "good"
print(p["look"])
del p["look"]
print(p.data)

  

  type:装逼的类创建,从此也可以看出Person即为type的一个示例(对象),也是一个类,所以type可以成为“类的类“。可以

 

def func(self):
print("this is a function") def __init__(self, name, age):
self.name = name
self.age = age Person = type("Person", (object,), {"func_name": func,
"__init__": __init__}) # 进行一个类的创建
p = Person("Jiang", 24)
p.func_name()

  

  __new__:可以自己封装一个类(对类的自定义化),__new__先于__init__执行。在python2.x中是由__call__函数创建。创建new的时候一定注意需要返回一个”cls“用于创建类。如果没有return将不会创建一个真正的实例

    def __new__(cls, *args, **kwargs):
print("this is new",args)
return object.__new__(cls)#继承父亲的__new__方法。

  __metacalss__:是一个很神奇的函数---元类。在python2.x的版本中可以看出差别,在3.x中有所区别。感兴趣的朋友可以试一下。用这个的目的就是为了自定义类,而不是按照系统默认的方法进行类的创建。

class Mytype(type):#定义一个元类
def __init__(self,what,base=None,dict=None):#重构init,加入自定义功能。
print('=======This is Mytype init=======')
super(Mytype,self).__init__(what,base,dict)#继承init,可正常实例化。
def __call__(self, *args, **kwargs):
print('=====This is Mytype call=====')
# obj=self.__new__(self,*args,**kwargs)
# self.__init__(obj,*args,**kwargs) class Person(object):
__metaclass__=Mytype#该对象以Mytype定义的形式进行创建
def __init__(self,name):
self.name = name
print("--Init the %s Person"%name)
def __new__(cls, *args, **kwargs):
print("--Person new %s"%args)
return object.__new__(cls)
p = Person("Jiang")

  

  在python2.x中执行的效果就是这样:

  由此可以看出是先执行了Mytype中自定义类的程序,再执行了Foo类的创建程序。详情请参阅StackOverflow上的链接。

在类方法中一个比较重要的来了

4 反射:

  1 hasattr(obj,name_str)--判断一个对象是否由对应(name_str)的字符串方法,有返回True,无返回False

  2 getattr(obj,name_str)--获得该字符串对应的函数/方法的内存方法

  3 setattr('x','y','v')--相当于x.y=v,但不等于,无法直接使用x.y。会提示在x中找不到y方法。可赋值给一个变量a=getattr(x,y),让变量去调用函数a()。动态的内存交互。

  4 delattr(obj,name_str)--删除obj中的name_str方法。

所有的方法都在下面的代码中使用,请参考:

def bulk(self):
print("%s is yelling"%self.name)#self.name用的就是Person里的self.name
class Person(object):
def __init__(self,name):
self.name = name#类的结构化
def eat(self,food):
print("%s is eating %s"%(self.name,food)) d = Person("Jiang")
print(d.name)
choice = input(">>".strip())#输入一个属性
if hasattr(d,choice):#判断是否具有“choice”
func = getattr(d,choice)#将d.choice的地址赋值给func
func("Banana")#对d.choice的调用
delattr(d, choice)#删除choice这个属性
else:
setattr(d,choice,bulk)#将bulk方法归在类下
c = getattr(d,choice)#将d.choice的地址赋值给c
c(d)#调用c
print(d.name)

  

  

  

python 常用方法的更多相关文章

  1. Python常用方法

    Python strip()方法 描述: Python strip()方法用于移除字符串头尾指定的字符(默认为空格). 语法: str.strip([chars]) 参数: chars -- 移除字符 ...

  2. python常用方法总结

    1.os模块的路径拼接: import os now_path=os.path.abspath(__file__)#当前运行文件的路径 print(now_path) uppeer_path=os.p ...

  3. Python 常用方法和模块的使用(time & datetime & os &random &sys &shutil)-(六)

    1 比较常用的一些方法 1.eval()方法:执行字符串表达式,并返回到字符串. 2.序列化:变量从内存中变成可存储或传输到文件或变量的过程,可以保存当时对象的状态,实现其生命周期的延长,并且需要时可 ...

  4. python常用方法详解

    1,讲序列分解为单独的变量 p=(4,5) x,y=p print(x,y) 如果在分解中想丢弃某些特定的值,可以采用_来进行 data=['A','B','c','d'] _,name,age,_= ...

  5. odoo之ERP系统

    odoo大纲 第一部分:数据库postgressql 大象 第二部分:ORM(API) 第三部分:客户端 用python软件写: .py文件 包含两部分:1.自定义部分,由自己写,定义类和功能. .继 ...

  6. python浅谈正则的常用方法

    python浅谈正则的常用方法覆盖范围70%以上 上一次很多朋友写文字屏蔽说到要用正则表达,其实不是我不想用(我正则用得不是很多,看过我之前爬虫的都知道,我直接用BeautifulSoup的网页标签去 ...

  7. python中的常用方法

    1.os模块的常用方法: >>> import os >>> >>> myFiles = ['accounts.txt', 'details.cs ...

  8. python字符串,列表,字典的常用方法

    本篇内容 字符串的常用方法 列表的常用方法 字典的常用方法 字符串的常用方法 center 字符居中显示,指定字符串长度,填充指定的填充字符 string = "40kuai" p ...

  9. 下篇:python的基本数据类型以及对应的常用方法(列表、元组、字典、集合)

    为了日后便于查询,本文所涉及到的所有命令集合如下: python中的基本数据类型有数字.字符串.布尔值.列表.元组.字典.就像每一个职业有自己特定的技能,比如医生能看病,农民能种田,每种数据类型也有属 ...

随机推荐

  1. iOS 利用异常 NSException 调试代码

    可以用在代码的调试上: -(instancetype)init{ @throw [NSException exceptionWithName:@"Singleton" reason ...

  2. C++ 11 左值,右值,左值引用,右值引用,std::move, std::foward

    这篇文章要介绍的内容和标题一致,关于C++ 11中的这几个特性网上介绍的文章很多,看了一些之后想把几个比较关键的点总结记录一下,文章比较长.给出了很多代码示例,都是编译运行测试过的,希望能用这些帮助理 ...

  3. Egret学习笔记 (Egret打飞机-5.实现子弹对象)

    上一章把飞机添加到屏幕上,但是飞机要发射子弹对吧?那么这一章我们就来实现一下发射子弹,并实现一个简单的子弹对象池 先来捋一捋思路 1.创建一个子弹对象 2.然后添加一个bitmap,显示子弹贴图 3. ...

  4. GB 标准

    std::map<int, std::string> GB2261 = { { 0,"未知的性别" }, { 1,"男性" }, { 2," ...

  5. Qt 如何使用 QImage 设置指定的颜色为透明色?

    Qt 如何使用 QImage 设置指定的颜色为透明色? 需求背景:使用华大身份证读卡器模块读取身份证信息,通过模块读取的图片为 *.BMP 格式,无透明色,故绘制到身份证上无法美观的显示. 通过查询身 ...

  6. ThreadLoacl,InheritableThreadLocal,原理,以及配合线程池使用的一些坑

    虽然使用AOP可以获取方法签名,但是如果要获取方法中计算得出的数据,那么就得使用ThreadLocal,如果还涉及父线程,那么可以选择InheritableThreadLocal. 注意:理解一些原理 ...

  7. eclipse导入/编译hadoop源代码

    1. 确保安装好JDK和eclipse 详细教程见: http://blog.csdn.net/kangdakangdaa/article/details/11364985 2. 安装 Subclip ...

  8. B+索引、Hash索引、数据类型长度

    1.为什么在数据库中要用B树索引而不是Hash索引? Mysql Hash索引结构的特殊性,其检索效率非常高,索引的检索可以一次定位,不像B-Tree 索引需要从根节点到枝节点,最后才能访问到页节点这 ...

  9. Linux基础五

    Yum软件包管理 yum:基于rpm包构建的软件更新机制 自动解决软件包依赖关系 所有软件包由集中的yum软件仓库提供. [root@hydra桌面]#ls /misc/cd/repodata/ (r ...

  10. 网络基础tcp/ip协议五

    传输层的作用: ip层提供点到点的链接. 传输层提供端到端的链接. 传输层的协议: TCP: 传输控制协议可靠的,面向链接的协议,传输效率低. UDP: 用户数据报协议,不可靠,无连接的服务,传输效率 ...