简体   繁体   中英

Error in manage.py runserver with Django on windows 8.1

I couldn't find this exitcode anywhere but hopefully one of you could help me or let me know if this is a bug in python/Django.

Anyway, first here's the 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

Ignore the weird filepath please, I even just tried putting it on C:\\ directly.

There's another maybe similar Stackoverflow Question here: UnicodeEncodeError when using the compile function but it's not like the filepath I use uses any non-English characters. I tried a couple solutions there but they didn't work.

Running python 3.4.1, tested in 2.7.x before, didn't work either. Runs fine on linux(Ubuntu).

There's nothing special in the django project since it's just the empty startproject project.

I was having the same issue, and I found the solution. From what I searched it also happens with Windows 7 & 8.

If you want to know with more detail how I solved it check the ticket I filed in Django's forums: Error in manage.py runserver on Windows (7 / 8 / 8.1) .

Now to solve the error open this file C:\\Program Files\\Python\\lib\\site-packages\\django\\utils\\autoreload.py (I'm using your code as reference) and add this line of code just before your error (line 279):

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

Your function now should look like this:

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

Now try using again manage.py runserver. I hope this solves your problem and don't feel you're alone.

In my case it had nothing to do with PATH , there seem to be CHROME_RESTART environment setting with some non-english characters. Poping it from new_environ did the trick:

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'

        # This will prevent UnicodeEncodeError
        new_environ.pop("CHROME_RESTART", None)

        exit_code = os.spawnve(os.P_WAIT, sys.executable, args, new_environ)
        if exit_code != 3:
            return exit_code

I tried this

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

but it did not work.

And my solution is

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

Hope it will help you!

UnicodeEncodeError: 'mbcs' codec can't encode characters in position 0--1:invalid character

I had the same problem on windows 7 with

$ python manage.py runserver

Just in case if someone has cyrillic computer name like I had, it's exactly the thing causing your encoding problem. So the solution is to rename your computer using latin alphabet symbols only.

I had the same problem.
The reason was non latin characters in an environment variables entry.
In my case it was cyrilic name of some folder, while my windows was originally english version.
So it had a conflict. After removing it - everything worked ok.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM