1
resposta

[Bug] Esse erro persiste ao executar o python manager.py runserver

Watching for file changes with StatReloader
Exception in thread django-main-thread:
Traceback (most recent call last):
  File "/usr/local/lib/python3.7/threading.py", line 917, in _bootstrap_inner
    self.run()
  File "/usr/local/lib/python3.7/threading.py", line 865, in run
    self._target(*self._args, **self._kwargs)
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/utils/autoreload.py", line 64, in wrapper
    fn(*args, **kwargs)
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/core/management/commands/runserver.py", line 110, in inner_run
    autoreload.raise_last_exception()
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/utils/autoreload.py", line 87, in raise_last_exception
    raise _exception[1]
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/core/management/__init__.py", line 375, in execute
    autoreload.check_errors(django.setup)()
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/utils/autoreload.py", line 64, in wrapper
    fn(*args, **kwargs)
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/__init__.py", line 24, in setup
    apps.populate(settings.INSTALLED_APPS)
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/apps/registry.py", line 114, in populate
    app_config.import_models()
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/apps/config.py", line 301, in import_models
    self.models_module = import_module(models_module_name)
  File "/usr/local/lib/python3.7/importlib/__init__.py", line 127, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "<frozen importlib._bootstrap>", line 1006, in _gcd_import
  File "<frozen importlib._bootstrap>", line 983, in _find_and_load
  File "<frozen importlib._bootstrap>", line 967, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 677, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 728, in exec_module
  File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/contrib/auth/models.py", line 3, in <module>
    from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/contrib/auth/base_user.py", line 48, in <module>
    class AbstractBaseUser(models.Model):
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/db/models/base.py", line 122, in __new__
    new_class.add_to_class('_meta', Options(meta, app_label))
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/db/models/base.py", line 326, in add_to_class
    value.contribute_to_class(cls, name)
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/db/models/options.py", line 207, in contribute_to_class
    self.db_table = truncate_name(self.db_table, connection.ops.max_name_length())
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/utils/connection.py", line 15, in __getattr__
    return getattr(self._connections[self._alias], item)
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/utils/connection.py", line 62, in __getitem__
    conn = self.create_connection(alias)
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/db/utils.py", line 204, in create_connection
    backend = load_backend(db['ENGINE'])
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/db/utils.py", line 111, in load_backend
    return import_module('%s.base' % backend_name)
  File "/usr/local/lib/python3.7/importlib/__init__.py", line 127, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "/home/mikaelhayden/Django/venv/lib/python3.7/site-packages/django/db/backends/sqlite3/base.py", line 15, in <module>
    from sqlite3 import dbapi2 as Database
  File "/usr/local/lib/python3.7/sqlite3/__init__.py", line 23, in <module>
    from sqlite3.dbapi2 import *
  File "/usr/local/lib/python3.7/sqlite3/dbapi2.py", line 27, in <module>
    from _sqlite3 import *
ModuleNotFoundError: No module named '_sqlite3'
1 resposta

Olá, Mikael! Tudo bem com você?

Pelo que pude perceber, o erro que está ocorrendo é um ModuleNotFoundError: No module named '_sqlite3'. Isso significa que o módulo do SQLite3 não está disponível no seu ambiente Python.

SQLite é um banco de dados SQL embutido no Python, e é comumente usado em desenvolvimento Django para testes e desenvolvimento por ser leve e fácil de configurar. O erro indica que o Python não está conseguindo importar o módulo do SQLite3.

Esse problema pode ocorrer por alguns motivos, mas está geralmente relacionado à instalação do Python no seu sistema. Aqui estão algumas possíveis soluções:

  1. Reinstalar o Python: Às vezes, a instalação do Python pode não ter sido feita corretamente ou pode ter faltado algum pacote. Nesse caso, reinstalar o Python pode resolver o problema. Certifique-se de instalar a versão mais recente e, se possível, utilize um gerenciador de versões como o pyenv.

  2. Instalar o SQLite3 manualmente: Em alguns casos, o SQLite3 pode não ter sido instalado com o Python. Você pode tentar instalar o SQLite3 manualmente. Segue o artigo aqui da Alura que conta o passo a passo da instalação: SQLite: da instalação até sua primeira tabela

  3. Verificar a variável de ambiente PYTHONPATH: O Python utiliza a variável de ambiente PYTHONPATH para determinar onde procurar por módulos. Se o SQLite3 estiver instalado, mas o Python não estiver conseguindo encontrá-lo, pode ser que o PYTHONPATH não esteja configurado corretamente.

Lembre-se de que essas são apenas sugestões baseadas no erro apresentado e podem não resolver completamente o problema, já que podem existir outras questões envolvidas que não estão evidentes no traceback do erro. Então, caso as opções acima não resolvam o seu problema, peço que compartilhe os passos que você realizou até a ocorrência do erro.

Espero ter ajudado e bons estudos!

Caso este post tenha lhe ajudado, por favor, marcar como solucionado ✓.