一:类的方法说明

类的方法分为实例方法,析构方法,构造方法,类方法,静态方法,属性方法,等等

类方法和静态方法都可以被类和类实例调用,类实例方法仅可以被类实例调用

类方法的隐含调用参数是类,而类实例方法的隐含调用参数是类的实例,静态方法没有隐含调用参数

1)实例方法:类的实例能够使用的方法。

2) 析构方法:类中使用def __init__(self)定义的方法,也就是当该类被实例化的时候就会执行该函数。那么我们就可以把要先初始化的属性放到这个函数里面

3) 构造方法:__del__”就是一个析构函数了,当使用del 删除对象时,会调用他本身的析构函数,另外当对象在某个作用域中调用完毕,在跳出其作用域的同时析构函数也会被调用一次,这样可以用来释放内存空间

4)静态方法:是一种普通函数,就位于类定义的命名空间中,它不会对任何实例类型进行操作。

  使用装饰器@staticmethod定义静态方法。类对象和实例都可以调用静态方法。

  只是名义上归类管理,实际上在静态方法里访问不了类的实例 中的中的任何属性

5)类方法:类方法是将类本身作为对象进行操作的方法。类方法使用@classmethod装饰器定义。类方法:只能访问类变量,不能访问实例变量

6)属性方法的作用就是通过@property把一个方法变成一个静态属性

二:示例代码

  

# -*- coding:utf-8 -*-
__author__ = 'shisanjun' class Person(object): country="中国"#类的公有属性或者类属性 def __init__(self,name,age): #构造方法,在类的实例化的时候被调用,用来初始化一些属性的时候使用
self.name=name #实例属性
self.age=age
self.__salary="" #私有属性 def talk(self): #实例方法
print("实例方法:国家:%s,名称为:%s,年龄为:%s,薪水:%s" %(self.country,self.name,self.age,self.__salary)) #提供私有属性访问接口
def get_salary(self):
return self.__salary def __del__(self): #析构方法,在实例被销毁的时候被调用
print("Person is del") #静态方法
@staticmethod
def sayHi(coutry):
"""
print("welcome %s to china" %self.name)
会报TypeError: sayHi() missing 1 required positional argument: 'self'
只是名义上归类管理,实际上在静态方法里访问不了类的实例 中的中的任何属性。
当普通方法使用
"""
print("静态方法:welcome to" ,coutry) #类方法
@classmethod
def eat(self):
"""
print("%s eat baozi" %self.name)
报错:AttributeError: type object 'Person' has no attribute 'name'
类方法只能调用类属性(公有属性)
"""
print("类方法: in %s eat baozi" %self.country) #属性方法
@property
def eat2(self):
print("属性方法,把一个方法变成一个静态属性") p=Person("shi",23)
p.talk() #访问类属性
print(Person.country) #实例属性
print(p.name) #直接访问类的私有属性会报错
#print(p.__salary) #强制访问私有属性
print(p._Person__salary) #私有属性访问2:
print(p.get_salary()) #静态方法调用
p.sayHi("china") #类方法调用
p.eat() #属性方法调用
#p.eat2() 报错TypeError: 'NoneType' object is not callable,正确访问如下:
#调用会出以下错误, 说NoneType is not callable, 因为eat2此时已经变成一个静态属性了,
# 不是方法了, 想调用已经不需要加()号了
p.eat2

3)类属性访问,修改,删除

  

# -*- coding:utf-8 -*-
__author__ = 'shisanjun' class Flight(object): def __init__(self,name):
self.flight_name=name def checking_status(self):
print("checking flight %s status" %self.flight_name)
return 1 @property
def flight_status(self): status=self.checking_status() if status == 0 :
print("flight got canceled...")
elif status == 1 :
print("flight is arrived...")
elif status == 2:
print("flight has departured already...")
else:
print("cannot confirm the flight status...,please check later") @flight_status.setter #修改
def flight_status(self,status):
status_dic = {
0 : "canceled",
1 :"arrived",
2 : "departured"
}
print("\033[31;1mHas changed the flight status to \033[0m",status_dic.get(status) ) @flight_status.deleter #删除
def flight_status(self):
print("status got removed...") f = Flight("CA980")
f.flight_status
f.flight_status = 2 #触发@flight_status.setter
del f.flight_status #触发@flight_status.deleter

