python导入模块
‘壹’ python如何导入自定义模块
1、相同目录下,若在程序test1.py中导入模块mod1,
则直接使用import
mod1或from
mod1
import
*;
2、主程序所在目录是模块所在目录的父(或祖辈)目录则要建立空文件__init__.py文件然后使用
from
mod2.mod2
import
*
‘贰’ python 导入模块问题
导入模块是会执行一遍的
如果不想在导入模块时执行某部分代码,
需要将那部分代码到
if __name__=='__main__': 里面,
那部分代码只会在当他是作为主文件运行时才会跑
‘叁’ 如何导入其他位置的python模块
import sys
print sys.path
上面的代码会给出所有可用的python路径,你把.py文件放到这些路径下面就可以在其他文件里导入它了。
另外一个特殊的路径就是当前路径,比如你在一个文件夹test下新建两个.py文件,分别为123.py 和456.py ,那么你可以在123.py写:
1
import 456
就可以导入456.py了。
python的模块都是.py文件,提示invaild syntax 是说语法错误。如果你用的是python3,那你的print就写错了。python2和3的print 区别如下。
1
2
print 'hello world' #python2
print('hello world') #python3
‘肆’ 如何导入python中的模块
定义模块,只要使用文本编辑器,把一些python代码输入到文本中,然后以.py为后缀名进行保存,任何此类文件都会被认为是python模块。
比如说,下面的代码输入到一个文件中,就可以看作是一个模块:
def printme(var): print varif __name__ == '__main__': printme(1)
假设说输入到a.py中,那么import a就可以把这个模块导入。
然后可执行a.printme(3),屏幕即可打印出3:
>>> a.printme(3)3>>>
一个模块顶层定义的变量,会自动变成模块的属性。例如:
data=[1,2,3]def printme(var): print varif __name__ == '__main__': printme(1)
data变量就是模块的一个属性。其实printme也是一个属性,只不过是一个函数罢了。
引入模块示例如下:(假定此时data=[1,2,3]未定义)
>>> import a>>> a.data Traceback (most recent call last): File "<pyshell#1>", line 1, in <mole> a.dataAttributeError: 'mole' object has no attribute 'data'>>> reload(a)<mole 'a' from 'C:/py\a.pyc'>>>> a.data Traceback (most recent call last): File "<pyshell#3>", line 1, in <mole> a.dataAttributeError: 'mole' object has no attribute 'data'>>>
从上述提示可以看出data属性未定义,此时再在a.py文件中定义data=[1,2,3],重新加载a模块,并输出data属性:
>>> reload(a)<mole 'a' from 'C:/py\a.py'>>>> a.data[1, 2, 3]>>>
这里的reload函数可以重新加载一个模块。如果在模块代码中更改了,那么需要重新加载。
上面a.data,就是访问模块中的属性。
上面的例子是导入一个文件作为一个模块。
其实python的模块导入还有更丰富的内容。
除了模块名之外,python也可以导入指定目录路径。python代码的目录就称为包。因此,这类导入就称为包导入。事实上,包导入是把计算机上的目录变成python的一个命名空间。而属性就是目录中包含的子目录或者是模块文件。
看下面例子:
在我的桌面上有一个aa文件夹,里面有bb文件夹,bb里面有a.py这个文件。
那么在aa和bb文件夹中分别放置一个__init__.py,之后,在命令行中import aa.bb.a,就可以导入模块a了。
‘伍’ python 导入模块
在文件夹a的下面,新建一个__init__.py的py文件,
然后添加ab文件路径为系统路径:sys.path.append(ab文件路径)
最后利用:from a import a即可。
‘陆’ python导入模块问题
其实很简单,这是命名空间的问题,每个模块或者一个包就是一个命名空间,每个都相对独立的,只有导入时才会有某种关系存在。
也就是说,如果你在connect.py文件里没有导入time模块,使用的话本来就会提示time没有定义(因为你事先没有导入嘛)。然后当程序运行时,会优先把模块和定义的函数先走一遍存在缓存里(你可以理解为检测一篇),然后再按照代码顺序由上而下运行。所以当程序优先运行模块和定义的函数时,发现你的connect.py报错,那么后面与这个函数或者模块相关的代码都不会再继续运行。
所以你在connect.py的文件里import time,而主py文件不需要导入time模块就行。
‘柒’ 有关Python导入模块的问题
我真的是。。。小白是真的可怜,连续回答了四个问题了。。。
你先查一下网络行吗,你看楼下在回答啥?我直接懵了。
要么把你要导入的文件放在你这个程序的下方后直接import,要么加相对地址。
‘捌’ 在python中,哪个关键字可以导入模块
有两种:
①import +模块名
②from +模块名 import +模块下的方法/类/值名
①示例:import math
之后可以使用math.log(40)等函数了,它会返回3.6888794541139363。
还有一种类似于import math as m,它就是表示你只要输入m就代表math了,可以方便写。这样的话就写m.log(40)
②示例:from math import log
之后可以直接使用log(40),但是不能使用math.(因为被跳过了),结果同上。
还有一种,就是类似于from math import *
这样之后,你就会把所有的math里的直接的方法/类/值调用出来,直接使用。
‘玖’ Python导入模块问题
这个问题涉及到包和模块管理。包名和模块名一般是小写。你的文件是下面的结构,需要创建空文件 b/__init__.py,将b目录变成package。
a/a.py
fromb.cimportindex
index()
b/c.py
defindex():
print("hello")
b/__init__.py
a/a.py 里面有两种引用方式,相对引用和绝对引用:
# 如果a.py是 library,两种引用方式都可以
from..b.cimportindex
# 如果a.py是 executable,必须使用绝对引用
fromb.cimportindex
如果使用绝对引用,需要确保b所在目录在PYTHONPATH (sys.path)里面,比如可以这样执行:
envPYTHONPATH=.pythona/a.py
‘拾’ 详解Python中import方法引入模块
在python用import或者from...import或者from...import...as...来导入相应的模块,作用和使用方法与C语言的include头文件类似。其实就是引入某些成熟的函数库和成熟的方法,避免重复造轮子,提高开发速度。
python的import方法可以引入系统的模块,也可以引入我们自己写好的共用模块,这点和php非常相似,但是它们的具体细节还不是很一样。因为php是在引入的时候指明引入文件的具体路径,而python中不能够写文件路径进行引入。
下面总结一下import的几种情况:
python包含子目录中的模块方法比较简单,关键是能够在sys.path里面找到通向模块文件的路径。
下面将具体介绍几种常用情况:
(1)主程序与模块程序在同一目录下:
如下面程序结构:
`-- src
|-- mod1.py
`-- test1.py
若在程序test1.py中导入模块mod1, 则直接使用import mod1或from mod1 import *;
(2)主程序所在目录是模块所在目录的父(或祖辈)目录
如下面程序结构:
`-- src
|-- mod1.py
|-- mod2
| `-- mod2.py
`-- test1.py
若在程序test1.py中导入模块mod2, 需要在mod2文件夹中建立空文件__init__.py文件(也可以在该文件中自定义输出模块接口); 然后使用 from mod2.mod2 import * 或import mod2.mod2.
(3)主程序导入上层目录中模块或其他目录(平级)下的模块
如下面程序结构:
`-- src
|-- mod1.py
|-- mod2
| `-- mod2.py
|-- sub
| `-- test2.py
`-- test1.py
若在程序test2.py中导入模块mod1和mod2。首先需要在mod2下建立__init__.py文件(同(2)),src下不必建立该文件。然后调用方式如下:
下面程序执行方式均在程序文件所在目录下执行,如test2.py是在cd sub;之后执行python test2.py
而test1.py是在cd src;之后执行python test1.py; 不保证在src目录下执行python sub/test2.py成功。
import sys
sys.path.append("..")
import mod1
import mod2.mod2