Python的三大神器,你知道是哪三大嗎?史上最詳細的入門教程!

Python的三大神器:裝飾器.迭代器與生成器!這就是Python的三大神器,好了廢話不多說。直接來上乾貨吧!

生成器

僅僅擁有生成某種東西的能力,如果不用__next__方法是獲取不到值得。

創建一個生成器函數

>>> def scq():... print("11")# 當函數代碼塊中遇到yield關鍵字的時候,這個函數就是一個生成器函數... yield 1... print("22")... yield 2... print("33")... yield 3...

把生成器賦值給一個對象

>>> r = scq()

查看r的蘇劇類型並且輸出r的值

>>> print(type(r),r) 

當執行生成器的__next__的時候,代碼會按照順序去執行,當執行到yield時會返回並提出,yield後面的值就是返回值,然後記錄代碼執行的位置,並退出

Python的三大神器,你知道是哪三大嗎?史上最詳細的入門教程!

Python的三大神器,你知道是哪三大嗎?史上最詳細的入門教程!

執行結果

C:\Python35\python.exe F:/Python_code/sublime/Week5/Day03/s1.py0 1 2 3 4Process finished with exit code 0

迭代器

具有訪問生成器的能力,可以訪問到生成器的值,類似於生成器的__next__方法,一個一個值一個值得去迭代,只能夠按照順序的去查找。

特點:

  1. 訪問者不需要關心迭代器內部的結構,僅需通過next()方法不斷去取下一個內容
  2. 不能隨機訪問集合中的某個值 ,只能從頭到尾依次訪問
  3. 訪問到一半時不能往回退
  4. 便於循環比較大的數據集合,節省內存

優化上面range或xrange的生成器

def irange(start, stop, step=1): while start != stop: yield start start += step  else:  raise StopIteration for n in irange(1, 10): """for循環只要遇到StopIteration就會停止"""  print(n)ret = irange(1, 20) print(ret) # 返回一個生成器,相當於只在內存中創建了一個值 print(list(ret)) # 如果想要得到全部的值,變成列表就可以
  1. /Library/Frameworks/Python.framework/Versions/3.5/bin/python3.5 /Users/ansheng/MyPythonCode/hello.py
  2. 1
  3. 2
  4. 3
  5. 4
  6. 5
  7. 6
  8. 7
  9. 8
  10. 9
  11. [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19]

  12. Process finished with exit code 0

Python之裝飾器

Python的三大神器,你知道是哪三大嗎?史上最詳細的入門教程!

現要在執行func這個函數前後執行一些操作,就可以創建一個裝飾器來實現:

  1. #!/usr/bin/env python
  2. # _*_ coding: utf-8 _*_

  3. def decorator(func): # 創建一個裝飾器函數,接受的參數arg參數就是func函數名

  4. def inner(*args, **kwargs):
  5. print("執行函數之前")
  6. ret = func(*args, **kwargs)
  7. print("執行函數之後")
  8. return ret

  9. return inner

  10. @decorator # 如果要讓某個函數使用裝飾器,只需要在這個函數上面加上@+裝飾器名
  11. def func(arg):
  12. print(arg)

  13. func("Hello World!")

輸出結果為:

  1. /usr/bin/python3.5 /home/ansheng/Documents/PycharmProjects/blogcodes/裝飾器.py
  2. 執行函數之前
  3. Hello World!
  4. 執行函數之後

  5. Process finished with exit code 0

多個裝飾器裝飾同一個函數

  1. #!/usr/bin/env python
  2. # _*_ coding: utf-8 _*_

  3. def decorator1(func):
  4. def inner():
  5. print("開始之前執行裝飾器01")
  6. ret = func()
  7. print("結束之後執行裝飾器01")
  8. return ret

  9. return inner


  10. def decorator2(func):
  11. def inner():
  12. print("decorator2>>>Start...")
  13. ret = func()
  14. print("decorator2>>>End...")
  15. return ret

  16. return inner


  17. @decorator1
  18. @decorator2
  19. def index():
  20. print("執行函數...")

  21. index()

輸出結果:

  1. /usr/bin/python3.5 /home/ansheng/Documents/PycharmProjects/blogcodes/裝飾器.py
  2. 開始之前執行裝飾器01
  3. decorator2>>>Start...
  4. 執行函數...
  5. decorator2>>>End...
  6. 結束之後執行裝飾器01

  7. Process finished with exit code 0

更多實例

  1. #!/usr/bin/env python
  2. # _*_ coding:utf-8 _*_

  3. # Created by 安生 on 2017/2/9

  4. """
  5. 函數裝飾器
  6. """


  7. def decorator(func):
  8. def wrapped(*args, **kwargs):
  9. return func(*args, **kwargs)

  10. return wrapped


  11. @decorator
  12. def func(a, b):
  13. return a + b


  14. print(func(1, 2))
  15. """
  16. 類裝飾器
  17. """


  18. class decorator:
  19. def __init__(self, func):
  20. self.func = func

  21. def __call__(self, *args, **kwargs):
  22. return self.func(*args, **kwargs)


  23. @decorator
  24. def func(a, b):
  25. return a + b


  26. print(func(1, 2))
  27. """
  28. 帶參數的函數裝飾器
  29. """


  30. def parameter(a, b):
  31. print(a, b)

  32. def decorator(func):
  33. def wrapped(*args, **kwargs):
  34. return func(*args, **kwargs)

  35. return wrapped

  36. return decorator


  37. @parameter(1, 2)
  38. def func(a, b):
  39. return a + b


  40. print(func(10, 20))
  41. """
  42. 帶參數的類裝飾器
  43. """


  44. def parameter(a, b):
  45. print(a + b)

  46. class decorator:
  47. def __init__(self, func):
  48. self.func = func

  49. def __call__(self, *args, **kwargs):
  50. return self.func(*args, **kwargs)

  51. return decorator


  52. @parameter(1, 2)
  53. def func(a, b):
  54. return a + b


  55. print(func(10, 20))

  56. """
  57. 帶參數的類裝飾器
  58. """


  59. def parameter(a, b):
  60. print(a, b)

  61. def decorator(cls):
  62. class wrapped:
  63. def __init__(self, *args, **kwargs):
  64. self.cls = cls(*args, **kwargs)

  65. def __getattr__(self, item):
  66. return getattr(self.cls, item)

  67. return wrapped

  68. return decorator


  69. @parameter(1, 2)
  70. class CLS:
  71. def __init__(self):
  72. self.a = 'a'

  73. def P(self, v):
  74. print(v)


  75. obj = CLS()
  76. print(obj.a)
  77. obj.P('Hello,')

  78. """
  79. 為函數中和類中的方法添加裝飾器
  80. """


  81. def Call(aClass):
  82. calls = 0

  83. def onCall(*args, **kwargs):
  84. nonlocal calls
  85. calls += 1
  86. print('call %s to %s' % (calls, func.__name__))
  87. return aClass(*args, **kwargs)

  88. return onCall


  89. @Call
  90. def func(a, b):
  91. return a + b


  92. print(func(1, 2))


  93. class CLS:
  94. def __init__(self):
  95. self.a = 'a'

  96. @Call
  97. def b(self):
  98. return self.a


  99. obj = CLS()
  100. print(obj.b())
Python的三大神器,你知道是哪三大嗎?史上最詳細的入門教程!


分享到:


相關文章: