简单说说python import与from…import…
在python用import或者from…import来导入相应的模块。模块其实就一些函数和类的集合文件,它能实现一些相应的功能,当我们需要使用这些功能的时候,直接把相应的模块导入到我们的程序中,我们就可以使用了。这类似于C语言中的include头文件,Python中我们用import导入我们需要的模块。
1 | import sys |
从以上我们可以简单看出:
导入mode,import与from…import的不同之处在于,简单说:
如果你想要直接输入argv变量到你的程序中而每次使用它时又不想打sys,
则可使用:from sys import argv
一般说来,应该避免使用from…import而使用import语句,
因为这样可以使你的程序更加易读,也可以避免名称的冲突
在使用 from xxx import * 时,如果想精准的控制模块导入的内容,可以使用 all = [xxx,xxx] 来实现,例如:
1 | two.py |
1 | one.py |
这时,类two() 将不会被import * 导入进来
关于Import中的路径搜索问题
类似于头文件,模块也是需要系统的搜索路径的,下面的命令即是系统默认的搜索路径,当你导入一个模块时,系统就会在下面的路径列表中搜索相应的文件。
1 | print(sys.path) |
(从例表中,我们可以看到python会首先在当前工作目录里去找)
如果没有找到相应的内容,则报错:
1 | import syss |
当然,我们也可以自行添加要搜索路径。调用列表的append方法即可:
1 | import sys |
创建自己的模块
在创建之前,有一点需要说明一下:每个Python模块都有它的__name__(就每个对象都自己的__doc__一样)。通过__name__我们可以找出每一个模块的名称,一般__name__的值有两种:1 一是主模块名称为:“main”(可以理解为直接运行的那个文件),2 那些被主模块导入的模块名称为:文件名字(不加后面的.py)。有__name__是很有用的,因为我们可以通过 if name == ‘xxx’ 判断来执行那些模块,那些模块不被执行。另外:每个Python程序也是一个模块。它扩展名为:.py扩展名。
下面,我们通过例子来说明:
首先:我们创建模块:mymodel.py
1 | #!/user/bin/python |
以上语句注意:
1.这个模块应该被放置在我们输入它的程序的同一个目录中,或者在sys.path所列目录之一。
2.你已经看到,它与我们普通的Python程序相比并没有什么特别之处
然后:我们在test.py中来调用此模块:test.py
1 | import sys,mymodel |
我们使用from…import…
1 | print('======================from.....import=====================================') |
以上语句注意:
1.我们可以通过import来导入多个模块,用“,”(逗号)分隔。
2.注意import与from…import…
创建自己的包
1.一个包的基本组织如下:
1 | FC/ |
在外部加载调用时,有以下方式:
coding:utf-8
加载方式一
import Fc.Libr.one
print Fc.Libr.one.a
加载方式二
from Fc.Libr import one
print one.a
加载方式三
from Fc.Libr.one import a
print a
加载方式四
from Fc.Libr import *
print one.a
注意直接使用第四种方式是不能正确导入Libr下的one子模块的,这就需要在Fc目录下的__init__.py文件中定义好需要加载子模块的名称
1 | Fc/Libr/__init__.py |
在加载包模块时,在import语句执行期时,遇到的所有__init__.py文件都会被执行,在上面代码中
首先会执行Fc目录中的__int__.py,然后执行Libr目录中的__init__.py
2.子模块加子模块问题
同一包的相同目录中:
1 | #coding:utf-8 |
同一包的不同目录中:
1 | #coding:utf-8 |
特别说明
1.import执行加载源文件中所有语名(所以模块是一个文件)。
2.import语句可以出现在程序中的任何位置。但是有一点是:无论import语句被使用了多少次,每个模块中的代码仅加载和执行一次,后续的import语句仅将模块名称绑定到前一次导入所创建的模块对象上。
3.值有种使用sys.modules可查看当前加载的所有模块。