作者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
1F:推 juiz:我的 code 里全都是 in function import 这种 anti pep8 :) 10/24 19:44
2F:→ buganini:我觉得in function import以locality的角度来看是比较好 10/24 21:47
3F:→ buganini:也比较不会删code的时候忘了删之类的…但其实这个问题, 10/24 21:49
4F:→ buganini:或是要列举depencendy的需求,应该都可以用IDE或其他工具 10/24 21:50
5F:→ buganini:才是 10/24 21:50
6F:→ buganini:不过如果是要自动移除没用到的import这不好作,要 10/24 21:51
7F:→ buganini:grep import倒是很容易,所以我其实比较支持in function 10/24 21:51
8F:→ buganini:import 10/24 21:51
9F:推 keitheis:同意…不过懒得改,不一致性还是架构上的大敌 10/25 01:08