4)类的特殊成员方法

1.__doc__表示类的描述信息

  

# -*- coding:utf-8 -*-
__author__ = 'shisanjun' class Person(object):
"""
介绍人的类
"""
def sayhi(self):
print("hi") p=Person()
print(p.__doc__)
"""
结果:介绍人的类
"""

2.__module__和__class__

 __module__表示当前操作对象在那个模块

 __class__表示当前操作的对象的类是什么

  

3.__init__构造方法,通过类创建对象时,自动解发执行。

4.__del__ 析构方法,当对象在内存中被释放时,自动触发执行,析构函数的调用是由解释器在进行垃圾回收时自动触发执行的

5.__call__对象后面加括号,触发执行。构造方法的执行是由创建对象触发的,即:对象 = 类名() ;而对于 __call__ 方法的执行是由对象后加括号触发的,即:对象() 或者 类()()

# -*- coding:utf-8 -*-
__author__ = 'shisanjun' class Person(object):
"""
介绍人的类
"""
def sayhi(self):
print("hi")
def __call__(self, *args, **kwargs):
print("use __call__") p=Person()
p()

6.__dict__查看类或对象中所有成员

# -*- coding:utf-8 -*-
__author__ = 'shisanjun' class Provice:
country="china" def __init__(self,name,count):
self.name=name
self.count=count def func(self,*args,**kwargs):
print("func") #获取类的成员,即静态字段,方法(不包括实例变量)
print(Provice.__dict__) obj1=Provice("s",23)
#获取实例的成员
print(obj1.__dict__) """
结果
{'__module__': '__main__', 'country': 'china', '__init__': <function Provice.__init__ at 0x0000000002AA28C8>, 'func': <function Provice.func at 0x0000000002AA2950>, '__dict__': <attribute '__dict__' of 'Provice' objects>, '__weakref__': <attribute '__weakref__' of 'Provice' objects>, '__doc__': None}
{'name': 's', 'count': 23} """

7.__str__如果类中定义了__str__访求,那么打印对象时,默认输出该方法的返回结果

# -*- coding:utf-8 -*-
__author__ = 'shisanjun' class Foo(object):
def __str__(self):
return "" obj=Foo()
print(obj)

8.__getitem__、__setitem__、__delitem__

# -*- coding:utf-8 -*-
__author__ = 'shisanjun' class Foo(object):
def __getitem__(self, key):
print("__getitem__",key) def __setitem__(self, key, value):
print("__setitem__",key,value) def __delitem__(self, key):
print("__delitem",key) obj=Foo()
result=obj['k1'] #触发__getitem__
obj['k2']=22 #触发__setitem__
del obj['k3'] #触发__delitem__

