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

您現在所在的位置:首頁 >常見問題 > 課程問題 > 奇酷總結:Python學習用得到的黑魔法!

奇酷總結:Python學習用得到的黑魔法!

來源:奇酷教育 發表于:

Python用得到的黑魔法當然是各種自省和動態綁定了。

  Python用得到的黑魔法當然是各種自省和動態綁定了。

  舉個例子,Python可以重新綁定解釋器的excepthook,這樣當程序異常結束時就可以做一些自定義的處理,我自己就一直拿這個配合ipdb進行debug。用以下代碼聲明一個ExceptionHook:

  class ExceptionHook :

  instance = None

  def __call__(self, *args, **kwargs) :

  if self.instance is None:

  from IPython.core import ultratb

  self.instance = ultratb.FormattedTB(mode = "Plain", color_scheme = "Linux", call_pdb = 1)

  return self.instance(*args, **kwargs)

  然后

  import sys

  sys.exceptionhook = ExceptionHook()

  重設完exceptionhook后,一旦你的代碼拋出異常,整個解釋器的環境都會被ipdb接管,然后就可以像交互模式下那樣使用了。通常我會在里面查一下棧,把必要的對象pickle一下,這樣以后復現錯誤也比較容易。

  由于IPython是非GUI的程序,所以即便在SSH里也可以使用這招,完美解決SSH缺少IDE難以debug的窘境。

  動態綁定的另一個用處,就是當程序依賴一個修改過的庫時,可以把修改的部分剝離出來,在運行時動態綁定到對應的庫上去就行。如果修改的是成員方法,需要這樣綁定:

  from types import MethodType

  def _foo(self, ...):

  pass

  obj.foo = MethodType(_foo, obj)

  順帶提一下,pickle也是個非常好用的工具,盡管序列化并不是python的專利。pickle可以用來保存各種運行過程中的對象:

  import pickle

  pickle.dump(xxx, open("xxx.dump", "w"))

  yyy = pickle.load(open("yyy.dump"))

  pickle可以減少很多工作量,尤其是在復現bug時,把正確部分的運行結果pickle下來,這樣每次可以從pickle的位置開始運行。跑多個相似的baseline時也有很好的效果。不足的是pickle比較吃硬盤,pickle一堆東西后很容易就十幾個G了,而且pickle不能序列化動態生成的對象,比如lambda表達式或者上面提到的動態綁定產生的成員方法。

  自省方面,Python可以通過dir()和help()函數分別取得對象下成員的列表和幫助,這個在找不到庫文檔的時候非常好用。只要開發者在函數下面寫了注釋,就能在help中看到。

  除了上面提到的這些特性,python還有一堆小trick,其他回答里也提到了一些。雖然其中很多是語法糖,不過用好它們可以讓程序更pythonic:

  1 類中用__slots__將成員靜態化,可以節省大量內存。

  2 裝飾器,常見用途如函數計時,亦可用來產生新的函數簽名。函數簽名會影響傳參檢查和ide補全,對帶不定長參數的函數非常有用。很多庫中都會用這種方法來兼容不同版本的API。

  3 生成器,對于只需遍歷的數據可以節省大量內存。

  4 *和**參數展開。典型的例子是zip(*list_x)和chain(*list_x),分別相當于轉置和concatenate。

  5 if __name__ == "__main__": 檢查是否作為主程序調用,用multiprocessing并行時主程序得用這個框起來。

  6 enumerate,例如將一個list變成list2index可以用dict([(x, i) for i, x in enumerate(list_x)])

  7 namedtuple,生成類似于C語言的結構體,同時支持tuple的所有語法。

  8 defaultdict,做統計時不用初始化的dict,可以用lambda實現嵌套構造defaultdict(lambda : defaultdict(int)),甚至遞歸字典tree = lambda : defaultdict(tree)。

