Re: [討論] 記錄 code snippet 的好用工具
※ 引述《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
04/28 19:42, 1F
推
04/28 22:17,
7年前
, 2F
04/28 22:17, 2F
推
04/29 01:24,
7年前
, 3F
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
討論串 (同標題文章)
本文引述了以下文章的的內容:
完整討論串 (本文為第 2 之 3 篇):