[英]Importing Modules from Multiple Parallel Subdirectories (Python)
对于python来说相对较新,我正在使用它进行工作中的实验室设备自动化。
我的脚本位于目录B中。目录B的父目录为目录A。目录A包含另一个目录,我需要从该目录输入和导入模块。 结构如下:
A
B C
myscript.py
E F
m1.py m2.py
我需要将m1.py和m2.py导入到脚本中。 我无法将我的脚本移到A目录中,因为它正在访问我在B中编写并转储的其他模块。出于公司特定的原因,我需要维护包括C目录和C目录以下的所有内容的目录结构(不要获取我开始了。)
我的问题是,我该如何智能地导入这些文件? 我不想对它们的路径进行硬编码,因为它们将存在于SVN中,并且根目录可能会更改。 我在考虑使用循环扫描吗? 我只是不熟悉使之成为可能的语法。 欢迎所有解决方案!
我有以下文件设置:
A
├── B
│ ├── __init__.py
│ └── myscript.py
└── C
├── E
│ ├── __init__.py
│ └── m1.py
├── F
│ ├── __init__.py
│ └── m2.py
└── __init__.py
码:
A / C / E / m1.py
def my_func1():
print 'func1'
A / C / F / m2.py
def my_func2():
print 'func2'
A / B / myscript.py
from C.E.m1 import my_func1
from C.F.m2 import my_func2
my_func1()
my_func2()
或者,如果您的导入目录名称带有空格(例如, C dir
而不是C
):
import importlib
m1 = importlib.import_module("C dir.E.m1")
m2 = importlib.import_module("C dir.F.m2")
m1.my_func1()
m2.my_func2()
所有__init__.py
文件均为空,但需要存在,因此Python知道在这些文件夹中查找代码。
cd
到A
目录,然后以包形式运行脚本。 注意:没有.py
和文件名的末尾。
$ python -m B.myscript
输出:
func1
func2
如果目录结构始终相同,则可以尝试将m1.py
和m2.py
导入,方法是将C
的路径附加到myscript.py
sys.path
中。
您还可以使用os.path.dirname
和os.path.join
和os.path.abspath
类的os.path
方法以及变量__file__
从B
相对地获取C
的路径。
范例-
import os.path
import sys
curdir = os.path.dirname(__file__)
cdir = os.path.abspath(os.path.join(curdir,'../C'))
sys.path.append(cdir)
import m1,m2
更好的做法是在Python中显式导入并注意目录结构。 如果结构发生变化,则您的进口也将发生变化。
只要您的项目位于python路径上,您就应该能够从位于B
或层次结构中其他任何位置的模块执行此操作:
from Project.A.B import myscript
from Project.A.C.E import m1
from Project.A.C.F import m2
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.