简单说说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可查看当前加载的所有模块。

在python中用import或者from_[转]python基础之---import与from...import....相关推荐

  1. 在python中用递归的方法编程_python基础之函数,递归,内置函数

    阅读目录 一 数学定义的函数与python中的函数 初中数学函数定义:一般的,在一个变化过程中,如果有两个变量x和y,并且对于x的每一个确定的值,y都有唯一确定的值与其对应,那么我们就把x称为自变量, ...

  2. Python中用PIL/Pillow裁剪图片

    # pip install Pillow # 在img标签里面只设置宽,不设置高,图片就会等比例缩放. # coding=utf-8 from PIL import Image import Imag ...

  3. python中用lxml解析html

    lxml,是python中用来处理xml和html的功能最丰富和易用的库.详情见:http://lxml.de/index.html. 在windows下安装lxml,可以用easy_install工 ...

  4. Python中用numpy进行图片处理

    其实在Python中,我们也可以用numpy进行图片处理,今天一起来学习下吧. 1.图像的数组表示: from PIL import Image from pylab import * from nu ...

  5. Python中用pandas将numpy中的数组数据保存到csv文件

    Python中用pandas将numpy中的数组数据保存到csv文件 本博客转载自:[1]https://blog.csdn.net/grey_csdn/article/details/7018587 ...

  6. python多级目录import_深入理解Python中import机制

    大型项目中为了维护方便,通常使用模块化开发,模块化的过程中,就会涉及到各种包或者模块的相互导入,即使是对于有多个项目的Python开发者来说, import 也会让人困惑!本文带你深入了解python ...

  7. python中用turtle画爱心表白

    python中用turtle画爱心表白 运行后的效果图: 下面的代码是在python3.7写的,代码有点长,但却语法简单易懂 代码如下: import turtle str = input('请输入表 ...

  8. Python中用Matplotlib做多个纵轴(多y轴)

    转载自:Python中用Matplotlib做多个纵轴(多y轴) Matlab里做多给轴的函数很直接,双轴是plotyy, 三轴是plotyyy, 四轴是plot4y,更多应该是multiplotyy ...

  9. python中用plt画图

    python中用plt画图 import matplotlib.pyplot as plt from matplotlib import font_manager #设置使用的字体,此处使用的是微软雅 ...

最新文章

  1. np.percentile()函数超详解 异常值极端值百分位四分位数
  2. ADPRL - 近似动态规划和强化学习 - Note 5 - Banach Fixed Point Theorem in Dynamic Programming
  3. Vertica数据库
  4. 从“执行新过程新增5%的工作量”看新过程引入
  5. Coding and Paper Letter(六)
  6. java调用指定浏览器_Java调用浏览器打开网页完整实例
  7. yii2.0下,JqPaginator与load实现无刷新翻页
  8. Linux学习笔记13--使用mount命令挂载CDROM
  9. 卡巴斯基宣布高端静谧岑寂僻静产物PURE
  10. ml工程师_ML工程师正在失业。 仍然学习ML
  11. C#反编译软件查看dll文件源码
  12. 2022年南京大学软件工程专硕考研初试第二411分上岸经验贴
  13. atmega328p引脚图_ATMEGA328P-AU 8位AVR微控制器
  14. android多个点的圆形进度条,Android 自定义圆形进度条总结
  15. 【G4基础04】2.4 How to Specify Particles
  16. AlphaTensor横空出世!打破矩阵乘法计算速度50年纪录,DeepMind新研究再刷Nature封面,详细算法已开源...
  17. 高德交通大数据为道路安全解法提供基础
  18. Android AOA协议Android端 流程总结
  19. 基于FPGA的波、幅、频、相可调DDS信号发生器的设计
  20. python网络爬虫网易云音乐下载_python网络爬虫爬取网易云音乐

热门文章

  1. Smart Business design time = CDS view + SADL
  2. 如何用postman发送新浪微博
  3. ABAP Modification browser SE95
  4. 根据变量值取得变量的参数名
  5. SAP CRM产品主数据重要函数COM_PRODUCT_UI_GETDETAIL的调试
  6. 使用JavaScript调用手机平台上的原生API
  7. 使用jMeter构造大量并发的随机HTTP请求
  8. Ubuntu2004,虚拟机中使用,解决系统图标变大变小以及分辨率降低问题
  9. Loadrunner-web资源相关图表
  10. 0-1背包问题(C语言)