#-*- coding:utf8 -*-
# 静态方法@staticmethod
# 静态方法(当eat变成静态方法后,再通过实例调用时就不会自动把实例本身当作一个参数传给self了。)
class Dog(object):
def __init__(self, name):
self.name = name
#@staticmethod # 静态方法(当eat变成静态方法后,再通过实例调用时就不会自动把实例本身当作一个参数传给self了。)
def eat(self):
print("%s is eating" % self.name) d = Dog("ChenRonghua")
d.eat()
#报错信息
#TypeError: eat() missing 1 required positional argument: 'self'

# 类方法
# 类方法通过@classmethod装饰器实现,类方法只能访问类变量,不能访问实例变量
# (当eat变成静态方法后,再通过实例调用时就不会自动把实例本身当作一个参数传给self了。)
class Dog(object):
def __init__(self, name):
self.name = name
@staticmethod
def eat():
print("%s is eating")#因为name是个实例变量,类方法是不能访问实例变量的 d = Dog("ChenRonghua")
d.eat()

class Dog(object):
name = "我是类变量" def __init__(self, name):
self.name = name
self.__food=None @classmethod
def eat(self):
print("%s is eating" % self.name)
def __call__(self, *args, **kwargs):#构造方法:对象=类名() 而__call__ 则是:对象()
print("running call",args,kwargs) def __str__(self):
return 'obj:%s'%self.name d = Dog("ChenRonghua")
d(2,3,4,name='开发量')#__call__ 则是:对象()
print(d.__dict__)#打印的是实例属性{'name': 'ChenRonghua', '_Dog__food': None}
print(Dog.__dict__)#打印的是类的属性
print(d)#module对象想知道它是谁__str__ d.eat() #把一个类做成字典了
#属性方法
#属性方法的作用就是通过@property把一个方法变成一个静态属性 class Dog(object):
''' 类是描述狗这个对象'''
def __init__(self, name):
self.name = name @property
def eat(self):
print(" %s is eating" % self.name) d = Dog("ChenRonghua")
print (Dog.__doc__) #d.eat() #因为eat此时已经变成一个静态属性了, 不是方法了, 想调用已经不需要加()号了,直接d.eat就可以了
d.eat
#@property 的实例---航班查询
#这个status属性的值是一系列动作后才得到的结果 class fly(object):
def __init__(self,name):
self._name=name
def check_status(self):
print("%s fly status"%self._name)
return 2
@property
def fly_status(self):
status=self.check_status()
if status==0:
print ("quxiao")
elif status==1:
print("daoda")
elif status == 2:
print("ready")
else:
print("later")
d=fly("k7")
d.fly_status #-----------另一种
class fly(object):
def __init__(self,name):
self._name=name
def check_status(self):
print("%s fly status"%self._name)
return 2
def fly_status(self):
status=self.check_status()
if status==0:
print ("quxiao")
elif status==1:
print("daoda")
elif status == 2:
print("ready")
else:
print("later")
d=fly("k7")
d.fly_status()
#__doc__表示类的描述信息
class Foo:
""" 描述类信息,这是用于看片的神奇 """ def func(self):
pass print(Foo.__doc__)

#__call__对象后面加括号
#构造方法,即:对象 = 类名() ;
#__call__方法 即:对象() 或者 类()() class Foo:
def __init__(self):
print("__init__") def __call__(self, *args, **kwargs):
print('__call__') obj = Foo() # 执行 __init__ obj() # 执行 __call__
#如果一个类中定义了__str__方法,那么在打印 对象 时,默认输出该方法的返回值

