转载 https://blog.csdn.net/winycg/article/details/78512300 https://www./Linux/2019-05/158423.htm 在同一个文件夹下,调用函数 def add(x,y): print('和为:%d'%(x+y)) B.py文件: import AA.add(1,2) 或 from A import addadd(1,2) 调用类: 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 Aa=A(2,3)a.add() 或 import Aa=A.A(2,3)a.add() 在不同文件夹下 B.py文件: import syssys.path.append(r'E:\PythonProject\winycg')'''python import模块时, 是在sys.path里按顺序查找的。sys.path是一个列表,里面以字符串的形式存储了许多路径。使用A.py文件中的函数需要先将他的文件路径放到sys.path中'''import Aa=A.A(2,3)a.add() Python中模块互相调用的例子 Python中模块互相调用容易出错,经常是在本地路径下工作正常,切换到其他路径来调用,就各种模块找不到了。解决方法是通过 假设代码结构如下: - mod_a__init__.py # 模块文件夹内必须有此文件aaa.py- mod_b__init__.py # 模块文件夹内必须有此文件bbb.py- ccc.py
如果aaa.py要调用bbb.py的内容,可以在aaa.py中如下写: import syssys.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 syssys.path.append(osp.join(osp.dirname(__file__), '..'))from ccc import * 代码示例: aaa.py如下: # -*- coding: utf-8 -*-from __future__ import print_functionimport os.path as ospimport syssys.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_functiondef print_b():print('this is b')if __name__=='__main__':pass ccc.py如下: # -*- coding: utf-8 -*-from __future__ import print_functionfrom 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 athis is bthis is c 如果调用ccc.py,结果如下: this is cthis is b |
|