Re: [問題] from xxx import ooo

看板Python作者 (pw)時間12年前 (2012/10/24 11:29), 編輯推噓2(207)
留言9則, 3人參與, 最新討論串6/6 (看更多)
※ 引述《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

10/24 19:44, , 1F
我的 code 裡全都是 in function import 這種 anti pep8 :)
10/24 19:44, 1F

10/24 21:47, , 2F
我覺得in function import以locality的角度來看是比較好
10/24 21:47, 2F

10/24 21:49, , 3F
也比較不會刪code的時候忘了刪之類的…但其實這個問題,
10/24 21:49, 3F

10/24 21:50, , 4F
或是要列舉depencendy的需求,應該都可以用IDE或其他工具
10/24 21:50, 4F

10/24 21:50, , 5F
才是
10/24 21:50, 5F

10/24 21:51, , 6F
不過如果是要自動移除沒用到的import這不好作,要
10/24 21:51, 6F

10/24 21:51, , 7F
grep import倒是很容易,所以我其實比較支持in function
10/24 21:51, 7F

10/24 21:51, , 8F
import
10/24 21:51, 8F

10/25 01:08, , 9F
同意…不過懶得改,不一致性還是架構上的大敵
10/25 01:08, 9F
文章代碼(AID): #1GXz4slo (Python)
討論串 (同標題文章)
文章代碼(AID): #1GXz4slo (Python)