2016-09-22 19 views
0

私はcsvファイル用のインポータを作成しようとしています。エラー:django.core.exceptions.AppRegistryNotReady:モデルがまだロードされていません

File "load_data.py", line 101, in <module> 
    import_SO(st,"statename",row[3]) # Objekt, Kriterium, zu vergleichender Wert 
    File "load_data.py", line 68, in import_SO 
    obj_state=type(item).objects.filter(crit=val)#crit=val) # suche object mit merkmal, hier statename 
    File "/usr/lib/python2.7/dist-packages/django/db/models/manager.py", line 127, in manager_method 
    return getattr(self.get_queryset(), name)(*args, **kwargs) 
    File "/usr/lib/python2.7/dist-packages/django/db/models/query.py", line 679, in filter 
    return self._filter_or_exclude(False, *args, **kwargs) 
    File "/usr/lib/python2.7/dist-packages/django/db/models/query.py", line 697, in _filter_or_exclude 
    clone.query.add_q(Q(*args, **kwargs)) 
    File "/usr/lib/python2.7/dist-packages/django/db/models/sql/query.py", line 1310, in add_q 
    clause, require_inner = self._add_q(where_part, self.used_aliases) 
    File "/usr/lib/python2.7/dist-packages/django/db/models/sql/query.py", line 1338, in _add_q 
    allow_joins=allow_joins, split_subq=split_subq, 
    File "/usr/lib/python2.7/dist-packages/django/db/models/sql/query.py", line 1150, in build_filter 
    lookups, parts, reffed_expression = self.solve_lookup_type(arg) 
    File "/usr/lib/python2.7/dist-packages/django/db/models/sql/query.py", line 1036, in solve_lookup_type 
    _, field, _, lookup_parts = self.names_to_path(lookup_splitted, self.get_meta()) 
    File "/usr/lib/python2.7/dist-packages/django/db/models/sql/query.py", line 1394, in names_to_path 
    field_names = list(get_field_names_from_opts(opts)) 
    File "/usr/lib/python2.7/dist-packages/django/db/models/sql/query.py", line 45, in get_field_names_from_opts 
    for f in opts.get_fields() 
    File "/usr/lib/python2.7/dist-packages/django/db/models/options.py", line 740, in get_fields 
    return self._get_fields(include_parents=include_parents, include_hidden=include_hidden) 
    File "/usr/lib/python2.7/dist-packages/django/db/models/options.py", line 802, in _get_fields 
    all_fields = self._relation_tree 
    File "/usr/lib/python2.7/dist-packages/django/utils/functional.py", line 59, in __get__ 
    res = instance.__dict__[self.name] = self.func(instance) 
    File "/usr/lib/python2.7/dist-packages/django/db/models/options.py", line 709, in _relation_tree 
    return self._populate_directed_relation_graph() 
    File "/usr/lib/python2.7/dist-packages/django/db/models/options.py", line 681, in _populate_directed_relation_graph 
    all_models = self.apps.get_models(include_auto_created=True) 
    File "/usr/lib/python2.7/dist-packages/django/utils/lru_cache.py", line 101, in wrapper 
    result = user_function(*args, **kwds) 
    File "/usr/lib/python2.7/dist-packages/django/apps/registry.py", line 168, in get_models 
    self.check_models_ready() 
    File "/usr/lib/python2.7/dist-packages/django/apps/registry.py", line 131, in check_models_ready 
    raise AppRegistryNotReady("Models aren't loaded yet.") 
django.core.exceptions.AppRegistryNotReady: Models aren't loaded yet. 

しかし、ときに私:ここでは、最小限の例では、それがあるように私は、コードを実行すると、その後、私は次のエラーを取得する

csv_filepathname="/home/thomas/Downloads/zip.csv" 
your_djangoproject_home="~/Desktop/Projects/myproject/myproject/" 

import sys,os,csv 

