syncdb erreur dans django lorsque vous essayez d'exécuter python manage.py syncdb
-
21-12-2019 - |
Question
Im à la Suite d'un django tutoriel mais je triple a tout vérifié et ses pas de travail pour moi, c'est ce que je reçois....qu'ai-je fait de mal.
python manage.py syncdb
Traceback (most recent call last):
File "manage.py", line 10, in <module>
execute_from_command_line(sys.argv)
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/lib/python2.7/site-packages/django/core/management/__init__.py", line 399, in execute_from_command_line
utility.execute()
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/lib/python2.7/site-packages/django/core/management/__init__.py", line 392, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/lib/python2.7/site-packages/django/core/management/base.py", line 242, in run_from_argv
self.execute(*args, **options.__dict__)
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/lib/python2.7/site-packages/django/core/management/base.py", line 284, in execute
self.validate()
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/lib/python2.7/site-packages/django/core/management/base.py", line 310, in validate
num_errors = get_validation_errors(s, app)
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/lib/python2.7/site-packages/django/core/management/validation.py", line 34, in get_validation_errors
for (app_name, error) in get_app_errors().items():
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/lib/python2.7/site-packages/django/db/models/loading.py", line 196, in get_app_errors
self._populate()
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/lib/python2.7/site-packages/django/db/models/loading.py", line 75, in _populate
self.load_app(app_name, True)
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/lib/python2.7/site-packages/django/db/models/loading.py", line 99, in load_app
models = import_module('%s.models' % app_name)
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/lib/python2.7/site-packages/django/utils/importlib.py", line 40, in import_module
__import__(name)
File "/Volumes/SWEETMEDIA/Development/Python/hackernews/hn/stories/models.py", line 6, in <module>
(hackernews)
sweetmedia: /Volumes/SweetMedia/Development/Python/hackernews/hn ▸▸▸▹▹▹▹▹▹▹
→
C'est ce que j'ai dans les BASES de données
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
C'est models.py
à partir de l'app stories
j'ai peut-être quelque chose ici, je n'ai pas le ramasser?
from urlparse import urlparse
from django.db import models
from django.contrib.auth.models import User
class Story(models.Model):
title = models.CharField(max_length=200)
url = models.URLField()
points = models.IntergerField()
moderator = models.ForeignKey(User)
created_at = models.DateTimeField(auto_now_add=True)
updated_at = models.DateTimeField(auto_now=True)
@property
def domain(self):
return urlparse(self.url).netloc
La solution 2
dans le modèle des modérateurs que j'ai eu:
points = models.IntergerField()
et "inte (r) gerfield" n'existe pas!lol je me suis trompé.Je l'ai corrigé pour:
points = models.IntegerField()
Autres conseils
Vous n'avez pas réglé le MOTEUR de base de données en paramètre settings.py
Cela va être créé dans le même répertoire que celui à partir duquel vous exécutez manage.py
'NAME': 'data.sqlite',
Cela donnera le nom de fichier de votre emplacement et pour la db
'NAME': '/yourpath/mysite/data.sqlite',
Le mieux est de passer un chemin absolu comme
import os
SETTINGS_DIR = os.path.dirname(os.path.abspath(__file__))
et le NOM que
'NAME': os.path.join(SETTINGS_DIR, 'data.sqlite'),