mypkg/
├── mypkg-1_0_0/
│ ├── __init__.py
├── __init__.py
以上目录是我的modules目录外观的示例。主模块mypkg
包含所有子版本。当我执行import mypkg
时,__init__
文件用于在运行目标版本__init__
文件并将属性设置为globals()
]时将导入重定向到正确的版本。
__init__.py
中的mypkg
外观如下:
def __load(): import os pkgrelease = "mypkg-1_0_0" if pkgrelease: current_path = __path__[0] new_path = os.path.join( current_path, pkgrelease ) init_path = os.path.join( new_path, "__init__.py" ) __path__[:] = [new_path] initf = open( init_path ) exec compile( initf.read(), init_path, "exec" ) in globals() initf.close() else: raise ImportError( "Could not find [%s] package version" % os.path.basename(__path__) ) __load() del __load
在
python2
中,这很好用,程序包被重定向到版本1_0_0
,并且在__version__
中保留并设置了该版本__init__
文件中的globals()
之类的东西。但是我也知道,有一种更好的方法可以实现我在这里想要实现的交叉兼容。由于exec编译语句,这在python3中不起作用。
mypkg /├──mypkg-1_0_0 /│├──__init__.py├──__init__.py上面的目录是我的modules目录的示例。主模块mypkg包含所有子版本。当我这样做时...
我发现了一个可以同时在py2 / 3上使用的解决方案。只需调整exec
函数以接受globals()
参数即可。显示为here in the docs。这是修改后的代码: