Windows 8.1上Django的manage.py runserver错误


问题内容

我在任何地方都找不到此退出代码,但希望你们中的一个可以帮助我或让我知道这是否是python / Django中的错误。

无论如何,首先这里是stacktrace:

    Traceback (most recent call last):
  File "C:\Sitezooi\SiteTest\manage.py", line 10, in <module>
    execute_from_command_line(sys.argv)
  File "C:\Program Files\Python\lib\site-packages\django\core\management\__init_
_.py", line 385, in execute_from_command_line
    utility.execute()
  File "C:\Program Files\Python\lib\site-packages\django\core\management\__init_
_.py", line 377, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "C:\Program Files\Python\lib\site-packages\django\core\management\base.py
", line 288, in run_from_argv
    self.execute(*args, **options.__dict__)
  File "C:\Program Files\Python\lib\site-packages\django\core\management\base.py
", line 338, in execute
    output = self.handle(*args, **options)
  File "C:\Program Files\Python\lib\site-packages\django\core\management\command
s\runserver.py", line 83, in handle
    self.run(*args, **options)
  File "C:\Program Files\Python\lib\site-packages\django\core\management\command
s\runserver.py", line 92, in run
    autoreload.main(self.inner_run, args, options)
  File "C:\Program Files\Python\lib\site-packages\django\utils\autoreload.py", l
ine 322, in main
    reloader(wrapped_main_func, args, kwargs)
  File "C:\Program Files\Python\lib\site-packages\django\utils\autoreload.py", l
ine 293, in python_reloader
    exit_code = restart_with_reloader()
  File "C:\Program Files\Python\lib\site-packages\django\utils\autoreload.py", l
ine 279, in restart_with_reloader
    exit_code = os.spawnve(os.P_WAIT, sys.executable, args, new_environ)
UnicodeEncodeError: 'mbcs' codec can't encode characters in position 0--1: inval
id character

请忽略奇怪的文件路径,我什至尝试将其直接放在C:\上。

这里还有另一个可能类似的Stackoverflow问题:使用编译功能时出现UnicodeEncodeError,但与我使用的文件路径不使用任何非英语字符一样。我在那里尝试了几种解决方案,但是它们没有用。

运行之前在2.7.x中测试过的python 3.4.1也不起作用。在linux(Ubuntu)上运行良好。

django项目没有什么特别的,因为它只是空的startproject项目。


问题答案:

我遇到了同样的问题,并且找到了解决方案。根据我的搜索,Windows 7和8也会发生这种情况。

如果您想更详细地了解我如何解决它,请检查我在Django论坛中提交的故障单Windows(7/8
/ 8.1)上的manage.py runserver错误

现在要解决错误,请打开以下文件 C:\ Program Files \ Python \ lib \ site-packages \ django \
utils \ autoreload.py
(我使用您的代码作为参考),并在错误发生之前添加以下代码行( 279行):

new_environ['PATH'] = os.path.abspath(new_environ['PATH'].replace('\u202a', ''))

您的函数现在应如下所示:

def restart_with_reloader():
    while True:
        args = [sys.executable] + ['-W%s' % o for o in sys.warnoptions] + sys.argv
        if sys.platform == "win32":
            args = ['"%s"' % arg for arg in args]
        new_environ = os.environ.copy()
        new_environ["RUN_MAIN"] = 'true'
        new_environ['PATH'] = os.path.abspath(new_environ['PATH'].replace('\u202a', ''))
        exit_code = os.spawnve(os.P_WAIT, sys.executable, args, new_environ)
        if exit_code != 3:
            return exit_code

现在,尝试再次使用manage.py runserver。我希望这可以解决您的问题,并且不要让您感到孤单。