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 ...
随机推荐
- CentOS安装Git
准备安装Gityum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel perl-devel #下载git-1 ...
- 新版mysql(mysql-5.7.12-winx64)安装
之前安装了一个php集成运行环境的mysql,不太习惯,还是想弄一个原生的环境来进行学习.于是,卸载了php集成环境中的mysql. 计算机环境:win7 x64. 1.mysql-5.7.12-wi ...
- Java最全文件操作实例汇总
本文实例汇总了Java文件操作.分享给大家供大家参考,具体如下: 1.创建文件夹 ? 1 2 3 4 5 6 7 8 9 10 11 //import java.io.*; File myFolder ...
- Lintcode: Segment Tree Query II
For an array, we can build a SegmentTree for it, each node stores an extra attribute count to denote ...
- Codeforce Round #214 Div2
我是不是快要滚蛋了,这次CF爆0? 居然第一题都过不去了,妈蛋附近有没有神经病医院,我要去看看! 精力憔悴! 第一题,我以为要恰好这么多钱,不能多余,想想这也没必要,不符合逻辑,及自己就是这么傻逼! ...
- [转] linux中常用的命令
系统信息 arch 显示机器的处理器架构(1) uname -m 显示机器的处理器架构(2) uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 - (SMBIOS ...
- 0422 数学口袋精灵app
首先要部署这个app项目就是第一步: 一.前提下载并安装JDK 在线图解:手把手教你安装JDK http://www.lvtao.net/server/windows-setup-jdk.h ...
- 关于C# winform 快速制作不规则边框的方法
今天逛博客园突然发现一个帖子写的 快速建立不规则边框的方式 突然发现以前自己用API的方式好傻… 杀鸡焉用牛刀 下边是从网上不断转载的 原帖: 地址:http://www.cnblogs.com ...
- 10---Net基础加强
复习: using System; using System.Collections.Generic; using System.Linq; using System.Text; using Syst ...
- react tab
<!DOCTYPE html> <html> <head> <script src="js/react.js"></scrip ...