奇酷教育-Python培训|UI培训|WEB大前端培训|Unity3D培训|HTML5培训|人工智能培训|JAVA开发的教育品牌

您現在所在的位置:首頁 >關于奇酷 > 行業動態 > 七個好用的裝飾器

七個好用的裝飾器

來源:奇酷教育 發表于:

七個好用的裝飾器

  七個好用的裝飾器:

 
  1、dispach
  Python 天然支持多態,但使用 dispatch 可以讓你的代碼更加容易閱讀。
 
  安裝:
 
  pip install multipledispatch
  使用:
 
  >>> from multipledispatch import dispatch
 
  >>> @dispatch(int, int)
  ... def add(x, y):
  ...     return x + y
 
  >>> @dispatch(object, object)
  ... def add(x, y):
  ...     return "%s + %s" % (x, y)
 
  >>> add(1, 2)
  3
 
  >>> add(1, 'hello')
  '1 + hello'
 
  2、click
  click 可以很方便地讓你實現命令行工具。
 
  安裝:
 
  pip install click
  使用:demo2.py :
 
  import click
 
  @click.command()
  @click.option('--count', default=1, help='Number of greetings.')
  @click.option('--name', prompt='Your name',
                help='The person to greet.')
  def hello(count, name):
      """Simple program that greets NAME for a total of COUNT times."""
      for x in range(count):
          click.echo(f"Hello {name}!")
 
  if __name__ == '__main__':
      hello()
  運行結果:
 
  ? python demo2.py --count=3 --name=joih
  Hello joih!
  Hello joih!
  Hello joih!
  ? python demo2.py --count=3
  Your name: somenzz
  Hello somenzz!
  Hello somenzz!
  Hello somenzz!
 
  3、celery
  分布式的任務隊列,非 Celery 莫屬。
 
  Celery 介紹和詳細用法,可以參考前文:
 
  開發環境下,如何通過一個命令讓 fastapi 和 celery 一起工作
 
  一文搞定 celery 任務遠程調用
 
  from celery import Celery
 
  app = Celery('tasks', broker='pyamqp://guest@localhost//')
 
  @app.task
  def add(x, y):
      return x + y
 
  4、deprecated
  這個相信大家在使用別的包時都遇到過,當要下線一個老版本的函數的時候就可以使用這個裝飾器。
 
  安裝:
 
  pip install Deprecated
  使用:demo4.py
 
  from deprecated import deprecated
  @deprecated ("This function is deprecated, please do not use it")
  def func1():
      pass
 
  func1()
  運行效果如下:
 
  ? python demo4.py
  demo4.py:6: DeprecationWarning: Call to deprecated function (or staticmethod) func1. (This function is deprecated, please do not use it)
    func1()
 
  5、deco.concurrent
  安裝:
 
  pip install deco
  使用 DECO 就像在 Python 程序中查找或創建兩個函數一樣簡單。我們可以用 @concurrent 裝飾需要并行運行的函數,用 @synchronized 裝飾調用并行函數的函數,使用舉例:
 
  from deco import concurrent, synchronized 
  @concurrent # We add this for the concurrent function
  def process_url(url, data):
    #Does some work which takes a while
    return result
 
  @synchronized # And we add this for the function which calls the concurrent function
  def process_data_set(data):
    results = {}
    for url in urls:
      results[url] = process_url(url, data)
    return results
 
  6、cachetools
  緩存工具
 
  安裝:
 
  pip install cachetools
  使用:
 
  from cachetools import cached, LRUCache, TTLCache
 
  # speed up calculating Fibonacci numbers with dynamic programming
  @cached(cache={})
  def fib(n):
      return n if n < 2 else fib(n - 1) + fib(n - 2)
 
  # cache least recently used Python Enhancement Proposals
  @cached(cache=LRUCache(maxsize=32))
  def get_pep(num):
      url = 'http://www.python.org/dev/peps/pep-%04d/' % num
      with urllib.request.urlopen(url) as s:
          return s.read()
 
  # cache weather data for no longer than ten minutes
  @cached(cache=TTLCache(maxsize=1024, ttl=600))
  def get_weather(place):
      return owm.weather_at_place(place).get_weather()
 
  7、retry
  重試裝飾器,支持各種各樣的重試需求。
 
  安裝:
 
  pip install tenacity
  使用:
 
  import random
  from tenacity import retry
 
  @retry
  def do_something_unreliable():
      if random.randint(0, 10) > 1:
          raise IOError("Broken sauce, everything is hosed!!!111one")
      else:
          return "Awesome sauce!"
 
  @retry(stop=stop_after_attempt(7))
  def stop_after_7_attempts():
      print("Stopping after 7 attempts")
      raise Exception
 
 
  @retry(stop=stop_after_delay(10))
  def stop_after_10_s():
      print("Stopping after 10 seconds")
      raise Exception
 
  @retry(stop=(stop_after_delay(10) | stop_after_attempt(5)))
  def stop_after_10_s_or_5_retries():
      print("Stopping after 10 seconds or 5 retries")
      raise Exception
 
