在同一个文件夹下,调用函数
A.py文件:
-
def add(x,y):
-
print(\'和为:%d\'%(x+y))
B.py文件:
-
import A
-
A.add(1,2)
或
-
from A import add
-
add(1,2)
调用类:
A.py文件:
-
class A:
-
def __init__(self,xx,yy):
-
self.x=xx
-
self.y=yy
-
def add(self):
-
print("x和y的和为:%d"%(self.x+self.y))
B.py文件:
-
from A import A
-
a=A(2,3)
-
a.add()
或
-
import A
-
a=A.A(2,3)
-
a.add()
在不同文件夹下
A.py文件的文件路径:E:\PythonProject\winycg
B.py文件:
-
import sys
-
sys.path.append(r\'E:\PythonProject\winycg\')
-
\'\'\'python import模块时, 是在sys.path里按顺序查找的。
-
sys.path是一个列表,里面以字符串的形式存储了许多路径。
-
使用A.py文件中的函数需要先将他的文件路径放到sys.path中\'\'\'
-
import A
-
-
a=A.A(2,3)
-
a.add()
Python中模块互相调用的例子
Python中模块互相调用容易出错,经常是在本地路径下工作正常,切换到其他路径来调用,就各种模块找不到了。解决方法是通过__file__定位当前文件的真实路径,再通过sys.path.append()来获取相对路径更新$PATH即可。
假设代码结构如下:
-
- mod_a
-
__init__.py # 模块文件夹内必须有此文件
-
aaa.py
-
- mod_b
-
__init__.py # 模块文件夹内必须有此文件
-
bbb.py
-
- ccc.py
- 调用同级模块
如果aaa.py要调用bbb.py的内容,可以在aaa.py中如下写:
-
import sys
-
sys.path.append(osp.join(osp.dirname(__file__), \'..\')) # 扫除路径迷思的关键!
-
from mod_b.bbb import *
- 调用下级模块
如果ccc.py要调用bbb.py的内容,可以在ccc.py中如下写:
from mod_b.bbb import *
- 调用上级模块
如果aaa.py要调用ccc.py的内容,可以在aaa.py中如下写:
-
import sys
-
sys.path.append(osp.join(osp.dirname(__file__), \'..\'))
-
from ccc import *
代码示例:
aaa.py如下:
-
# -*- coding: utf-8 -*-
-
-
from __future__ import print_function
-
import os.path as osp
-
import sys
-
sys.path.append(osp.join(osp.dirname(__file__), \'..\'))
-
from mod_b.bbb import *
-
from ccc import *
-
-
def print_a():
-
print(\'this is a\')
-
-
def _call_mod_b():
-
print_a()
-
print_b()
-
-
def _call_mod_c():
-
print_c()
-
-
-
if __name__==\'__main__\':
-
_call_mod_b()
-
_call_mod_c()
bbb.py如下:
-
# -*- coding: utf-8 -*-
-
-
from __future__ import print_function
-
-
def print_b():
-
print(\'this is b\')
-
-
-
if __name__==\'__main__\':
-
pass
ccc.py如下:
-
# -*- coding: utf-8 -*-
-
-
from __future__ import print_function
-
from mod_b.bbb import *
-
-
def print_c():
-
print(\'this is c\')
-
-
def _call_mod_b():
-
print_c()
-
print_b()
-
-
-
if __name__==\'__main__\':
-
_call_mod_b()
如此,当不管在何处调用aaa.py时,结果都一样,如下:
-
this is a
-
this is b
-
this is c
如果调用ccc.py,结果如下:
-
this is c
-
this is b