class Foo:
def __str__(self):
return 'alex li'
obj = Foo()
print(obj)
#生命的起源是通过Type来实现的
def func(self):
print ("hello %s"%self.name) def __init__(self,name,age):
self.name=name
self.age=age foo=type("foo",(object,),{"talk":func,
"__init__":__init__})
f =foo("alex",32)
f.talk() print(type(foo)) #<class 'type'>
#-*- coding:utf8 -*-
class Dog():
def __init__(self,name):
self.name=name
def eat(self):
print ("%s is eating..."%self.name) d=Dog("zhangsan")
choice=input(">>:").strip()
# print (hasattr(d,choice))#>>:eat---True
# getattr(d,choice)() #zhangsan is eating...
if hasattr(d,choice):
func=getattr(d,choice)
func()
#-*- coding:utf8 -*-
def dulk(self):
print("%s is yelling.."%self.name)
class Dog():
def __init__(self,name):
self.name=name
def eat(self,food):
print ("%s is eating..."%self.name,food) d=Dog("zhangsan")
choice=input(">>:").strip()
# print (hasattr(d,choice))#>>:eat---True
# getattr(d,choice)() #zhangsan is eating...
if hasattr(d,choice):
func=getattr(d,choice)
func("lisi") #>>:eat --zhangsan is eating... lisi
#hasattr (obj,name_str)判断一个对象是否有对应的name_str字符串的
#getattr(obj,name_str)根据字符串去获取对象对应方法里的内存地址
else :
# setattr(d,choice,dulk)
# d.talk(d)
setattr(d,choice,32)
print(getattr(d,choice)) #>>:talk --32
#-*- coding:utf8 -*-
def dulk(self):
print("%s is yelling.."%self.name)
class Dog():
def __init__(self,name):
self.name=name
def eat(self,food):
print ("%s is eating..."%self.name,food) d=Dog("zhangsan")
choice=input(">>:").strip()
# print (hasattr(d,choice))#>>:eat---True
# getattr(d,choice)() #zhangsan is eating...
if hasattr(d,choice):
getattr(d,choice)
else :
# print(setattr(d,choice,None))
setattr(d,choice,dulk)
func=getattr(d,choice)
func(d)
#-*- coding:utf8 -*-
def dulk(self):
print("%s is yelling.."%self.name)
class Dog():
def __init__(self,name):
self.name=name
def eat(self,food):
print ("%s is eating..."%self.name,food) d=Dog("zhangsan")
choice=input(">>:").strip()
# print (hasattr(d,choice))#>>:eat---True
# getattr(d,choice)() #zhangsan is eating...
if hasattr(d,choice):
func=getattr(d,choice)
setattr(d ,choice,"xiaobai")
# func("lisi") #>>:eat --zhangsan is eating... lisi
#hasattr (obj,name_str)判断一个对象是否有对应的name_str字符串的
#getattr(obj,name_str)根据字符串去获取对象对应方法里的内存地址
else :
# setattr(d,choice,dulk)
# d.talk(d)
setattr(d,choice,32)
print(getattr(d,choice))
print(d.name) #>>:name----xiaobai
#setattr (obj,'y',z) is equitvalent to x.y=z 对对象添加新的属性

异常处理

#-*- coding:utf8 -*-
#---字典出错,列表出错
data={}
names=['zhangsan','lisi']
# data['name'] #KeyError: 'name'
try:
names[3] #这个报错,下一个错误就不会执行了
data['name'] except KeyError as e:
print('没有这个key',e)
except IndexError as e:
print("列表操作错误", e)
try_未知错误-Exception最后用
data={}
names=['zhangsan','lisi']
# data['name'] #KeyError: 'name'
try:
open("test.txt")
names[3] # 如果它放在try的第一位 就不报未知错误
data['name'] except KeyError as e:
print('没有这个key',e)
except IndexError as e:
print("列表操作错误", e)
except Exception as e: #错误排除不出来,最后报未知错误
print ("未知错误",e )
ValueError
#-*- coding:utf8 -*-
s1="hello"
try:
int(s1)
except ValueError as e:
print ("类型不正确",e)
两种错误都采用统一的处理办法
#-*- coding:utf8 -*-
#---字典出错,列表出错
data={}
names=['zhangsan','lisi']
# data['name'] #KeyError: 'name'
try:
names[3] #这个报错,下一个错误就不会执行了
data['name'] except (KeyError ,IndexError) as e:
print('没有这个key',e)
# except IndexError as e:
# print("列表操作错误", e)
自定义异常
#-*- coding:utf8 -*-
#__str__类返回什么格式
class flmException(Exception):
def __init__(self,msg):
self.message=msg
# def __str__(self):
# return self.message #替换为 return "abc"
try:
raise flmException("数据库连不上")
except flmException as e:
print(e)

												

