Re: [討論] 記錄 code snippet 的好用工具

看板Soft_Job作者 (有些事,有時候。。。)時間7年前 (2018/04/28 19:00), 7年前編輯推噓3(301)
留言4則, 4人參與, 7年前最新討論串2/3 (看更多)
※ 引述《alan23273850 (God of Computer Science)》之銘言: : 各位板友午安,本魯軟體板首次發文請小力鞭 : 是說最近常和同學討論到整理 code snippet 的重要,也就是功能導向的筆記 : 舉例來說,要測量程式執行的時間, : 以 C 語言來說,可以是: : clock_t start = clock(); : ... // code execution : clock_t end = clock(); : printf("%f\n", (float)(end - start) / CLOCKS_PER_SEC); : 但如果是以 python 而言,則是: : import datetime : before = datetime.datetime.now() : ... // code execution : after = datetime.datetime.now() : print after - before : 那麼各位工程師不覺得針對不同的功能,把所有語言的 code 整理在一起, : 未來撰寫程式在翻閱或查閱的時候就更方便,不需要再敲 Google 關鍵字了呢? : 台大資訊系劉邦鋒教授也有寫過 "由片語學習 C 程式設計" 一書, : 雖然我沒讀過,不過我猜應該就類似書中那種以功能為導向整理過的感覺。 : 有沒有什麼好用的工具或方法能有條不紊地整理這些 code 呢? 亂入一下,python 其實用 decorator 比較方便,也有人有提供 library def stopwatch(func): def with_logging(*args, **kwargs): start_time = time.time() try: return func(*args, **kwargs) finally: end_time = time.time() logger.info("{:36s} :: {:.3f}".format( \ func.__name__, end_time - start_time)) pass return with_logging @stopwatch def my_function(): # do something pass ========================================================== 至於 cheat sheet 的部分,最好是能被『執行』的程式碼。 因為單純眼睛看可能不太明白,可是跑一次就懂了。 不過,當你在『工作』的場域時,這些常用的工作大致都應該包好了。 也就是當你想要自幹某些東西時,先問一下同事有沒有相似的功能已被實作。 或是你可能打開舊專案,複製一段 code 出來用而已。 這類比較小行數的 cheat sheet 大概只會剩下一些難記的參數。 像是那個我永遠記不住的 ffmpeg 參數,或是建立專案時 gradle 編譯設定。 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 59.115.99.169 ※ 文章網址: https://www.ptt.cc/bbs/Soft_Job/M.1524913222.A.3A7.html ※ 編輯: qrtt1 (59.115.99.169), 04/28/2018 19:05:11

04/28 19:42, 7年前 , 1F
其實我對 python 真的不是很熟,感謝建議
04/28 19:42, 1F

04/28 22:17, 7年前 , 2F
推 decorator
04/28 22:17, 2F

04/29 01:24, 7年前 , 3F
既然要用decorator 那乾脆再補個functools.wraps比較好
04/29 01:24, 3F

04/29 09:35, 7年前 , 4F
同推樓上
04/29 09:35, 4F
應 review comment 來補補 :) from functools import wraps def stopwatch(func): @wraps(func) def with_logging(*args, **kwargs): start_time = time.time() try: return func(*args, **kwargs) finally: end_time = time.time() logger.info("{:36s} :: {:.3f}".format( func.__name__, end_time - start_time)) pass return with_logging ※ 編輯: qrtt1 (59.115.99.169), 04/29/2018 09:56:10
文章代碼(AID): #1Qv5H6Ed (Soft_Job)
文章代碼(AID): #1Qv5H6Ed (Soft_Job)