sys.path.append(your_djangoproject_home) 
os.environ['DJANGO_SETTINGS_MODULE'] = 'settings' 

from django.db.models.fields.related import ManyToManyField 
from myapp.models import ZipCode,state 


dataReader = csv.reader(open(csv_filepathname), delimiter=',', quotechar='"') 




def import_SO(item, crit,val): 

    debug = 1; 

    obj_state=type(item).objects.filter(crit=val) 
    <...some other stuff...> 
    return 



for row in dataReader: 

    st=state(statecode=row[2],statename=row[3]) 

    import_SO(st,"statename",row[3]) 

そして、ここで私のモデルである

class state(models.Model): 
    statecode = models.CharField(max_length=2, default='XX') 
    statename = models.CharField(max_length=32, default='XXXXXXXXXXXXX') 

です"obj_state = type(item).objects.filter(crit = val)"を "obj_state = type(item).objects.filter(statename = val)"に変更してください。 すべて正常に動作します。だから、変数 "crit"に問題があるようですが、この例では "statename"という検索条件を表しています。だから私は引数を介してcritをメソッド "import_SO"に渡したいが、何らかの理由でそれが機能しない。

エラーが発生する直前に変数critを出力すると、変数の内容が正しいように見えます。

アイデア?

更新:

Traceback (most recent call last): 
    File "load_data.py", line 11, in <module> 
    django.setup() 
    File "/usr/lib/python2.7/dist-packages/django/__init__.py", line 18, in setup 
    apps.populate(settings.INSTALLED_APPS) 
    File "/usr/lib/python2.7/dist-packages/django/apps/registry.py", line 85, in populate 
    app_config = AppConfig.create(entry) 
    File "/usr/lib/python2.7/dist-packages/django/apps/config.py", line 112, in create 
    mod = import_module(mod_path) 
    File "/usr/lib/python2.7/importlib/__init__.py", line 37, in import_module 
    __import__(name) 
ImportError: No module named myproject 

がUPDATE: 私のインストール済みのアプリケーション: 私のコードに your_djangoproject_home="~/Desktop/Projects/myprojectos.environ['DJANGO_SETTINGS_MODULE'] = 'myproject.settings'

を追加した後、私は次のエラーを取得する

INSTALLED_APPS = (
    'django.contrib.admin', 
    'django.contrib.auth', 
    'django.contrib.contenttypes', 
    'django.contrib.sessions', 
    'django.contrib.messages', 
    'django.contrib.staticfiles', 
    'myproject.myapp' 
) 
+0

http://stackoverflow.com/documentation/django/5848/django-from-the-command-line/20596/django-from-the-command-line#t=201609221231588765522 django.setup()を実行する必要があります。 – e4c5

+0

'filter(crit = val)'は変数 'crit'ではなくフィールド名 'crit'をフィルタリングします。変数 'crit'を使いたいなら、' filter(** {crit:val}) 'のようなことをする必要があります。 – Alasdair

+0

現在動作中です。ありがとうございました! – Helyx

答えて

1

あなたがする必要がありますORMを使用する前にスクリプトでdjango.setup()を呼び出してくださいデータにアクセスする。

import django 

sys.path.append(your_djangoproject_home) 
os.environ['DJANGO_SETTINGS_MODULE'] = 'settings' 

django.setup() 

詳細はthe docsを参照してください。

+0

これは私にこのエラーを与えます:ImportError:myprojectという名前のモジュールがありません。私のappfolderとsettings.py、urls.pyなどのパスは "〜/ Desktop/Projects/myproject/myproject /"です。 – Helyx

+0

これは別の問題です。あなたの質問を完全なトレースバックで更新してください。コードを 'your_djangoproject_home ="〜/ Desktop/Projects/myproject "と' os.environ ['DJANGO_SETTINGS_MODULE'] = 'myproject.settings'に変更すると、問題が解決する可能性があります。 – Alasdair

+0

更新されました。それは問題を解決しませんでした – Helyx

関連する問題