内容简介:Python中模块互相调用容易出错,经常是在本地路径下工作正常,切换到其他路径来调用,就各种模块找不到了。解决方法是通过假设代码结构如下:如果aaa.py要调用bbb.py的内容,可以在aaa.py中如下写:
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
Linux公社的RSS地址 : https://www.linuxidc.com/rssFeed.aspx
本文永久更新链接地址: https://www.linuxidc.com/Linux/2019-05/158423.htm
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 一种在 Library 模块中调用 Application 模块功能的方法
- Nodejs如何调用Dll模块
- node中使用C++模块调用调用speex完成语音文件压缩
- 利用 Transform 解决模块化开发服务调用问题
- 『互联网架构』软件架构-Dubbo调用模块(46)
- NW.js 0.28 发布,Web 调用 Node 模块
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。