第1部分
该模块仅加载一次,因此再次导入不会造成性能损失。如果您确实希望再次加载/解析它,则必须使用
reload()该模块。
首先检查的是
sys.modules,以前已导入的所有模块的缓存。[来源]
第2部分
from foo import *导入
a本地范围。将值分配给时
a,它将替换为新值-但
foo.a不会触及原始变量。
因此,除非您
import foo进行修改
foo.a,否则两个调用将返回相同的值。
对于可变类型(例如列表或字典),它会有所不同,对其进行修改确实会影响原始变量-但为其分配新值仍不会修改
foo.whatever。
如果您需要更多详细信息,请访问http://docs.python.org/reference/executionmodel.html:
以下构造绑定名称:函数的形式参数, import语句 ,类和函数定义(这些绑定在定义块中的类或函数名称),以及
目标(如果在赋值中出现的话,则是标识符 )的 目标 ,用于第二个循环头except子句标题的位置或在with语句之后。
与您相关的两个粗体部分:首先,名称与导入期间的
a值绑定
foo.a。然后,在执行 *** 作时
a =5,名称
a将绑定到
5。由于修改列表/字典不会引起任何绑定,因此这些 *** 作将修改原始 *** 作(
b并
foo.b绑定到要 *** 作的同一对象)。分配一个新的对象
b将再次装订 *** 作,从而分开
b从
foo.b。
还值得注意该
import语句的确切作用:
import foo
将模块名称绑定到当前作用域中的模块对象,因此,如果您进行修改foo.whatever
,则将使用该模块中的名称-任何修改/赋值都会影响模块中的变量。from foo import bar
仅将给定名称foo
绑定到(即将保持未绑定状态)到具有相同名称的元素中foo
-因此对的 *** 作bar
行为如前所述。from foo import *
行为与上一个类似,但是它导入所有不带下划线前缀的全局名称。如果模块__all__
仅定义此序列内的名称,则将导入。
第3部分 (甚至在您的问题中都不存在:p)
python文档非常好,而且通常很冗长-您可以在其中找到几乎所有与语言相关的问题的答案。以下是一些有用的链接:
- http://docs.python.org/reference/datamodel.html(类,属性,魔术方法等)()
- http://docs.python.org/reference/executionmodel.html(变量如何在python中工作)
- http://docs.python.org/reference/expressions.html
- http://docs.python.org/reference/simple_stmts.html(如的语句
import
,yield
) - http://docs.python.org/reference/compound_stmts.html(块语句,例如
for
,try
,with
)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)