2017-10-24 6 views
1

をfloat型に文字列を変換できませんでした私は、このDjangoのモデルに移行/ makemigrationsにしてみてください:リターンフロート(値)とValueError:Djangoのモデルに

from django.db import models 
from myapp.models import Site 

class GscElement(models.Model): 
    ctr = models.FloatField('Taux de clic', default=0.0) 
    impressions = models.IntegerField('Nombre d\'impressions', default=0) 
    position = models.FloatField('Position moyenne', default=0.0) 
    clicks = models.IntegerField('Nombre de clics', default=0) 
    site = models.ForeignKey(
     Site, 
     models.SET_NULL, 
     blank=True, 
     null=True 
    ) 

class Page(GscElement): 
    page_field = models.TextField('Url de la page', default='') 
    startdate = models.DateField('Date du debut', null=True) 
    enddate = models.DateField('Date de fin', null=True) 

    class Meta: 
     unique_together = (('startdate', 'enddate', 'page_field',)) 

class Query(GscElement): 
    query_field = models.TextField('Requête', default='') 
    startdate = models.DateField('Date du debut', null=True) 
    enddate = models.DateField('Date de fin', null=True) 

    class Meta: 
     unique_together = (('startdate', 'enddate', 'query_field'),) 

と私はこのエラーを取得する:

Applying gsc.0004_auto_20171024_1916...Traceback (most recent call last): 
    File "manage.py", line 22, in <module> 
    execute_from_command_line(sys.argv) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/core/management/__init__.py", line 364, in execute_from_command_line 
    utility.execute() 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/core/management/__init__.py", line 356, in execute 
    self.fetch_command(subcommand).run_from_argv(self.argv) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/core/management/base.py", line 283, in run_from_argv 
    self.execute(*args, **cmd_options) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/core/management/base.py", line 330, in execute 
    output = self.handle(*args, **options) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/core/management/commands/migrate.py", line 204, in handle 
    fake_initial=fake_initial, 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/migrations/executor.py", line 115, in migrate 
    state = self._migrate_all_forwards(state, plan, full_plan, fake=fake, fake_initial=fake_initial) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/migrations/executor.py", line 145, in _migrate_all_forwards 
    state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/migrations/executor.py", line 244, in apply_migration 
    state = migration.apply(state, schema_editor) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/migrations/migration.py", line 129, in apply 
    operation.database_forwards(self.app_label, schema_editor, old_state, project_state) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/migrations/operations/fields.py", line 87, in database_forwards 
    field, 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/backends/sqlite3/schema.py", line 238, in add_field 
    self._remake_table(model, create_field=field) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/backends/sqlite3/schema.py", line 113, in _remake_table 
    self.effective_default(create_field) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/backends/base/schema.py", line 229, in effective_default 
    default = field.get_db_prep_save(default, self.connection) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/models/fields/__init__.py", line 770, in get_db_prep_save 
    prepared=False) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/models/fields/__init__.py", line 762, in get_db_prep_value 
    value = self.get_prep_value(value) 
    File "/Users/Quentin/git/myapp/myapp_env/lib/python3.6/site-packages/django/db/models/fields/__init__.py", line 1781, in get_prep_value 
    return float(value) 
ValueError: could not convert string to float: 

理由は何ですか?

FYIモデルを変更する前にデータベースを復元しようとしましたが、マイグレーションも失敗しましたが、同じエラーが常に発生しました。

ありがとうございました!

編集:私は、移行ファイルを見ることなく確かに言うことはできませんすべてのトレースバック

+1

トレースバックを切断しないでください。全体を見せてください。 –

+1

'Taux de clic'これは文字列なので、問題が発生することがあります。 description = "(" Text ")を追加したい場合は – ytsejam

答えて

2

を貼り付けました。それらを投稿すると役に立つでしょう。つまり、文字列フィールドから浮動フィールドにctrまたはpositionの名前を変更しようとしたようです。

これはおそらく、あなたがマカミゲーションを実行したときに起こり、フィールドの名前を変更したかどうか尋ねられました。

  1. 再び
  2. すると再び
  3. 実行のpython manage.pyのmakemigrationsデータベースを復元している最新の移行
  4. を削除します:あなたは、これらのフィールド内のデータを気にしない場合は、次のように行うことができますフィールドの名前を変更したかどうかを尋ねます。新しいフロートを作成する

    ジャンゴあなたが現在お使いのモデルに保存されたデータを保持する必要がある場合、私は次のことをお勧めしたいので、暗黙のうちに、フロートに文字列を変換することはできませんフィールド2

  5. 2番目のフィールドの名前を変更フロートに変換し、一つのフィールドからデータを取得するために管理コマンドを実行し、他のフィールド
  6. 最初の(文字列)を削除し、フィールド
  7. に保存します(floatフィールド)あなたが必要とする名前に私は持っている。
+1

あなたの説明のおかげで、私は何が起こったのか理解しています: – Quentin

関連する問題