多进程并发机制,内建函数getattr工厂格局

python多进程并发机制:

getattr()这些艺术最关键的机能是贯彻反射机制。也等于说能够经过字符串获取方式实例。  传入差别的字符串,调用的措施不等同。

python元类:**type()   **

此间运用了multprocessing.Pool进度池,来动态扩展进度

原型:getattr(对象,方法名)

元类是python高阶语法.
合理的选择能够收缩大气重复性的代码.

#coding=utf-8
from multiprocessing import Pool
import time
def ft(x):
  #多任务,系统自动化配进程执行
  for i in range(2):
    print i,'-----------',x
    time.sleep(1)



def main_process():
    pool = Pool(processes=4) #控制进程池的大小,为4个进程
    for i in range(10):
        #添加入进程池,apply带_async,单独apply为阻塞版本;函数名target,参数args
        result = pool.apply_async(ft,(i,))

    pool.close()
    pool.join()

    if result.successful():
        print('_____success_____')


if __name__=="__main__":
    main_process()

 

 

运作结果:

举个栗子:

元类实际上做了以下三地点的干活:

C:Python27python.exe D:/weixin/temp/testtmp.py
0 ----------- 0
0 ----------- 1
0 ----------- 2
0 ----------- 3
1 ----------- 0
1 ----------- 1
1 ----------- 2
1 ----------- 3
0 ----------- 4
0 ----------- 5
0 ----------- 6
0 ----------- 7
1 ----------- 4
1 ----------- 5
1 ----------- 6
1 ----------- 7
0 ----------- 8
0 ----------- 9
1 ----------- 8
1 ----------- 9
_____success_____

Process finished with exit code 0

pyMethod类下定义了七个章程,getattr(pyMethod(),’out%s’%str)()  
传入的不二等秘书诀名不一样,调用分歧的格局。些处方法名称叫字符串。

 

从上述运营结果能够看来,壹遍最多实行了作者们设定的4个进度。

这样的话,想一想是还是不是用项非常多,作者得以把艺术名配置到文件中,读取时利用getattr动态去调用。

  • 干预创设类的进度
  • 修改类
  • 重临改过现在的类

 

#coding=utf-8

class pyMethod(object):
    def outstr(self):
        print('this is string')

    def outint(self):
        print('this is number')

    def outdate(self):
        print('this is date')


if __name__=="__main__":
    str = 'int'
    getattr(pyMethod(),'out%s'%str)()     
    str = 'str'
    getattr(pyMethod(),'out%s'%str)()
    str = 'date'
    getattr(pyMethod(),'out%s'%str)()

 

 

 

怎么使用元类?

 

为什么要选用元类这种歪曲且易于出错的效果与利益?
貌似情状下,大家并不会利用元类,99%的开采者并不会用到元类,所以日常不要寻思那个标题。
元类主用用于创立API,叁个第一名的例证正是Django的ORM。
它让大家得以如此定义三个类:

 

class Person(models.Model):
  name = models.CharField(max_length=30)
  age = models.IntegerField()

 

运行上面包车型地铁代码:

guy = Person(name='bob', age='35')
print(guy.age)

回到的结果是int品类并不是IntegerField对象。那是因为models.Model行使了元类,它会将Python中定义的字段转变来数据库中的字段。
因此选拔元类,Django将复杂的接口转换来轻松的接口。

 

原型:type(类名,基类元组(可以为空,用于继承), 包含属性或函数的字典)

 以下三种写法都得以:

type(‘Class’,(object,),dict(hello=fun()))

type(‘Class’,(object,),{“hello”:fun()})

1、class 自定义的类名称

2、(object,卡塔 尔(阿拉伯语:قطر‎是世袭类,的元组,如果独有一个就写这种时势(object,);几个(object,xxxx,)

3、dict(hello=fun()) 或 {“hello”:fun()}
第多个参数,是三个字典等号左是
自定义的章程名,侧边是已写好的措施名,那些要小心,有参数且并未有私下认可值的情状下,要加括号;

 

def fun():
    print('hello world!')


if __name__=="__main__":

    h = type('Hello',(object,),dict(hello=fun()))
    tc = h()
    tc.hello

 

引用:

h 也正是收到Hello类;tc
= h()实例化类;tc.hello方法,调用的实在是我们定义的fun方法。

    Hello = type('Hello',(object,),dict(hello=fun()))
    tc = Hello()
    tc.hello

 type()动态创立类后,还是能增添越多的秘技和天性:

def mysql():
    conn = pymysql.connect(host='127.0.0.1',port=3306 ,user='root' ,passwd='q123456' ,db='amsql' )
    cur = conn.cursor()
    sql = "SELECT * FROM amt_case_interface_table"
    ret = cur.execute(sql)
    print(cur.fetchmany(3))
    #conn.commit()

    cur.close()
    conn.close()

Hello.mysql = mysql()

调用:

tc.mysql

 

Linux and
python学习调换1,2群已满.

Linux and
python学习沟通3群新开,招待参预,一同学习.qq 3群:563227894

不前行,不倒退,结束的景色是从未的.

联机前进,与君共勉,

 

Linux and
python学习交换1,2群已满.

 getattr(pyMethod(),'out%s'%str)()  注意pyMethod()和最后的()   这里之所以这么写pyMethod()加括号是实例化类对象,最后的括号,因为getattr函数反射后,是一个方法对象。

Linux and
python学习沟通3群新开,应接参与,一同学习.qq 3群:563227894

 

不前行,不倒退,截至的状态是未曾的.

运转结果:

同步前进,与君共勉,

C:Python27python.exe D:/weixin/python_getattr.py
this is number
this is string
this is date

Process finished with exit code 0

 

 

Linux and
python学习交换1,2群已满.

Linux and
python学习交换3群新开,应接参加,一齐学习.qq 3群:563227894

不前行,不倒退,截至的情事是未曾的.

协办发展,与君共勉,

发表评论

电子邮件地址不会被公开。 必填项已用*标注