from … import 语句
Python 的 from 语句让你从模块中导入一个指定的部分到当前命名空间中,语法如下:
from modname import name1, name2, … nameN
例如,要导入模块 fibo 的 fib 函数,使用如下语句:
from fibo import fib,fib2
fib(500)
运行结果:
这个声明不会把整个fibo模块导入到当前的命名空间中,它只会将fibo里的fib函数引入进来。
from … import * 语句
把一个模块的所有内容全都导入到当前的命名空间也是可行的,只需使用如下声明:
from modulename import *
这提供了一个简单的方法来导入一个模块中的所有项目。然而这种声明不该被过多地使用。
深入模块
模块除了方法定义,还可以包括可执行的代码。这些代码一般用来初始化这个模块。这些代码只有在第一次被导入时才会被执行。
每个模块有各自独立的符号表,在模块内部为所有的函数当作全局符号表来使用。
所以,模块的作者可以放心大胆的在模块内部使用这些全局变量,而不用担心把其他用户的全局变量搞混。
从另一个方面,当你确实知道你在做什么的话,你也可以通过 modname.itemname 这样的表示法来访问模块内的函数。
模块是可以导入其他模块的。在一个模块(或者脚本,或者其他地方)的最前面使用 import 来导入一个模块,当然这只是一个惯例,而不是强制的。被导入的模块的名称将被放入当前操作的模块的符号表中。
还有一种导入的方法,可以使用 import 直接把模块内(函数,变量的)名称导入到当前操作模块。比如:
from fibo import fib,fib2
fib(500)
运行结果:
这种导入的方法不会把被导入的模块的名称放在当前的字符表中(所以在这个例子里面,fibo 这个名称是没有定义的)。
这还有一种方法,可以一次性的把模块中的所有(函数,变量)名称都导入到当前模块的字符表:
from fibo import *
fib(500)
运行结果:
这将把所有的名字都导入进来,但是那些由单一下划线(_)开头的名字不在此例。大多数情况, Python程序员不使用这种方法,因为引入的其它来源的命名,很可能覆盖了已有的定义。
__name__属性
一个模块被另一个程序第一次引入时,其主程序将运行。如果我们想在模块被引入时,模块中的某一程序块不执行,我们可以用__name__属性来使该程序块仅在该模块自身运行时执行。
# 文件名:useingname
# 测试__name__属性
if __name__ == '__main__':
print('在模块内部,自身运行。')
else:
print('可在被导入我(useingname模块)的文件离运行')
运行输出如下:
导入useingname模块
import useingname
运行输出如下:
说明: 每个模块都有一个__name__属性,当其值是’main’时,表明该模块自身在运行,否则是被引入。
说明:name 与 main 底下是双下划线, _ _ 是这样去掉中间的那个空格。
dir() 函数
内置的函数 dir() 可以找到模块内定义的所有名称。以一个字符串列表的形式返回:
import fibo,sys
print(dir(fibo))
print("----------------------------------------------------------------------------")
print(dir(sys))
以上脚本运行结果为:
如果没有给定参数,那么 dir() 函数会罗列出当前定义的所有名称:
import fibo
fibo.fib(1000)
print("-----------------------")
fibolist = []
fibolist = fibo.fib2(1000)
print(fibolist)
print("-----------------------")
print(fibo.__name__)
print("-----------------------")
fib = fibo.fib
fib(1000)
print("-----------------------")
print(dir())
以上脚本运行结果: