1. ''''''
    '''类装饰器'''
    class Test():
    def __init__(self,func):
    print('---初始化---')
    print('func name is %s'%func.__name__)
    self.__func = func
  2.  
  3. def __call__(self, *args, **kwargs):
    print('---类装饰器中的内容----')
    self.__func
  4.  
  5. @Test #相当于test = Test(test)
    def test():
    print('---test---')
  6.  
  7. test() #调用Test类中的__call__方法。
  8.  
  9. '''Python中万物皆对象,类也是一个对象,如下面一个类在定义后,他就是一个Person对象'''
    print('--------------------1---------------------')
    class Person():
  10.  
  11. print('----xxxxxx-------')
  12.  
  13. def __init__(self):
    self.name = 'an'
  14.  
  15. '''元类:元类就是用来创建类(对象)的,元类就是类的类。'''
    print('--------------------2---------------------')
    def printNum(self):
    print('----num-%d-----'%self.num)
    Test3 = type('Test3',(),{'printNum':printNum}) #type()就是来定义元类的,第一个参数:类名,第二个参数:父类,第三个参数:属性名或方法名。
    t3 = Test3()
    t3.num = 100
    t3.printNum()
  16.  
  17. #下面代码就和上边元类定义类效果一样,但是元类将类定义和方法定义分开,方便维护。
    class printNum2():
    def printNum(self):
    print('----num-%d-----' % self.num)
    t2 = printNum2()
    t2.num = 100
    t2.printNum()
  18.  
  19. #元类:metaclass_recv
    def upper_attr(a,b,c): #第一个参数:类名,第二个参数:类的父类,第三个参数:类的属性。
    #便利属性字典,把不是__开头的属性名字变为大写
    newAttr = {}
    for name,value in c.items():
    if not name.startswith("__"):
    newAttr[name.upper()] = value
  20.  
  21. #调用type来创建一个类
    return type (a,b,newAttr)
  22.  
  23. class Foo(metaclass=upper_attr): #设置Foo类的元类为upper_attr,作用是,创建类的时候决定创建的类是什么样子的,
    #创建类的时候先执行metaclass属性对应的东西。
    bar = 'bip'
  24.  
  25. print(hasattr(Foo,'bar'))
    print(hasattr(Foo,'BAR'))
  26.  
  27. f = Foo()
    print(f.BAR)
  28.  
  29. '''垃圾回收GC:引用计数为主,隔代回收为辅。'''
    print('--------------------3---------------------')
    #引用计数机制:对象引用计数为0时,垃圾回收。但解决不了循环引用。
    import gc
    class ClassA():
    def __init__(self):
    print('object born,id:%s'%str(hex(id(self))))
  30.  
  31. def f2():
    while True:
    c1 = ClassA()
    c2 = ClassA()
    c1.t = c2
    c2.t = c1
    del c1
    del c2
    gc.collect() #手动进行垃圾回收
  32.  
  33. # gc.disable() 关闭GC gc.enable() 开启GC
    # f2()
  34.  
  35. import sys
    a = ClassA()
    print(sys.getrefcount(a)) #查看对象引用个数
    #所谓垃圾回收就是调用对象的__del__方法。
  36.  
  37. '''内建属性'''
    print('--------------------4---------------------')
    class Itcast():
    def __init__(self,subject1):
    self.subject1 = subject1
    self.subject2 = 'cpp'
  38.  
  39. #属性访问时拦截器,打log
    def __getattribute__(self, item): #item--->"subject2"
    if item == 'subject1':
    print('log subject1')
    return 'redirect python'
    else: #测试时注释掉这2行,将找不到subject2
    return object.__getattribute__(self,item) #调用父类object的方法。
  40.  
  41. def show(self):
    print('this is Itcast')
  42.  
  43. s = Itcast("python")
    print(s.subject1)
    print(s.subject2)
    s.show() #先获取show属性对应的结果,,,应该是一个方法;方法()。
  44.  
  45. '''内建方法'''
    print('--------------------5---------------------')
    print(range(1,10)) #range()返回的是一个迭代值,什么时候用什么时候生成值,同生成器原理。
    # 如果想的得到列表,用list(rang())
    print(list(range(1,8,2))) #第三个参数是步长
  46.  
  47. #map():根据原有数据得到新的数据
    m = map(lambda x : x*x ,[1,2,3]) #[1,2,3]可迭代,但不是迭代对象
    for i in m:
    print(i)
  48.  
  49. m2 = map(lambda x,y : x+y,[1,2,3],[4,5,6])
    for i in m2:
    print(i)
  50.  
  51. def f1(x,y):
    return (x,y)
    l1 = [0,1,2,3,4,5,6]
    l2 = ['Sun','M','T','W','T','F','S']
    l3 = map(f1,l1,l2)
    print(list(l3))
  52.  
  53. #fileter():有筛选功能
    l4 = filter(lambda x : x%2,[1,2,3,4]) #function接受一个参数,返回布尔值True或False。
    print(list(l4))
  54.  
  55. l5 = filter(None,"she") #参数为None时不过滤
    print(list(l5))
  56.  
  57. from functools import reduce
    print(reduce(lambda x,y : x+y,[1,2,3,4]))
    print(reduce(lambda x,y : x+y,['aa','bb','cc'],'dd'))
  58.  
  59. ss = [1,3,2,5,4]
    print(sorted(ss)) #返回一个排序之后的新的列表
    print(ss)
    ss.sort() #将列表排序
    print(ss)
  60.  
  61. '''集合'''
    print('---------------------6--------------------')
    aaa = [11,22,11,22,33]
    print(set(aaa)) #集合去重
    #集合运算&、|、
    aa = {'a','b','c'}
    bb = {'a','c','d'}
    print(aa&bb)
    print(aa|bb)
    print(aa-bb)
    print(aa^bb) #对称差集
  62.  
  63. '''functools模块'''
    print('---------------------6--------------------')
    import functools
    print(dir(functools)) #functools模块中常用函数
    #偏函数
    def showarg(*args,**kwargs):
    print(args)
    print(kwargs)
  64.  
  65. p1 = functools.partial(showarg,1,2,3) #只需要传一次参数,后边再去调用这个函数的时候,相应的参数就不用再传了。
    p1()
    p1(4,5,6)
    p1(a='python',b='itcast')
  66.  
  67. #wraps函数
    def note(func):
    "note function"
    # @functools.wraps(func) #当加上这行,查看test()的说明文档时就会看到它原本的注释。
    def wrapper():
    "wrapper function2222"
    print('note something')
    return func()
    return wrapper
  68.  
  69. @note
    def test():
    "test function"
    print('I am test')
  70.  
  71. #使用装饰器时,有一些细节需要被注意,例如,被装饰后的函数其实已经是另外一个函数了(函数名等函数属性会发生改变)。
    #添加后由于函数名和函数的doc发生了改变,对测试结果有一些影响。
    print(help(test)) #此处函数的说明文档是装饰器中的说明文档,而非test()的原本的说明文档注释。
  72.  
  73. '''常见模块'''
    print('---------------------7--------------------')
    #常用标准库:
    #builtins:内建函数默认加载 os:操作系统接口 sys:Python自身的运行环境
    #functools:常用的工具 json:编码和解码JSON对象 logging:记录日志、调试
    #multiprocessing:多进程 threading:多线程 copy:拷贝
    #time:时间 datetime:日期和时间 calendar:日历
    #hashlib:加密算法 random:生成随机数 re:字符串正则匹配
    #socket:标准的BSD Sockets API shutil:文件和目录管理 glob:基于文件通配符搜索
    import hashlib
    m = hashlib.md5() #创建hash对象:md5:(message-Digest Algorithm 5)消息摘要算法,得出一个128位的密文。
    print(m) #<md5 HASH object>
    m.update(b'itcast') #更新哈希对象以字符串参数
    print(m.hexdigest())
  74.  
  75. #常用第三方扩展库:
    #requests:使用的是urllib3,继承了urllib2的所有特性 urlib:基于http的高层库 scrapy:爬虫
    #beautifulsoup4:HTML/XML的解析器 celery:分布式任务调度模块 redis:缓存
    #Pillow(PIL):图像处理 xlsxwriter:仅写excel功能,支持xlsx xlwt:仅写Excel,支持xls,2013或更早版office
    #xlrd:仅读Excel功能 elasticsearch:全文搜索引擎 pymysql:数据库连接库
    #mongoengine/pymongo:mongodbpython接口 matplotlib:画图 numpy/scipy:科学计算
    #diango/tornado/flask:web框架 xmltodict:xml转dict SimpleHTTPServer:简单的HTTPServer,不使用Web框架
    #gevent:基于协程的python网络库 fabric:系统管理 pandas:数据处理库
    #scikit-learn:机器学习库

