问题:
在airflow中,很多时候我们在airflow dags文件夹写了很多的utils, 但是直接导入不是很方便,甚至出错。那么在脚本中如何动态的导入任意位置的包呢?
方式1:
位置为: ~/utils/util
def hello(name):
print("hello" + name)
import imp
import sys
cfg_path = "~/utils/util.py"
module = sys.modules[__name__]
override_conf = imp.load_source("util", cfg_path)
for key in dir(override_conf):
if key.isupper():
setattr(module, key, getattr(override_conf, key))
from util import hello
hello("zoe")
方式2:
import imp
import sys
cfg_path = "~/utils/util.py"
import cfg_path not in sys.path:
sys.path.append(cfg_path)