转载 https://blog.csdn.net/winycg/article/details/78512300
https://www.linuxidc.com/Linux/2019-05/158423.htm
在同一个文件夹下,调用函数
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