我试图从解释器内使用Python命令执行一个文件。

编辑:我试图使用变量和设置从该文件,而不是调用一个单独的进程。


当前回答

就做,

from my_file import *

确保不要添加.py扩展名。如果子目录中使用。py文件,

from my_dir.my_file import *

其他回答

假设你想要以下特性:

源文件在调试器中正常运行(文件名显示在堆栈中,等等) __name__ == '__main__'为True,因此脚本的行为与脚本相同。

exec(open('foo.py').read())特性1失败 导入foo策略失败特性2

要做到这两点,你需要:

    source = open(filename).read()
    code = compile(source, filename, 'exec')
    exec(code)

我不是专家,但这是我注意到的:

例如,如果你的代码是mycode.py,你只输入'import mycode', Python会执行它,但不会让解释器使用你的所有变量。我发现你应该输入'from mycode import *'如果你想让所有变量对解释器可用。

python -c "exec(open('main.py').read())"

我试图使用该文件中的变量和设置,而不是调用一个单独的进程。

好吧,简单地导入带有import filename的文件(减去.py,需要在相同的目录中或在你的PYTHONPATH上)将运行该文件,使其变量、函数、类等在文件名中可用。变量名称空间。

如果你有cheddar。py,变量spam和函数eggs,你可以用import cheddar导入它们,用cheddar访问变量。并通过调用cheddar.eggs()来运行该函数

如果你在cheddar.py中有在函数之外的代码,它将立即运行,但是构建在导入上运行的应用程序将使你的代码难以重用。如果可能的话,把所有东西都放在函数或类中。

没想到我还没见过。你可以执行一个文件,然后在执行结束后使用-i选项保持解释器打开:

| foo.py |
----------
testvar = 10

def bar(bing):
  return bing*3

--------



$ python -i foo.py
>>> testvar 
10
>>> bar(6)
18