对修改的Django项目执行命令出现异常。
$python manage.py runserver
报错日志:
Traceback (most recent call last):
File "manage.py", line 22, in <module>
main()
File "manage.py", line 18, in main
execute_from_command_line(sys.argv)
File "/home/user/apps/venv/lib/python3.8/site-packages/django/core/management/__init__.py", line 419, in execute_from_command_line
utility.execute()
File "/home/user/apps/venv/lib/python3.8/site-packages/django/core/management/__init__.py", line 413, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "/home/user/apps/venv/lib/python3.8/site-packages/django/core/management/__init__.py", line 257, in fetch_command
klass = load_command_class(app_name, subcommand)
File "/home/user/apps/venv/lib/python3.8/site-packages/django/core/management/__init__.py", line 39, in load_command_class
module = import_module('%s.management.commands.%s' % (app_name, name))
File "/usr/lib/python3.8/importlib/__init__.py", line 127, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "<frozen importlib._bootstrap>", line 1014, in _gcd_import
File "<frozen importlib._bootstrap>", line 991, in _find_and_load
File "<frozen importlib._bootstrap>", line 975, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 671, in _load_unlocked
File "<frozen importlib._bootstrap_external>", line 848, in exec_module
File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
File "/home/user/apps/venv/lib/python3.8/site-packages/django/contrib/staticfiles/management/commands/runserver.py", line 3, in <module>
from django.core.management.commands.runserver import (
File "/home/user/apps/venv/lib/python3.8/site-packages/django/core/management/commands/runserver.py", line 10, in <module>
from django.core.servers.basehttp import (
File "/home/user/apps/venv/lib/python3.8/site-packages/django/core/servers/basehttp.py", line 14, in <module>
from wsgiref import simple_server
File "/usr/lib/python3.8/wsgiref/simple_server.py", line 13, in <module>
from http.server import BaseHTTPRequestHandler, HTTPServer
File "/usr/lib/python3.8/http/server.py", line 628, in <module>
class SimpleHTTPRequestHandler(BaseHTTPRequestHandler):
File "/usr/lib/python3.8/http/server.py", line 879, in SimpleHTTPRequestHandler
if not mimetypes.inited:
AttributeError: module 'mimetypes' has no attribute 'inited'
查看重点问题所在:
File "/usr/lib/python3.8/http/server.py", line 879, in SimpleHTTPRequestHandler
if not mimetypes.inited:
AttributeError: module 'mimetypes' has no attribute 'inited'
点击源文件查看位于server.py第879行的详细内容:
data:image/s3,"s3://crabby-images/d294e/d294e9a7fde7015290c93ef72ec96c556fcf2796" alt="server.py-line879"
data:image/s3,"s3://crabby-images/7e4c1/7e4c158601da880fc21458ca8432d33beadfdc84" alt="import mimetypes"
data:image/s3,"s3://crabby-images/2f235/2f235ff8225727d48ac868f905afbdac801a26c6" alt="mimetypes.py: inited"
在server.py中的头部是“import mimetypes”,mimetypes是内置库。查看mimetypes.py源代码,可见变量"inited"是存在的。可见是导入重名的“mimetypes”库导致的异常。仔细查找发现是项目自定义相同名称的模块文件。
data:image/s3,"s3://crabby-images/5bb9f/5bb9f58271cc81db1a32d37c67b345debb4d9a5f" alt="自定义mimetypes.py"
命名自定义的mimetypes.py为mimetypesd.py。
data:image/s3,"s3://crabby-images/22c76/22c76181c32053da8f91058a70c20c43b6febedb" alt="rename self-defined mimetypes.py to mimetypesd.py"
重新执行命令:
$python manage.py runserver
data:image/s3,"s3://crabby-images/d1856/d1856e22cef0db388b66e11f36d4db19264f03dd" alt="redo python manage.py runserver"
|