python7 静态方法、类方法、属性方法 ;反射;异常处理
#-*- 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 静态方法、类方法、属性方法 ;反射;异常处理的更多相关文章
- python静态方法类方法属性方法
Python的静态方法和类成员方法都可以被类或实例访问,两者概念不容易理清,但还是有区别的: 1)静态方法无需传入self参数,类成员方法需传入代表本类的cls参数: 2)从第1条,静态方法是无法访问 ...
- 面向对象【day08】:静态方法、类方法、属性方法(九)
本节内容 概述 静态方法 类方法 属性方法 总结 一.概述 前面我们已经讲解了关于类的很多东西,今天讲讲类的另外的特性:静态方法(staticmethod).类方法(classmethod).属性方法 ...
- python-day7-静态方法、类方法、属性方法、特殊成员方法、反射、异常处理、socket
@特殊方法.异常处理.反射.socket @类 属性 实例变量 类变量 私有属性__var 方法 构造方法, 析构函数(python自带,不写也有,写了相当与重构) 私有方法 继承 继承 组合 @7. ...
- Python全栈开发之7、面向对象编程进阶-类属性和方法、异常处理和反射
一.类的属性 1.@property属性 作用就是通过@property把一个方法变成一个静态属性 class Room: def __init__(self,name,length,width,he ...
- Python3学习之路~7.1 静态方法、类方法、属性方法
静态方法 通过@staticmethod装饰器即可把其装饰的方法变为一个静态方法,什么是静态方法呢?其实不难理解,普通的方法,可以在实例化后直接调用,并且在方法里可以通过self.调用实例变量或类变量 ...
- Python 静态方法,类方法,属性方法
方法的使用 静态方法 - 只是名义上归类管理,实际上在静态方法里访问不了类或实例中的任何属性. class Dog(object): def __init__(self,name): self.nam ...
- python第三十三天----静态方法、类方法、属性方法
@staticmethod 装饰后,类中的方法转成静态方法 class a: @staticmethod def b(self): print('') 静态方法不可以访问实例变量或类变量,相当于类中的 ...
- Python面向对象静态方法,类方法,属性方法
Python面向对象静态方法,类方法,属性方法 属性: 公有属性 (属于类,每个类一份) 普通属性 (属于对象,每个对象一份) 私有属性 (属于对象,跟普通属性相似,只是不能通过对象直接访问) 方法: ...
- python中的静态方法、类方法、属性方法(福利:关于几种方法更好的解释)
该部分的三个属性都是高级方法,平时用的地方不是很多 一.静态方法 静态方法的使用不是很多,可以理解的就看一下,用的地方不是很多 class Dog(object): def __init__(self ...
随机推荐
- python加密模块学习
1. md5模块 md5.new([arg]) 返回一个md5对象,如果给出参数,则相当于调用了update(arg) md5.update(arg) 用string参数arg更新md5对 ...
- ps 简介
1. ps 简介ps 命令就是最根本相应情况下也是相当强大地进程查看命令.运用该命令可以确定有哪些进程正在运行和运行地状态. 进程 是否结束.进程有没有僵死.哪些进程占用了过多地资源等等.总之大部分信 ...
- PostgreSQL 非持久化设置(Non-Durable Settings)
Durability is a database feature that guarantees the recording of committed transactions even if the ...
- keil 编译的一些错误
以前使用的是MDK4.5 但是没有stm32F3的元器件,果断的使用了4.6版本了.但是编译之后出现这样错误:linking....\Obj\prj.axf: Warning: L6373W: lib ...
- Eclipse Ctrl+Tab Alt+/ 快捷键
原来Eclipse的Next Editor 快捷键是 Ctrl+Tab 但是后几个版本将这个快捷键改为Ctrl+F6 了 在Keys设置下面 搜索 NextEditor 将其设置回来即可 同样 原来C ...
- Android 利用Service实现下载网络图片至sdk卡
package com.example.myapp5; import android.app.Activity; import android.content.Intent; import andro ...
- Android Notification通知栏使用
package com.example.mynotifycation; import android.app.Activity; import android.app.Notification; im ...
- 夺命雷公狗---Thinkphp----9之中间层的创建,防止跨目录访问
我们创建一个CommonController.class.php的中间层,让后让别的控制器都直接继承CommonController这个控制器即可决解跨目录访问的问题, <?php namesp ...
- SQL Server session故障排查
--根据作业名 查找session id select a.spid,a.blocked,b.name,substring(replace(a.PROGRAM_NAME,'SQLAgent - TSQ ...
- Android SDK Manager更新报错
错误log: Fetching https://dl-ssl.google.com/android/repository/addons_list-.xml Fetched Add-ons List s ...