设为首页 收藏本站
查看: 1235|回复: 0

[经验分享] [转]python基础之---import与from...import....

[复制链接]

尚未签到

发表于 2015-4-20 11:35:11 | 显示全部楼层 |阅读模式
  简单说说python import与from...import....(python模块)
  在python用import或者from...import来导入相应的模块。模块其实就一些函数和类的集合文件,它能实现一些相应的功能,当我们需要使用这些功能的时候,直接把相应的模块导入到我们的程序中,我们就可以使用了。这类似于C语言中的include头文件,Python中我们用import导入我们需要的模块。
  eg:



import sys
print('================Python import mode==========================');
print ('The command line arguments are:')
for i in sys.argv:
print (i)
print ('\n The python path',sys.path)
from sys import argv,path#导入特定的成员
print('================python from import===================================')
print('path:',path)
如果你要使用所有sys模块使用的名字,你可以这样:
from sys import *
print('path:',path)
  从以上我们可以简单看出:
  ############################
#导入mode,import与from...import的不同之处在于,简单说:
# 如果你想要直接输入argv变量到你的程序中而每次使用它时又不想打sys,
# 则可使用:from sys import argv
# 一般说来,应该避免使用from..import而使用import语句,
# 因为这样可以使你的程序更加易读,也可以避免名称的冲突
###########################
  在使用 from xxx import * 时,如果想精准的控制模块导入的内容,可以使用 __all__ = [xxx,xxx] 来实现,例如:
  two.py



__all__ = ['a','b'] #__为双横线
class two():
def __init__(self):
print('this is two')
a = 'this is two a'
b = 'this is two b'
if __name__=='__main__':
t = two()

one.py
from two import *
print a
print b
t = two()
这时,类two() 将不会被 import * 导入进来
  关于Import中的路径搜索问题
  类似于头文件,模块也是需要系统的搜索路径的,下面的命令即是系统默认的搜索路径,当你导入一个模块时,系统就会在下面的路径列表中搜索相应的文件。



>>> print(sys.path)
['D:/xx/PythonSERVER/python31/Code', 'D:\\xx\\PythonSERVER\\python31\\Lib\\idlelib', 'C:\\WINDOWS\\system32\\python31.zip', 'D:\\xx\\PythonSERVER\\python31\\DLLs', 'D:\\xx\\PythonSERVER\\python31\\lib', 'D:\\xx\\PythonSERVER\\python31\\lib\\plat-win', 'D:\\xx\\PythonSERVER\\python31', 'D:\\xx\\PythonSERVER\\python31\\lib\\site-packages']
(从例表中,我们可以看到python会首先在当前工作目录里去找)
  如果没有找到相应的内容,则报错:



>>> import syss
Traceback (most recent call last):
File "D:/xxx/xxx/xx/Code/test.py", line 19, in
import syss
ImportError: No module named syss
当然,我们也可以自行添加要搜索路径。调用列表的append方法即可:
import sys
sys.path.append('D:/xx/PythonSERVER/python31/Code')
  创建自己的模块
  在创建之前,有一点需要说明一下:每个Python模块都有它的__name__(就每个对象都自己的__doc__一样)。通过__name__我们可以找出每一个模块的名称,一般__name__的值有种:1 一是主模块名称为:"__main__"(可以理解为直接运行的那个文件),2 那些被主模块导入的模块名称为:文件名字(不加后面的.py)。有__name__是很有用的,因为我们可以通过 if __name__  == 'xxx' 判断来执行那些模块,那些模块不被执行。另外:每个Python程序也是一个模块。它扩展名为:.py扩展名。
  下面,我们通过例子来说明:
首先:我们创建模块:mymodel.py



#!/user/bin/python
#Filename:mymodel.py
version = '1.0'
def sayHello():
print ('Hello world')
def modelName():
return __name__#返回它自己的名称
#end of model
  以上语句注意:
                    1 这个模块应该被放置在我们输入它的程序的同一个目录中,或者在sys.path所列目录之一。
                    2 你已经看到,它与我们普通的Python程序相比并没有什么特别之处
  
  然后:我们在test.py中来调用此模块:test.py



import sys,mymodel
sys.path.append('D:/xx/PythonSERVER/python31/Code')#提供搜索路径
print(__name__) #此处打印主模块的名称:__main__
mymodel.sayHello()
print('Version',mymodel.version)
print('Model Name',mymodel.modelName())#打印被导入模块的名称: mymodel

我们使用from..import...
print('======================from.....import=====================================')
from mymodel import *
print(__name__)#此处打印主模块的名称:__main__
sayHello()
print('Version',version)
print('Model Name',modelName()) #打印被导入模块的名称: mymodel
  以上语句注意:
                    1 我们可以通过import来导入多个模块,用“,”(逗号)分隔。
                    2 注意import与from..import.....
  
  创建自己的包
1 一个包的基本组织如下:



FC/
__init__.py
Libr/
__init__.py
one.py
two.py
....
Model/
__init__.py
one.py
....

在外部加载调用时,有以下方式:
#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文件中定义好需要加载子模块的名称
Fc/Libr/__init__.py
__all__=['one','two'] #定义加载子模块的名称
  在加载包模块时,在import语句执行期时,遇到的所有__init__.py文件都会被执行,在上面代码中
首先会执行Fc目录中的__int__.py,然后执行Libr目录中的__init__.py
2 子模块加子模块问题
同一包的相同目录中:



#coding:utf-8
#加载方式一:使用完全限定名称
from Fc.Libr import one
aa = 'libr two load one---'+one.a
#加载方式二:使用相对导入
from . import one
bb = 'libr two load one----'+one.b
方二中使用.来表示在同一级目录中。

#加载方式三:(这种方式应当避免:最后找不到会转移到标准库)
import Fc.Libr.one
cc = 'libr two load one---'+Fc.Libr.one.a
在外部使用时:
#coding:utf-8
from Fc.Libr import *
print two.aa
print two.bb

同一包的不同目录中:
#coding:utf-8
from ..Model import one
a = 'libr two load mode one---'+one.a
使用时:
#coding:utf-8
from Fc.Libr import *
print two.a
将输出:libr two load mode one---fc model one
  另外在导入一个包时,会定义一个特殊的变量__path__,该变量包含一个目录列表。
__path__可通过__init__.py文件中包含的代码访问,最初包含的一项具有包的目录名称。我们可以
向__path__列表提供更多的目录,以更改查找子模块时使用的搜索路径,大型项目中这个很有用。
  
  特别说明
    1  import执行加载源文件中所有语名(所以模块是一个文件)。
    2  import语句可以出现在程序中的任何位置。但是有一点是:无论import语句被使用了多少次,每个模块中的代码仅加载和执行一次,后续的import语句仅将模块名称绑定到前一次导入所创建的模块对象上。
    3  使用sys.modules可查看当前加载的所有模块。
  
  
  另外对比PHP include()相对工作目录 来引入文件

  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-58811-1-1.html 上篇帖子: python网络编程学习笔记(6):Web客户端访问 下篇帖子: Python:itertools模块
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表