模块导入之import vs from-import

      与其他可以导入类的语言不同,Python中导入的是模块或模块属性。当运行到导入模块语句时,各外部模块将依次执行。

         模块的导入语句基本形式有两种:import格式和from-import格式。

         使用import语法导入的格式为

import module1_name

#or

import module1_name,module2_name,...

       这两种没有太大的不同,只有可读性的差别。

              导入后,可以使用全限定名称访问模块中定义的成员,格式为

                                       module_name.函数名/变量名         #使用模块内特定的成员

另外一种导入方式为

from module_name import number1_name,number2_name,number3_name,……

          这种方法导入的是一个模块的几个成员,导入内容过长变成多行导入时,用一个\可以换行。用from-import语句可以把名字导入到当前命名空间去,成为当前模块的一个属性,因此不需要在使用时加句点属性标识符,可以直接调用。

         如果要把模块中所有的名称都导入到当前名称空间可以用:

frommodule_name import *

>>> import math

>>> math.pi                                  #.属性调用

3.141592653589793

 

>>> from math import cos,ceil

>>> cos(60)                                  #直接调用

-0.9524129804151563

>>>ceil(5.64)

6.0

           下面看一下两种导入方式的区别,以下列文件导入关系为例

a模块调用b模块,b模块调用c模块,

#a.py

[root@localhost test]# cat a.py

import b

--------------------------------------------------------------------------------------------------------------------------------------------------

#b.py

[root@localhost test]# cat b.py

import c

------------------------------------------------------------------------------------------------------------------------------------------------------

#c.py

[root@localhost test]# cat c.py

def fun():

       print "i'm c"


import形式

>>> import a

        使用dir()看一下导入外部模块后,本模块中现有的成员

>>> dir(a)

['__builtins__', '__doc__', '__file__','__name__', '__package__', 'b']

>>> 

>>>dir(a.b)

['__builtins__','__doc__', '__file__', '__name__', '__package__', 'c']

>>> 

       如果我们想调用c模块中的fun函数,是不可以的

>>> fun()

Traceback (most recent call last):

  File"", line 1, in

NameError: name 'fun' is not defined

       很明显,a模块下没有这个函数成员。fun函数只存在于c模块的命名空间中,

       我们需要逐级指明

>>>a.b.c.fun()

i'm c

>>> 

       另外一种方式是使用from-import导入方式,直接将模块成员放入其他模块命名空间中。

from-import方式

       这是另外一种导入到当前命名空间中的方式

修改b.py为

[root@localhosttest]# vi b.py

#import c

from c import *

       查看此时a模块中的成员

>>> dir(a)

['__builtins__','__doc__', '__file__', '__name__', '__package__', 'b']

>>>dir(a.b)

['__builtins__','__doc__', '__file__', '__name__', '__package__', 'fun']

>>>a.b.fun()

i'm c

>>> 

       可见,使用from c import fun,直接将fun函数导入b的命名空间中了。我们可以继续将fun函数直接导入到a的命名空间中,这需要改写a.py为

[root@localhosttest]# vi a.py

#import b

from b import *

       此时再查看a模块的成员,如

>>> dir(a)

['__builtins__','__doc__', '__file__', '__name__', '__package__','fun']

>>> 

        当然,从实践中来看,第二种方式不是很好的编程风格,当导入多个模块时,多个模块可能存在同一个名称的函数,导致名称冲突。这是因为

Namespaces can also be further nested, since it loads the variable names into the

global namespace and could potentially overwrite already existing variable

names。forexample if we import modules, or if we are defining new classes. In those caseswe have to use prefixes to access those nested namespaces.

一般推荐所有的模块在开头导入,最好按这样的顺序:Python标准库模块,Python第三方模块,应用程序自定义模块,然后用一个空行分割这三个模块的导入语句。

         模块导入过程也遵循作用域规则,即在一个文件的顶层导入,那么它的作用域就是全局的,如果在函数中导入,就是局部的。

你可能感兴趣的:(模块导入之import vs from-import)