python基础--类的方法的更多相关文章

  1. Python基础——类new方法与单例模式

    介绍: new方法是类中魔术方法之一,他的作用是给类实例化开辟一个内存地址,并返回一个实例化,再由__init__对这个实例进行初始化,故它的执行肯定就是在初始化方法__init__之前了.new方法 ...

  2. python基础——类和实例

    python基础——类和实例 面向对象最重要的概念就是类(Class)和实例(Instance),必须牢记类是抽象的模板,比如Student类,而实例是根据类创建出来的一个个具体的“对象”,每个对象都 ...

  3. Python基础-类

    Python基础-类 @(Python)[python, python基础] 写在前面 如非特别说明,下文均基于Python3 摘要 本文重点讲述如何创建和使用Python类,绑定方法与非绑定方法的区 ...

  4. python基础——类名称空间与对象(实例)名称空间

    python基础--类名称空间与对象(实例)名称空间 1 类名称空间 创建一个类就会创建一个类的名称空间,用来存储类中定义的所有名字,这些名字称为类的属性 而类的良好总属性:数据属性和函数属性 其中类 ...

  5. python基础——类定义(转)

    一.类定义: class <类名>: <语句> 类实例化后,可以使用其属性,实际上,创建一个类之后,可以通过类名访问其属性.如果直接使用类名修改其属性,那么将直接影响到已经实例 ...

  6. Python菜鸟之路:Python基础-类(1)——概念

    什么是类? 在python中,把具有相同属性和方法的对象归为一个类(class).类是对象的模板或蓝图,类是对象的抽象化,对象是类的实例化.类不代表具体的事物,而对象表示具体的事物. 类的创建 cla ...

  7. Python基础——类

    创建类 class people: '帮助信息:dsafdaf' #所有实例都会共享的 number=100 #构造函数,初始化的方法,当创建一个类的时候,首先会调用它 def __init__(se ...

  8. 【原】Python基础-类

    class CPerson: name = "default" __name2 = "inaccessable name" #类作用域内的变量可以被所有实例访问 ...

  9. Python 入门之Python基础数据类型及其方法

    Python 入门之Python基础数据类型 1. 整型:int 用于计算,用于比较 (在赋值的时候先执行等号右边的内容) 1.1 整数的加 a = 10 b = 20 print(a + b) 结果 ...

随机推荐

  1. 51nod 1376 最长上升子序列的数量 | DP | vector怒刷存在感!

    51nod 1376 最长上升子序列的数量 题解 我们设lis[i]为以位置i结尾的最长上升子序列长度,dp[i]为以位置i结尾的最长上升子序列数量. 显然,dp[i]要从前面的一些位置(设为位置j) ...

  2. BZOJ2079 [Poi2010]Guilds 【贪心】

    题目链接 BZOJ2079 题解 题意就是黑白染色,要求相邻点存在不同颜色的点 显然从一个点出发,相邻点如果没有染色,染不同颜色,那么一个联通块一定会满足要求 证明:在\(dfs\)树上,每个点父亲和 ...

  3. MySQL总结小妙招

    mysql5.7版本,免登陆修改管理员密码: vim /etc/my.cnf 加入skip-grant-tables,重启MySQL 终端输入 mysql ,直接登录MySQL数据库,然后use my ...

  4. 【loj2586】【APIO2018】选圆圈

    题目 有 \(n\) 个圆$c_1,c_2, \cdots , c_n $,执行如下的操作: 找到剩下的半径最大的圆删除并删除所有和它有交的其他并没有被删除的圆: 求每个圆是被那个圆删除的: $1 \ ...

  5. Linux运维二:CentOS6.6系统安装后的基本配置与优化

    CentOS6.6系统安装完成后还需要做一些配置与优化: 一:Linux内核版本号介绍 查看内核版本: [root@Gin scripts]# uname -r 2.6.32-504.el6.x86_ ...

  6. Logistic Ordinal Regression

    sklearn实战-乳腺癌细胞数据挖掘(博客主亲自录制视频教程) https://study.163.com/course/introduction.htm?courseId=1005269003&a ...

  7. Casting a Classifier into a Fully Convolutional Network将带全连接的网络做成全卷积网络

    详见:http://nbviewer.jupyter.org/github/BVLC/caffe/blob/master/examples/net_surgery.ipynb 假设使用标准的caffe ...

  8. spring cloud 配置中心

    1. spring cloud配置中心server 1.1 创建git仓库 首先在github上搭建一个存储配置中心的仓库,需要创建两个分支,一个是master,一个是dev分支.自己学习可以用公开库 ...

  9. uboot常用命令详解

    dnw:在进入系统之前进入指令行,输入该指令可下载烧录文件. re:重新启动嵌入式系统. printenv:打印当前系统环境变量. setenv:设置环境变量,格式:setenv name value ...

  10. DFS——>记忆化搜索——>动态规划

    以洛谷P1802  5倍经验日 为例 https://www.luogu.org/problem/show?pid=1802 题目背景 现在乐斗有活动了!每打一个人可以获得5倍经验!absi2011却 ...