fl军哥

导航

 

       今天学习的是关于高级模块的内容,关于这个高级模块我不是太了解,下面是我学习之后的一些总结:其中有相关解释和常常容易踏入的陷阱。_X的命名方式可以防止from *导入这个变量,然而这种方法不能阻止其他导入方式的导入,并不是一些面向对象语言中的私有声明。__all__会列出from *复制的变量名,与_X正相反。同样只对from *有效,不是私有声明。from __feature__ import featurename还不是很理解,好象是用选用扩展功能的方式开启特殊的代码编译。模块可以通过检测自己的__name__是否为"__main__"确定它是在执行还是被导入。这样可以让模块在扮演两种不同角色时发挥不同功能。相对导入:路径以一个点开始,定位同一个包的模块。可以开启__feature__中强迫导入的绝对性。很类似于Linux,两个点表示上一级路径。

陷阱一:顶层代码的语句次序。被import时模块的顶层代码会立即执行,此时它所引用后文定义的变量将无效。

陷阱二:字符串变量是不能直接用于import语句的。可以使用exec "import" + modname来使用字符串modname。这样做仍然有个缺点,每次执行时必须编译import语句。更好的代替方案是string = __import__(modname),然后把string单列一行执行即可。

陷阱三:from复制变量名而不是拷贝。

#nested1.py
X = 99
def printer():print X

#nested2.py
from nested1 import X,printer
X = 88
printer()

%python nested2.py
99

陷阱四:reload不影响from导入。为了更新变量,使用.运算符来导入和修改其他模块的变量。

陷阱五:reload、from及交互模式测试。这部分比较有启发性,建议在原书仔细阅读,简要概括就还是:导入后(模块)要重载(模块),重载后还要重新执行import(变量)。reload和from的合作并不完美,最佳原则是使用reload和import来启动程序。

posted on 2020-02-09 22:05  信1705-2张小军  阅读(123)  评论(0编辑  收藏  举报