python7 静态方法、类方法、属性方法 ;反射;异常处理的更多相关文章

  1. python静态方法类方法属性方法

    Python的静态方法和类成员方法都可以被类或实例访问,两者概念不容易理清,但还是有区别的: 1)静态方法无需传入self参数,类成员方法需传入代表本类的cls参数: 2)从第1条,静态方法是无法访问 ...

  2. 面向对象【day08】:静态方法、类方法、属性方法(九)

    本节内容 概述 静态方法 类方法 属性方法 总结 一.概述 前面我们已经讲解了关于类的很多东西,今天讲讲类的另外的特性:静态方法(staticmethod).类方法(classmethod).属性方法 ...

  3. python-day7-静态方法、类方法、属性方法、特殊成员方法、反射、异常处理、socket

    @特殊方法.异常处理.反射.socket @类 属性 实例变量 类变量 私有属性__var 方法 构造方法, 析构函数(python自带,不写也有,写了相当与重构) 私有方法 继承 继承 组合 @7. ...

  4. Python全栈开发之7、面向对象编程进阶-类属性和方法、异常处理和反射

    一.类的属性 1.@property属性 作用就是通过@property把一个方法变成一个静态属性 class Room: def __init__(self,name,length,width,he ...

  5. Python3学习之路~7.1 静态方法、类方法、属性方法

    静态方法 通过@staticmethod装饰器即可把其装饰的方法变为一个静态方法,什么是静态方法呢?其实不难理解,普通的方法,可以在实例化后直接调用,并且在方法里可以通过self.调用实例变量或类变量 ...

  6. Python 静态方法,类方法,属性方法

    方法的使用 静态方法 - 只是名义上归类管理,实际上在静态方法里访问不了类或实例中的任何属性. class Dog(object): def __init__(self,name): self.nam ...

  7. python第三十三天----静态方法、类方法、属性方法

    @staticmethod 装饰后,类中的方法转成静态方法 class a: @staticmethod def b(self): print('') 静态方法不可以访问实例变量或类变量,相当于类中的 ...

  8. Python面向对象静态方法,类方法,属性方法

    Python面向对象静态方法,类方法,属性方法 属性: 公有属性 (属于类,每个类一份) 普通属性 (属于对象,每个对象一份) 私有属性 (属于对象,跟普通属性相似,只是不能通过对象直接访问) 方法: ...

  9. python中的静态方法、类方法、属性方法(福利:关于几种方法更好的解释)

    该部分的三个属性都是高级方法,平时用的地方不是很多 一.静态方法 静态方法的使用不是很多,可以理解的就看一下,用的地方不是很多 class Dog(object): def __init__(self ...

随机推荐

  1. python os用法笔记

    获取文件所在路径 import os os.path.dirname(__file__)  获取当前文件的所在路径 print (os.path.dirname(os.path.dirname(__f ...

  2. C# 集合-并发处理-锁OR线程

    每次写博客,第一句话都是这样的:程序员很苦逼,除了会写程序,还得会写博客!当然,希望将来的一天,某位老板看到此博客,给你的程序员职工加点薪资吧!因为程序员的世界除了苦逼就是沉默.我眼中的程序员大多都不 ...

  3. Java基础之序列化对象——将对象写入到文件中(SerializeObjects)

    控制台程序. 首先定义一个含有任意不同数据类型域的可序列化类: import java.io.Serializable; public class Junk implements Serializab ...

  4. HTTP报文

    HTTP报文分为请求报文(request message)与响应报文(response message). 一.报文的组成部分 一个HTTP报文由3部分组成,分别是: (1).起始行(start li ...

  5. PHP的基本语法

    PHP的基本语法和c#的基本语法是差不多的,在这里只和大家聊一下PHP和C#语法不同的地方. 首先 PHP和c#的标记方式不一样,PHP他是一门脚本语言,JS也是脚本语言,只不过JS是运行在客户端的, ...

  6. java中时间的比较

    进入要比较从库中取出的时间,期初使用比较date.getTime()的值,但是当时间的年月日都相同时,时分秒较早的getTime()值比时分秒较晚的getTime()的值要大,至今笔者还不知这是为什么 ...

  7. editPlus修改默认的文件编码

  8. android 修改系统的dialog样式

    android 修改系统的dialog样式 一.觉得自定义配置文件麻烦?那就来修改系统自定义XML文件来实现修改系统dialog的样式吧. 如果是在XML中样式:首先来说下样式.  在 Style.x ...

  9. Mysql 修改字段长度、修改列名、新增列

    alter table 表名 modify column 字段名 类型; 例如 数据库中user表 name字段是varchar(30) 可以用 ) ; --修改字段长度 )--修改表列名 ); -- ...

  10. linux-批量重命名脚本

    #!/bin/bash # rename jpg and png count= for img in *.jpg *.png do new=image-$count.${img#*.} mv > ...