首页  >  问答  >  正文

python - 刚创建项目 django manage.py runserver 报错UnicodeEncodeError:'mbcs'

win10系统,python 3.5.2, djang 1.10.3
刚刚创建django项目

C:\Users\JD\Desktop\firstsite>python manage.py runserver
Traceback (most recent call last):
  File "manage.py", line 22, in <module>
    execute_from_command_line(sys.argv)
  File "C:\Python35\lib\site-packages\django\core\management\__init__.py", line 367, in execute_from_command_line
    utility.execute()
  File "C:\Python35\lib\site-packages\django\core\management\__init__.py", line 359, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "C:\Python35\lib\site-packages\django\core\management\base.py", line 294, in run_from_argv
    self.execute(*args, **cmd_options)
  File "C:\Python35\lib\site-packages\django\core\management\commands\runserver.py", line 58, in execute
    super(Command, self).execute(*args, **options)
  File "C:\Python35\lib\site-packages\django\core\management\base.py", line 345, in execute
    output = self.handle(*args, **options)
  File "C:\Python35\lib\site-packages\django\core\management\commands\runserver.py", line 97, in handle
    self.run(**options)
  File "C:\Python35\lib\site-packages\django\core\management\commands\runserver.py", line 106, in run
    autoreload.main(self.inner_run, None, options)
  File "C:\Python35\lib\site-packages\django\utils\autoreload.py", line 334, in main
    reloader(wrapped_main_func, args, kwargs)
  File "C:\Python35\lib\site-packages\django\utils\autoreload.py", line 305, in python_reloader
    exit_code = restart_with_reloader()
  File "C:\Python35\lib\site-packages\django\utils\autoreload.py", line 291, 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: invalid character

网上没有搜出成功又可解决我的问题的办法。
但有别人成功却不能解决我的:

http://stackoverflow.com/ques... 或者 https://segmentfault.com/q/10...
在~Python35\lib\site-packages\django\utils\autoreload.py中添加

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

也可尝试添加

new_environ['PATH'] = os.path.abspath(new_environ['PATH'].encode('ascii', 'replace'))

但这两种方法都不能解决的问题。

希望有经验的同学能够看到我的问题并好心解答
谢谢

迷茫迷茫2713 天前1113

全部回复(1)我来回复

  • 大家讲道理

    大家讲道理2017-04-18 09:56:03

    我自己解决了呃。
    主要还是去C:Python35Libsite-packagesdjangoutils里面找autoreload.py这个文件的问题。
    定位:autoreload.py --- 函数restart_with_reloader。最终采用的代码如下:

    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'
            # 删除CLASSPATH
            if 'CLASSPATH' in new_environ.keys():
                del new_environ['CLASSPATH']
            exit_code = os.spawnve(os.P_WAIT, sys.executable, args, new_environ)
            if exit_code != 3:
                return exit_code
                

    看上去有点乱,但意思其实就是一个一个打印出来看哪个有问题。
    我发现在我的new_environ里面,有个CLASSPATH字段出了问题,

    'CLASSPATH': '.;\u202aC:\Program Files\Java\jdk1.8.0_101\bin'
    

    于是我就想办法把这里面的U202a去掉,后来去不掉(因为很神奇地,单独定位print(new_environ['CLASSPATH'])是没有u202a的,靠),我干脆del删除掉。
    嗯,IT WORKED

    回复
    0
  • 取消回复