类装饰器,元类,垃圾回收GC,内建属性、内建方法,集合,functools模块,常见模块的更多相关文章

  1. python 装饰器(五):装饰器实例(二)类装饰器(类装饰器装饰函数)

    回到装饰器上的概念上来,装饰器要求接受一个callable对象,并返回一个callable对象(不太严谨,详见后文). 那么用类来实现也是也可以的.我们可以让类的构造函数__init__()接受一个函 ...

  2. python装饰器2:类装饰器

    装饰器1:函数装饰器 装饰器2:类装饰器 装饰器3:进阶 本文是装饰器相关内容的第二篇,关于类装饰器. "类装饰器"有两种解读方式:用来装饰类的装饰器:类作为装饰器装饰其它东西.你 ...

  3. typescript装饰器定义 类装饰器 属性装饰器 装饰器工厂

    /* 装饰器:装饰器是一种特殊类型的声明,它能够被附加到类声明,方法,属性或参数上,可以修改类的行为. 通俗的讲装饰器就是一个方法,可以注入到类.方法.属性参数上来扩展类.属性.方法.参数的功能. 常 ...

  4. python高级 之(二) --- 类装饰器

    装饰器-初级 在不改变原有函数逻辑功能的基础上,为函数添加新的逻辑功能.使代码可读性更高.结构更加清晰.冗余度更低 简介 """ 闭包: 函数嵌套的格式就是闭包.写装饰器 ...

  5. 垃圾回收GC:.Net自己主动内存管理 上(三)终结器

    垃圾回收GC:.Net自己主动内存管理 上(三)终结器 垃圾回收GC:.Net自己主动内存管理 上(一)内存分配 垃圾回收GC:.Net自己主动内存管理 上(二)内存算法 垃圾回收GC:.Net自己主 ...

  6. python 描述符 上下文管理协议 类装饰器 property metaclass

    1.描述符 #!/usr/bin/python env # coding=utf-8 # 数据描述符__get__ __set__ __delete__ ''' 描述符总结 描述符是可以实现大部分py ...

  7. python 进阶篇 函数装饰器和类装饰器

    函数装饰器 简单装饰器 def my_decorator(func): def wrapper(): print('wrapper of decorator') func() return wrapp ...

  8. 详解Python闭包,装饰器及类装饰器

    在项目开发中,总会遇到在原代码的基础上添加额外的功能模块,原有的代码也许是很久以前所写,为了添加新功能的代码块,您一般还得重新熟悉源代码,稍微搞清楚一点它的逻辑,这无疑是一件特别头疼的事情.今天我们介 ...

  9. [b0019] python 归纳 (五)_类装饰器

    总结: 类装饰器, 本质是一个函数,输入一个类,返回一个类 Case 1 啥都没做 def deco(in_class): return in_class @deco class Cat: def _ ...

随机推荐

  1. 前后端分离djangorestframework——序列化与反序列化数据

    我们写好后端的代码,要把数据交给前端的展示的,这个数据以什么类型给前端呢?学到这里,我们已经知道这个数据最好是json字符串才行,因为网络间的传输,只认字符串或者二进制,字符串就是我们的数据,二进制就 ...

  2. Cs231n课堂内容记录-Lecture 4-Part1 反向传播及神经网络

     反向传播 课程内容记录:https://zhuanlan.zhihu.com/p/21407711?refer=intelligentunit 雅克比矩阵(Jacobian matrix) 参见ht ...

  3. LeetCode算法题-Happy Number(Java实现)

    这是悦乐书的第188次更新,第190篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第47题(顺位题号是202).编写算法以确定数字是否"幸福". 幸福 ...

  4. Android Studio教程03-Activtiy生命周期的理解

    目录 1. Activity 1.1. 安卓中的Activity定义和特性: 1.2. 注册Activity 1. Intent filters:设置默认开启的activity 1.3. Activi ...

  5. centos7下安装docker(18.3docker日志---logging driver---fluentd)

    前面我们学的ELK中用filebeat收集docker容器日志,利用的是dcoker默认的logging driver json-file,下面我们用fluentd来收集容器日志 Fluentd是一个 ...

  6. 简单的C#TCP协议收发数据示例

    参考:http://www.cnblogs.com/jzxx/p/5630516.html 一.原作者的这段话很好,先引用一下: Socket的Send方法,并非大家想象中的从一个端口发送消息到另一个 ...

  7. [matlab] 15.罚函数降维

    求非线性规划 min f(x)= x(1)^2 + x(2)^2 + 8 s.t. { x(1)^2-x(2)>=0 , -x(1) - x(2)^2 +2 = 0, x(1)>=0 ,x ...

  8. tensorflow中的name_scope, variable_scope

    在训练深度网络时,为了减少需要训练参数的个数(比如LSTM模型),或者是多机多卡并行化训练大数据.大模型等情况时,往往就需要共享变量.另外一方面是当一个深度学习模型变得非常复杂的时候,往往存在大量的变 ...

  9. 转://linux下hugepages理解

    就Linux应用程序而言,使用的都是虚拟地址,当应用程序读写一个指定的虚拟地址时,内存管理单元会自动进行虚拟地址到物理地址的转换.一个虚拟地址可以映射到多个物理地址,但当前映射到哪一个物理地址取决于当 ...

  10. 03 python 初学(字符格式化输出)

    #_author: lily #_date: 2018/12/16 name = input("your name: ") age = input("your age: ...