主站蜘蛛池模板: 探伤仪,漆膜厚度测试仪,轮胎花纹深度尺厂家-淄博创宇电子 | 营养师网,营养师考试时间,报名入口—网站首页 | 电机修理_二手电机专家-河北豫通机电设备有限公司(原石家庄冀华高压电机维修中心) | 聚氨酯催化剂K15,延迟催化剂SA-1,叔胺延迟催化剂,DBU,二甲基哌嗪,催化剂TMR-2,-聚氨酯催化剂生产厂家 | 回转炉,外热式回转窑,回转窑炉-淄博圣元窑炉工程有限公司 | 高柔性拖链电缆_卷筒电缆_耐磨耐折聚氨酯电缆-玖泰特种电缆 | LCD3D打印机|教育|桌面|光固化|FDM3D打印机|3D打印设备-广州造维科技有限公司 | 爆破器材运输车|烟花爆竹运输车|1-9类危险品厢式运输车|湖北江南专用特种汽车有限公司 | 搪瓷反应釜厂家,淄博搪瓷反应釜-淄博卓耀| 储能预警-储能消防系统-电池舱自动灭火装置-四川千页科技股份有限公司官网 | 偏心半球阀-电动偏心半球阀-调流调压阀-旋球阀-上欧阀门有限公司 | 经济师考试_2025中级经济师报名时间_报名入口_考试时间_华课网校经济师培训网站 | 碎石机设备-欧版反击破-欧版颚式破碎机(站)厂家_山东奥凯诺机械 高低温试验箱-模拟高低温试验箱订制-北京普桑达仪器科技有限公司【官网】 | MES系统工业智能终端_生产管理看板/安灯/ESOP/静电监控_讯鹏科技 | 珠宝展柜-玻璃精品展柜-首饰珠宝展示柜定制-鸿钛展柜厂家 | 云南丰泰挖掘机修理厂-挖掘机维修,翻新,再制造的大型企业-云南丰泰工程机械维修有限公司 | POS机办理_个人POS机免费领取 - 银联POS机申请首页 | 深圳美安可自动化设备有限公司,喷码机,定制喷码机,二维码喷码机,深圳喷码机,纸箱喷码机,东莞喷码机 UV喷码机,日期喷码机,鸡蛋喷码机,管芯喷码机,管内壁喷码机,喷码机厂家 | 菏泽商标注册_菏泽版权登记_商标申请代理_菏泽商标注册去哪里 | 细砂提取机,隔膜板框泥浆污泥压滤机,螺旋洗砂机设备,轮式洗砂机械,机制砂,圆锥颚式反击式破碎机,振动筛,滚筒筛,喂料机- 上海重睿环保设备有限公司 | 电缆接头_防水接头_电缆防水接头_防水电缆接头_上海闵彬 | 焊接烟尘净化器__焊烟除尘设备_打磨工作台_喷漆废气治理设备 -催化燃烧设备 _天津路博蓝天环保科技有限公司 | 海峰资讯 - 专注装饰公司营销型网站建设和网络营销培训 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 礼仪庆典公司,礼仪策划公司,庆典公司,演出公司,演艺公司,年会酒会,生日寿宴,动工仪式,开工仪式,奠基典礼,商务会议,竣工落成,乔迁揭牌,签约启动-东莞市开门红文化传媒有限公司 | 塑料检查井_双扣聚氯乙烯增强管_双壁波纹管-河南中盈塑料制品有限公司 | 工业设计,人工智能,体验式3D展示的智能技术交流服务平台-纳金网 J.S.Bach 圣巴赫_高端背景音乐系统_官网 | 北京中航时代-耐电压击穿试验仪厂家-电压击穿试验机 | 防爆正压柜厂家_防爆配电箱_防爆控制箱_防爆空调_-盛通防爆 | 环比机械| 锂电池生产厂家-电动自行车航模无人机锂电池定制-世豹新能源 | 湿地保护| 华东师范大学在职研究生招生网_在职研究生招生联展网 | 深圳货架厂家_金丽声精品货架_广东金丽声展示设备有限公司官网 | 穿线管|波纹穿线管|包塑金属软管|蛇皮管?闵彬专注弱电工程? | 净气型药品柜-试剂柜-无管道净气型通风柜-苏州毕恩思 | 河南膏药贴牌-膏药代加工-膏药oem厂家-洛阳今世康医药科技有限公司 | 无线讲解器-导游讲解器-自助讲解器-分区讲解系统 品牌生产厂家[鹰米讲解-合肥市徽马信息科技有限公司] | 中医中药治疗血小板减少-石家庄血液病肿瘤门诊部 | PSI渗透压仪,TPS酸度计,美国CHAI PCR仪,渗透压仪厂家_价格,微生物快速检测仪-华泰和合(北京)商贸有限公司 | 千淘酒店差旅平台-中国第一家针对TMC行业的酒店资源供应平台 |