为什么manage.py执行脚本在if __name__ ==“__ main__”下使用时运行两次

时间:2014-03-11 11:14:06

标签: python django popen

目标。 启动django框架时还会启动依赖django对象的其他PY脚本。 从配置文件中获取服务器和端口号。

问题: Popen好像跑了两次,我不确定为什么?

#!/usr/bin/env python
import os
import sys
import subprocess
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "test.localsettings")
from django.core.management import execute_from_command_line

def getargs(): 
    try:
        f = open("config")
        data = []
        for line in f:
            data.append(line)
        f.close()
        server = data[0].rstrip()
        port = data[1]
        newargs = ['lmanage.py', 'runserver', server + ':' + port]
        return newargs

    except Exception as e:
        print e
        pass

if __name__ == "__main__":

    #Launching Checker
    try: 
        checker = subprocess.Popen([sys.executable, os.path.join(os.getcwd() + "checker.py")], stdout=subprocess.PIPE, stderr=subprocess.PIPE, stdin=subprocess.PIPE)
        print checker.pid
    except Exception as e:
        print e
        pass 
    print "end"

    execute_from_command_line(getargs())

输出:

16200
end
29716
end
Validating models...

这是我的第一次尝试,如果有人知道更好的方法,那么请随时告诉我。

谢谢大家。

1 个答案:

答案 0 :(得分:4)

您的代码正在启动runserver命令,这会导致Django使用reloader,这反过来意味着您的代码被重新执行,就像在命令行中输入一样。如果您在启动--noreload时使用runserver,问题就会消失。

基本上,在修改源文件时自动重新加载Django的相同工具(在开发中非常有用)现在导致代码执行两次。