主站蜘蛛池模板: 天津暖气片厂家_钢制散热器_天津铜铝复合暖气片_维尼罗散热器 | 德国BOSCH电磁阀-德国HERION电磁阀-JOUCOMATIC电磁阀|乾拓百科 | 合肥弱电工程_安徽安防工程_智能化工程公司-合肥雷润 | 中式装修设计_全屋定制家具_实木仿古门窗花格厂家-喜迎门 | 东莞市超赞电子科技有限公司 全系列直插/贴片铝电解电容,电解电容,电容器 | 仓储货架_南京货架_钢制托盘_仓储笼_隔离网_环球零件盒_诺力液压车_货架-南京一品仓储设备制造公司 | 山东太阳能路灯厂家-庭院灯生产厂家-济南晟启灯饰有限公司 | 一路商机网-品牌招商加盟优选平台-加盟店排行榜平台 | 恒压供水控制柜|无负压|一体化泵站控制柜|PLC远程调试|MCGS触摸屏|自动控制方案-联致自控设备 | 低温等离子清洗机(双气路进口)-嘉润万丰 | 淄博不锈钢,淄博不锈钢管,淄博不锈钢板-山东振远合金科技有限公司 | 世纪豪门官网 世纪豪门集成吊顶加盟电话 世纪豪门售后电话 | 三效蒸发器_多效蒸发器价格_四效三效蒸发器厂家-青岛康景辉 | 强效碱性清洗剂-实验室中性清洗剂-食品级高纯氮气发生器-上海润榕科学器材有限公司 | 东莞螺杆空压机_永磁变频空压机_节能空压机_空压机工厂批发_深圳螺杆空压机_广州螺杆空压机_东莞空压机_空压机批发_东莞空压机工厂批发_东莞市文颖设备科技有限公司 | 安全阀_弹簧式安全阀_美标安全阀_工业冷冻安全阀厂家-中国·阿司米阀门有限公司 | 七维官网-水性工业漆_轨道交通涂料_钢结构漆 | 防水套管|柔性防水套管|伸缩器|伸缩接头|传力接头-河南伟创管道 防水套管_柔性防水套管_刚性防水套管-巩义市润达管道设备制造有限公司 | PU树脂_水性聚氨酯树脂_聚氨酯固化剂_聚氨酯树脂厂家_宝景化工 | 杭州高温泵_热水泵_高温油泵|昆山奥兰克泵业制造有限公司 | 蓝米云-专注于高性价比香港/美国VPS云服务器及海外公益型免费虚拟主机 | 上海噪音治理公司-专业隔音降噪公司-中广通环保 | 展厅装修公司|企业展厅设计|展厅制作|展厅搭建—广州展厅装饰公司 | 环保袋,无纺布袋,无纺布打孔袋,保温袋,环保袋定制,环保袋厂家,环雅包装-十七年环保袋定制厂家 | 四川成人高考_四川成考报名网| 湖南专升本-湖南省专升本报名-湖南统招专升本考试网 | 冰雕-冰雪世界-大型冰雕展制作公司-赛北冰雕官网 | 超声波焊接机,振动摩擦焊接机,激光塑料焊接机,超声波焊接模具工装-德召尼克(常州)焊接科技有限公司 | 泰来华顿液氮罐,美国MVE液氮罐,自增压液氮罐,定制液氮生物容器,进口杜瓦瓶-上海京灿精密机械有限公司 | 慢回弹测试仪-落球回弹测试仪-北京冠测精电仪器设备有限公司 | 阀门智能定位器_电液动执行器_气动执行机构-赫尔法流体技术(北京)有限公司 | 滤芯,过滤器,滤油机,贺德克滤芯,精密滤芯_新乡市宇清流体净化技术有限公司 | 烟气在线监测系统_烟气在线监测仪_扬尘检测仪_空气质量监测站「山东风途物联网」 | 运动木地板_体育木地板_篮球馆木地板_舞台木地板-实木运动地板厂家 | 气弹簧定制-气动杆-可控气弹簧-不锈钢阻尼器-工业气弹簧-可调节气弹簧厂家-常州巨腾气弹簧供应商 | 海峰资讯 - 专注装饰公司营销型网站建设和网络营销培训 | 温州食堂承包 - 温州市尚膳餐饮管理有限公司 | 上海噪音治理公司-专业隔音降噪公司-中广通环保 | 北京西风东韵品牌与包装设计公司,创造视觉销售力! | 合肥触摸一体机_触摸查询机厂家_合肥拼接屏-安徽迅博智能科技 | 热缩管切管机-超声波切带机-织带切带机-无纺布切布机-深圳市宸兴业科技有限公司 |