作者peterwolf (pw)
看板Python
標題Re: [問題] from xxx import ooo
時間Wed Oct 24 19:29:55 2012
※ 引述《keitheis (無)》之銘言:
: ※ 引述《sheauhei ( )》之銘言:
: : ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
: : 這說法個人有點其他想法,算借題發揮吧 :p
: : 如果指的是上述例子為了繞過import exception的問題,
: : 而延遲了import的時間點,
: : 這本身做法就是有問題的...可以說是來亂的阿 orz
: : 不過,在一般性來講,個人建議是:
: : "盡可能延遲module import的時間點,至到需要用到它。"
: : 一個平常的例子就是,
: : 如果只有在某個function中需要用到某個module,
: : 那最好在function的local namesapce去import,
: : 而不要在global namespace import。
: : 簡單的例子
: : main.py:
: : import a
: : ...
: : def executeA():
: : a.func()
: : a.py:
: : import b
: : def func():
: : b.xxx() ...
: : b.py:
: : ....
: : 在這個例子中,executeA()這個function,
: : 可能從頭到尾都不會被執行到,
: : 但是卻因為它,從main.py開始執行時,
: : 就一路從a.py 一直到 b.py,
: : 甚至更多的module都被import進來。
: : (如果你目前在做的專案有上千個module,
: : 你就會知道這恐怖了 囧...)
: 嗯嗯,受教了!
: 就效能為上而言我想這是可以認真考慮的
: 但就專案維護容易度而言,要找出一個程式用了(相依)哪些模組
: 我個人偏好,如 PEP 8 所推薦的,直接看檔案開頭容易
: 然後遇到哪裡有效能問題,再來小心地處理
: 除非一開始就是在寫效能導向程式(如 yyc XD)
: 否則太早最佳化是萬惡之源?XD
: : 建議是:
: : main.py:
: : def executeA():
: : import a
: : a.func()
: : a.py:
: : def func():
: : import b
: : b.xxx() ...
: : b.py:
: : ...
: : 除非executeA()被執行到,
: : 不然a.py 和 b.py 乃至於其後會用到的module
: : 都不會被load到。
: : ---
: : 這原則的另個好處(?),
: : 就是可以剛好繞過原原po的那種
: : a import b, b import a問題.... orz
藉這個標題請幾位高手 review 一下我的做法。
我的 python 是自學的,所以可能做法很奇怪…
如果一段程式碼還不到 class 的層次的話,我會在 function 裡
加註,也會在檔案的開頭部份寫明引入的 module。像這樣:
import someModule
import anotherModule
funcA():
#import someModule
blah blah blah...
funcB()
#import anotherModule
blah blah blah...
這樣的目的有二:
1). 我隨時可以把 funcA() 整段程式複製以後貼到別的地方用,
只要把其內的第一行解註就行了。
2). 在 trace code 的時候,很方便就知道這個 funcA() 用到的
的 module 名稱是什麼。
這樣很「不簡潔」,但在維護可讀性的前提下(因為我記性很差,
兩天沒碰,就忘了自己寫什麼了),不知道有沒有更好的做法呢?
謝謝
pw.
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 36.224.123.80
推 juiz:我的 code 裡全都是 in function import 這種 anti pep8 :) 10/24 19:44
→ buganini:我覺得in function import以locality的角度來看是比較好 10/24 21:47
→ buganini:也比較不會刪code的時候忘了刪之類的…但其實這個問題, 10/24 21:49
→ buganini:或是要列舉depencendy的需求,應該都可以用IDE或其他工具 10/24 21:50
→ buganini:才是 10/24 21:50
→ buganini:不過如果是要自動移除沒用到的import這不好作,要 10/24 21:51
→ buganini:grep import倒是很容易,所以我其實比較支持in function 10/24 21:51
→ buganini:import 10/24 21:51
推 keitheis:同意…不過懶得改,不一致性還是架構上的大敵 10/25 01:08