2017-03-06 1 views
0

그래서 서버가 시작될 때만 실행되는 Django 1.10 앱에 코드를 추가하려고합니다. 나는 이것을 수행하는 방법에 대한 지침을 herehere에서 가져 갔다. 내가 파이썬 콘솔을 실행하려고 할 때마다 나는이 얻을 :이를 찾는 시도했지만 그러나 내가 사용하고, 그것은 장고와 업데이트 문제에 관련이 있기 때문에이 예외를 얻을 모두가 것 같다"django.core.exceptions.AppRegistryNotReady : 앱이 아직로드되지 않았습니다." 시작 코드

C:\Users\username\Envs\projectName [master ≡ +0 ~2 -0 !]> python manage.py shell 
Traceback (most recent call last): 
    File "manage.py", line 22, in <module> 
    execute_from_command_line(sys.argv) 
    File "C:\Users\username\AppData\Local\Programs\Python\Python35\lib\site-packages\django\core\management\__init__.py", line 367, in execute_from_command_line 
    utility.execute() 
    File "C:\Users\username\AppData\Local\Programs\Python\Python35\lib\site-packages\django\core\management\__init__.py", line 341, in execute 
    django.setup() 
    File "C:\Users\username\AppData\Local\Programs\Python\Python35\lib\site-packages\django\__init__.py", line 27, in setup 
    apps.populate(settings.INSTALLED_APPS) 
    File "C:\Users\username\AppData\Local\Programs\Python\Python35\lib\site-packages\django\apps\registry.py", line 85, in populate 
    app_config = AppConfig.create(entry) 
    File "C:\Users\username\AppData\Local\Programs\Python\Python35\lib\site-packages\django\apps\config.py", line 90, in create 
    module = import_module(entry) 
    File "C:\Users\username\AppData\Local\Programs\Python\Python3\lib\importlib\__init__.py", line 126, in import_module 
    return _bootstrap._gcd_import(name[level:], package, level) 
    File "<frozen importlib._bootstrap>", line 986, in _gcd_import 
    File "<frozen importlib._bootstrap>", line 969, in _find_and_load 
    File "<frozen importlib._bootstrap>", line 944, in _find_and_load_unlocked 
    File "<frozen importlib._bootstrap>", line 222, in_call_with_frames_removed 
    File "<frozen importlib._bootstrap>", line 986, in _gcd_import 
    File "<frozen importlib._bootstrap>", line 969, in _find_and_load 
    File "<frozen importlib._bootstrap>", line 958, in _find_and_load_unlocked 
    File "<frozen importlib._bootstrap>", line 673, in _load_unlocked 
    File "<frozen importlib._bootstrap_external>", line 662, in exec_module 
    File "<frozen importlib._bootstrap>", line 222, in_call_with_frames_removed 
    File "C:\Users\username\Envs\projectName\appName\apps.py", line 2, in <module> 
    import appName.osm as osm 
    File "C:\Users\username\Envs\projectName\appName\osm.py", line 4, in <module> 
    from .models import Country, Embassy 
    File "C:\Users\username\Envs\projectName\appName\models.py", line 38, in <module> 
    class Country(models.Model): 
    File "C:\Users\username\AppData\Local\Programs\Python\Python35\lib\site-packages\django\db\models\base.py", line 105, in __new__ 
    app_config = apps.get_containing_app_config(module) 
    File "C:\Users\username\AppData\Local\Programs\Python\Python35\lib\site-packages\django\apps\registry.py", line 237, in get_containing_app_config 
    self.check_apps_ready() 
    File "C:\Users\username\AppData\Local\Programs\Python\Python35\lib\site-packages\django\apps\registry.py", line 124, in check_apps_ready 
    raise AppRegistryNotReady("Apps aren't loaded yet.") 
django.core.exceptions.AppRegistryNotReady: Apps aren't loaded yet. 

1.10 오랜 시간 동안 (내가 전에 아무것도 만진 적이 있는지 확실하지 않음). 무슨 일있어?

프로젝트 이름/프로그램 응용/apps.py :

from django.apps import AppConfig 
import finder.osm as osm # this seems to cause the issue 

class FinderConfig(AppConfig): 
    name = 'finder' 
    init = True 
    def ready(self): 
     pass 

프로젝트 이름/프로그램 응용/__ init__.py :

default_app_config = 'appName.apps.AppNameConfig' 

프로젝트 이름/프로그램 응용/models.py :

from django.db import models 

class Country(models.Model): 
    #... 

class Embassy(models.Model): 
    #... 
+1

대부분의 경우 원형 가져옵니다. –

답변

1

로서 @ Andrey Shipilov는 AppConfig 클래스와 같은 수준으로 가져올 수 없으므로 잘못된 가져 오기의 경우라고 설명했습니다. 내 솔루션에 대한 수정 AppConfig.ready로 가져 오기를 이동하는 것이었다()

프로젝트 이름/프로그램 응용/apps.py :

from django.apps import AppConfig 


class FinderConfig(AppConfig): 
    import finder.osm as osm 
    name = 'finder' 
    init = True 
    def ready(self): 
     pass 
관련 문제