博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
类的特殊方法
阅读量:6119 次
发布时间:2019-06-21

本文共 2304 字,大约阅读时间需要 7 分钟。

静态方法(只是名义上归类管理,但实际上在今天方法里无法访问类或实例中的任何属性)

class cat(object):def __init__(self,name):    self.name=name@staticmethod # 实际上和类没关系了def eat(self):    print("%s is eating %s "%(self.name,"food"))

c=cat("alex")

c.eat(c) #强行有关系要把实例传进去(其实就是一个函数)

类方法

class cat(object):name="alex" # 类变量def __init__(self,name):    self.name=name@classmethod # 类方法只能访问类变量,不能访问实例变量def eat(self):    print("%s is eating %s "%(self.name,"food"))

c=cat("拉大")

c.eat() #强行有关系要把实例传进去(其实就是一个函数)

属性方法(把一个方法变成静态属性)

class cat(object):name="alex" # 类变量def __init__(self,name):    self.name=name    self.__food=None #创建一个私有属性@property # 把一个方法变成静态属性(属性正常无法传参数)def eat(self):    print("%s is eating %s " % (self.name,self.__food))@eat.setter #(修改)(属性传参数方法)def eat(self,food):    print("set food is " , food)    self.__food=food#给私有属性赋值来达到给静态属性传参数功能@eat.deleter #(删除属性方法)def eat(self):    del self.__food    print("删完了")

c=cat("拉大")

c.eat #方法变成静态属性能直接调用
c.eat="汉堡"
c.eat

del c.eat

c.eat

类的特殊成员方法

doc方法

class cat(object):'''猫的类'''pass

c=cat()

print(cat.doc) #输出类的描述信息(猫的类)
print(c.doc)#输出类的描述信息(猫的类)

module和class方法

from ttt import opp

pp=opp()
print(pp.module) #输出类是从哪个模块导入的
print(pp.class) # 输出类本身路径什么的

call方法

class dog(object):def __init__(self,name):    self.name=namedef eat(self):    print("eat all the others!")def __call__(self,*args,**kwargs):    print("all for one the",args,kwargs)

d=dog("alex")

d() # 运行call方法
dog("alex")() # 运行call方法
d(name="alex")

dict和str方法

class dog(object):def __init__(self,name):    self.name=namedef eat(self):    print("eat all the others!")def __call__(self,*args,**kwargs):    print("all for one the",args,kwargs)def __str__(self):  #返回一个谁的对象    return "[obj:%s]"%self.name #(返回值给print(d))

d=dog("alex")

print(d) # 输出str返回值
print(dog.dict) #打印类里的所有属性,不包括实例属性
print(d.dict) #打印所有实例属性,不包括类的属性

变成字典的形式

class   Foo(object):def __init__(self):     self.data={}def __getitem__(self, key):    print('__getitem__', key)    return self.data.get(key)def __setitem__(self, key, value):    print('__setitem__', key, value)    self.data[key]=valuedef __delitem__(self, key):    print('__delitem__', key) #到这一步其实没有删掉,是否删自己决定

obj = Foo()

result = obj['k1'] # 自动触发执行 getitem

obj['k2'] = 'alex' # 自动触发执行 setitem
print(obj["k2"])
#print(obj.data)
#obj
#del obj['k1']#到这一步其实没有删掉,是否删自己决定

转载于:https://blog.51cto.com/12992048/2295233

你可能感兴趣的文章
三级菜单
查看>>
Data Wrangling文摘:Non-tidy-data
查看>>
加解密算法、消息摘要、消息认证技术、数字签名与公钥证书
查看>>
while()
查看>>
常用限制input的方法
查看>>
Ext Js简单事件处理和对象作用域
查看>>
IIS7下使用urlrewriter.dll配置
查看>>
12.通过微信小程序端访问企查查(采集工商信息)
查看>>
WinXp 开机登录密码
查看>>
POJ 1001 Exponentiation
查看>>
HDU 4377 Sub Sequence[串构造]
查看>>
云时代架构阅读笔记之四
查看>>
WEB请求处理一:浏览器请求发起处理
查看>>
Lua学习笔记(8): 元表
查看>>
PHP经典算法题
查看>>
LeetCode 404 Sum of Left Leaves
查看>>
醋泡大蒜有什么功效
查看>>
hdu 5115(2014北京—dp)
查看>>
数据结构中常见的树(BST二叉搜索树、AVL平衡二叉树、RBT红黑树、B-树、B+树、B*树)...
查看>>
PHP读取日志里数据方法理解
查看>>