元类
python中,对象是由元类创建的,类也是一种对象,也就是说元类就是‘类的类’
eg、电脑中的cpu、内存等等。cpu、内存相当是x。
https://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000/001386820064557c69858840b4c48d2b8411bc2ea9099ba000
内置函数
内置函数 | 描述 |
---|---|
issubclass(sub, sup) | 如果类 sub 是类 sup 的子类,则返回 True,反之,为 False |
isinstance(obj1, obj2) | 如果实例obj1是类obj2或者obj2子类的一个实例;或者如果obj1 是 obj2 的类型,则返回 True;反之,为 False。 |
hasattr(obj, attr) | 如果 obj 有属性 attr(用字符串给出),返回 True,反之,返回 |
getattr(obj, attr[, default]) | 获取 obj 的 attr 属性;与返回 obj.attr 类似;如果 attr 不是 obj 的属性,如果提供了默认值,则返回默认值;不然, 就会引发一个 AttributeError 异 |
setattr(obj, attr, val) | 设置obj的attr属性值为val,替换任何已存在的属性值; 不然,就创建属性;类似于 obj.attr=val |
delattr(obj, attr) | 从 obj 中删除属性 attr(以字符串给出);类似于 del obj.attr |
dir(obj=None) | 返回 obj 的属性的一个列表;如果没有给定 obj,dir()则显示局部名字空间空间中的属性,也就是 locals().keys() |
super(type, obj=None) | 返回一个表示父类类型的代理对象;如果没有传入 obj, 则返 回的 super 对象是非绑定的;反之,如果 obj 是一个 type , issubclass(obj,type) 必 为 True ; 否 则 , isinstance(obj,type)就必为 True |
vars(obj=None) | 返回 obj 的属性及其值的一个字典;如果没有给出 obj, vars()显示局部名字空间字典(属性及其值),也就是 locals()。 |
常用的一些方法实例
class A(object):
def __init__(self,):
print( 'create an instance of',self.__class__.__name__)
@property
def name(self):
return self.__name
@name.setter
def name(self,__value):
self.__name = __value
def show(self):
print(self.__name )
class B(A):
pass
b= B()
a= A()
a.name = "limei"
print(a.show())
# 判断是否是子类
print(issubclass(B,A))
# 判断是否是实例或者子类的实例。是返回true,不是返回false。
print(isinstance(b,A))
print(hasattr(B,"name"))
定制类
python中有很多有特殊用途的函数,可用于扩充类。
实现: 1、模拟标准类型 2、重载操作符
**用来定制类的特殊方法 **
(http://blog.csdn.net/fdl19881/article/details/8443893)
以下只是部分,详细看上面链接
内置函数 | 描述 |
---|---|
init | 构造器(带一些可选的参数) |
new | 构造器 |
del | 构造器 |
str | 可打印的字符输出;内建 str()及 print 语句 |
repr | 运行时的字符串输出(用于调试) |
unicode | Unicode 字符串输出 |
call | 表示可调用的实例 |
nonzero | 为object 定义 False 值 ;内置bool() |
len | “长度”(可用于类);内建 len() |
cmp | 对象比较;内建 cmp() |
lt | 小于/小于或等于;对应<及<=操作符 |
gt | 大于/大于或等于;对应>及>=操作符 |
eq | 等于/不等于;对应==,!=及<>操作符 |
C.*add(self, obj) | 加;+操作符 |
C.*sub(self, obj) | 减;-操作符 |
C.*mul(self, obj) | 乘;*操作符 |
C.*div(self, obj) | 除;/操作符 |
新式类的常用法的解释
__init__ 创建完对象后调用,对当前对象的实例的一些初始化
__new__(cls, *args, **kwargs) 创建对象时调用,返回当前对象的一个实例,只有在新式类的情况下才会有的方法
new的作用
1、主要是当你继承一些不可变的class时(比如int, str, tuple), 提供给你一个自定义这些类的实例化过程的途径。还有就是实现自定义的metaclass
2、因为类每一次实例化后产生的过程都是通过__new__来控制的,所以通过重载__new__方法,我们 可以很简单的实现单例模式。
class Singleton(object):
def __new__(cls):
# 关键在于这,每一次实例化的时候,我们都只会返回这同一个instance对象
if not hasattr(cls, 'instance'):
cls.instance = super(Singleton, cls).__new__(cls)
return cls.instance
obj1 = Singleton()
obj2 = Singleton()
obj1.attr1 = 'value1'
print obj1.attr1, obj2.attr1
print obj1 is obj2
__call__
一个对象实例可以有自己的属性和方法,当我们调用实例方法时,我们用instance.method()来调用。能不能直接在
class Student(object):
def __init__(self, name):
self.name = name
def __call__(self):
print('My name is %s.' % self.name)
输出:
>>> s = Student('Michael')
>>> s()
My name is Michael.
__str__(重新定制打印方式)
class A(object):
@property
def name(self):
return self.__name
@name.setter
def name(self,__value):
self.__name = __value
def __str__(self):
return "this is student name is {0}".format(self.__name)
a=A()
a.name="test"
print(a)
输出如下:
this is student name is test
__iter__(返回迭代对象,用于 for in方法)
__getslice__、__setslice__、__delslice__(切片方法)
闭包(闭包(closure)是函数式编程的重要的语法结构)
闭包构成是:一个函数与他的环境变量结合,在Python中,所谓的闭包是一个包含有环境变量取值的函数对象。
def line_conf():
b = 15
def line(x):
return 2*x+b
return line
my_line = line_conf()
print(my_line(5))
分析:我们可以看到,line定义的隶属程序块中引用了高层级的变量b,但b信息存在于line的定义之外 (b的定义并不在line的隶属程序块中)。我们称b为line的环境变量。事实上,line作为line_conf的返回值时,line中已经包括b的取值(尽管b并不隶属于line)。
装饰器
python中一切都是对象,函数也是对象,因而可以当成参数传递。
装饰模式就是在调用目标函数之前,对这个函数队形进行装饰。
最简单的装饰模式如下:
def say_english():
print("hello")
def greet(say):
print("英语的你好怎么输出")
say()
print("了解了吗")
greet(say_english)
greet方法就是把say_English方法修饰。
输入如下:
英语的你好怎么输出
hello
了解了吗
如果把项目上的say_english(),都需要改为这样格式的输出,则需要把项目中的say_english()改为greet(say_english)这个方法,这样子需要大量的工程或者会改漏,为了调用say_english()也能达到greet(say_english),则修改如下:
def say_english():
print("hello")
def greet(say):
def wrapper():
print("英语的你好怎么输出")
say()
print("了解了吗")
return wrapper
say_english = greet(say_english)
say_english()
python中一切都是对象,那么greet()函数return的是wrapper的对象。
###语法糖@(python2.4之后才会出现)
python中@相当于 say_english = greet(say_english) 这句,修改如下:
def greet(say):
def wrapper():
print("英语的你好怎么输出")
say()
print("了解了吗")
return wrapper
@greet
def say_english():
print("hello")
say_english()