首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ImportError:无法从“djongo”导入名称“djongo_access_url”

ImportError:无法从“djongo”导入名称“djongo_access_url”
EN

Stack Overflow用户
提问于 2022-08-22 07:28:01
回答 1查看 81关注 0票数 0

在django服务器中使用Djongo和Mongodb时,我得到了以下错误:

代码语言:javascript
复制
Watching for file changes with StatReloader
Performing system checks...

Exception in thread django-main-thread:
Traceback (most recent call last):
  File "/usr/lib/python3.10/threading.py", line 1009, in _bootstrap_inner
    self.run()
  File "/usr/lib/python3.10/threading.py", line 946, in run
    self._target(*self._args, **self._kwargs)
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/utils/autoreload.py", line 53, in wrapper
    fn(*args, **kwargs)
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/core/management/commands/runserver.py", line 118, in inner_run
    self.check(display_num_errors=True)
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/core/management/base.py", line 392, in check
    all_issues = checks.run_checks(
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/core/checks/registry.py", line 70, in run_checks
    new_errors = check(app_configs=app_configs, databases=databases)
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/core/checks/urls.py", line 13, in check_url_config
    return check_resolver(resolver)
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/core/checks/urls.py", line 23, in check_resolver
    return check_method()
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/urls/resolvers.py", line 408, in check
    for pattern in self.url_patterns:
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/utils/functional.py", line 48, in __get__
    res = instance.__dict__[self.name] = self.func(instance)
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/urls/resolvers.py", line 589, in url_patterns
    patterns = getattr(self.urlconf_module, "urlpatterns", self.urlconf_module)
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/utils/functional.py", line 48, in __get__
    res = instance.__dict__[self.name] = self.func(instance)
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/urls/resolvers.py", line 582, in urlconf_module
    return import_module(self.urlconf_name)
  File "/usr/lib/python3.10/importlib/__init__.py", line 126, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "<frozen importlib._bootstrap>", line 1050, in _gcd_import
  File "<frozen importlib._bootstrap>", line 1027, in _find_and_load
  File "<frozen importlib._bootstrap>", line 1006, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 688, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 883, in exec_module
  File "<frozen importlib._bootstrap>", line 241, in _call_with_frames_removed
  File "/home/cchilders/projects/stocks_backend/dividends_project/urls.py", line 23, in <module>
    path('users/', include('users.urls', namespace='users')),
  File "/home/cchilders/.local/lib/python3.10/site-packages/django/urls/conf.py", line 34, in include
    urlconf_module = import_module(urlconf_module)
  File "/usr/lib/python3.10/importlib/__init__.py", line 126, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "<frozen importlib._bootstrap>", line 1050, in _gcd_import
  File "<frozen importlib._bootstrap>", line 1027, in _find_and_load
  File "<frozen importlib._bootstrap>", line 1006, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 688, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 883, in exec_module
  File "<frozen importlib._bootstrap>", line 241, in _call_with_frames_removed
  File "/home/cchilders/projects/stocks_backend/users/urls.py", line 3, in <module>
    from . import views
  File "/home/cchilders/projects/stocks_backend/users/views.py", line 10, in <module>
    from djongo import transaction
  File "/home/cchilders/.local/lib/python3.10/site-packages/djongo/transaction.py", line 2, in <module>
    from djongo import djongo_access_url
ImportError: cannot import name 'djongo_access_url' from 'djongo' (/home/cchilders/.local/lib/python3.10/site-packages/djongo/__init__.py)

我的用户/views.py:

代码语言:javascript
复制
from django.shortcuts import render
from django.http import HttpResponse
from django.views.decorators.csrf import csrf_exempt

import json

from helpers.view_functions import parse_request_body
from .models import UserProfile

from djongo import transaction


@csrf_exempt
def get_user_profile(request, user_id):
    # pass
    if request.method == 'GET':
        with transaction.atomic():
            profile, created = UserProfile.objects.get_or_create(user_id=user_id)
        if created:
            profile.user_id = user_id
            profile.searches = [
                {'search_term': 'hd'},
                {'search_term': 'wba'},
            ]
            profile.display_settings = [
                {'setting_name': 'showYieldChange', 'visible': True},
                {'setting_name': 'showAllDividends', 'visible': True},
            ]
            profile.save()
            print("user saved in db")
        user = UserProfile.objects.get(user_id=user_id)


        data = {
            'user_id': user.user_id,
            'searches': user.searches,
            'display_settings': user.display_settings
        }
        json_data = json.dumps(data)
        return HttpResponse({json_data}, content_type='application/json')

    if request.method == 'POST':
        body = parse_request_body(request)
        searches = body['searches']
        searches_objects = [{'search_term': x} for x in searches]
        print("New searches for user {user_id}".format(user_id=user_id))
        print(searches_objects)
        user = UserProfile.objects.get(user_id=user_id)
        user.searches = searches_objects
        user.display_settings = body['display_settings']
        user.save()
        return HttpResponse("it worked")

用户/urls.py:

代码语言:javascript
复制
from django.urls import path

from . import views

app_name = 'dividends'
urlpatterns = [
    path('<str:user_id>', views.get_user_profile, name='get_user_profile'),
]

requirements.txt:

代码语言:javascript
复制
bs4
django==3.1.12
django-cors-headers
djongo
gunicorn
html5lib
pymongo==3.12.3
python-decouple
yfinance

用户/Models.py:

代码语言:javascript
复制
from djongo import models


class RecentSearch(models.Model):
    search_term = models.CharField(max_length=100)

    class Meta:
        abstract = True


class DisplaySetting(models.Model):
    setting_name = models.CharField(max_length=150)
    visible = models.BooleanField()

    class Meta:
        abstract = True


class UserProfile(models.Model):
    user_id = models.CharField(max_length=255, unique=True)
    searches = models.ArrayField(model_container=RecentSearch, null=True)
    display_settings = models.ArrayField(model_container=DisplaySetting, null=True)

    objects = models.DjongoManager()

在ipython中:

代码语言:javascript
复制
IPython 8.4.0 -- An enhanced Interactive Python. Type '?' for help.

In [1]: import djongo

In [2]: from djongo import transaction
---------------------------------------------------------------------------
ImportError                               Traceback (most recent call last)
Input In [2], in <cell line: 1>()
----> 1 from djongo import transaction

File ~/.local/lib/python3.10/site-packages/djongo/transaction.py:2, in <module>
      1 from djongo.exceptions import NotSupportedError
----> 2 from djongo import djongo_access_url
      4 print(f'This version of djongo does not support transactions. Visit {djongo_access_url}')
      5 raise NotSupportedError('transactions')

ImportError: cannot import name 'djongo_access_url' from 'djongo' (/home/cchilders/.local/lib/python3.10/site-packages/djongo/__init__.py)

In [3]: 
EN

回答 1

Stack Overflow用户

发布于 2022-08-22 17:32:08

正确使用get_or_create,只有在只有一个唯一模型时,created=True才能解决重复模型的错误时才保存新的数据

代码语言:javascript
复制
@csrf_exempt
def get_user_profile(request, user_id):
    pass
    if request.method == 'GET':
        # with transaction.atomic():
        profile, created = UserProfile.objects.get_or_create(user_id=user_id)
        if created:
            profile.user_id = user_id
            profile.searches = [
                {'search_term': 'hd'},
                {'search_term': 'wba'},
            ]
            profile.display_settings = [
                {'setting_name': 'showYieldChange', 'visible': True},
                {'setting_name': 'showAllDividends', 'visible': True},
            ]
            profile.save()
            print("user saved in db")
        # user = UserProfile.objects.get(user_id=user_id)

    
        data = {
            'user_id': profile.user_id,
            'searches': profile.searches,
            'display_settings': profile.display_settings
        }
        json_data = json.dumps(data)
        return HttpResponse({json_data}, content_type='application/json')

必须将唯一属性(如user_id或股票代码)设置为unique=True。

代码语言:javascript
复制
@csrf_exempt
def get_user_profile(request, user_id):
    pass
    if request.method == 'GET':
        # with transaction.atomic():
        profile, created = UserProfile.objects.get_or_create(user_id=user_id)
        if created:
            profile.user_id = user_id
            profile.searches = [
                {'search_term': 'hd'},
                {'search_term': 'wba'},
            ]
            profile.display_settings = [
                {'setting_name': 'showYieldChange', 'visible': True},
                {'setting_name': 'showAllDividends', 'visible': True},
            ]
            profile.save()
            print("user saved in db")
        # user = UserProfile.objects.get(user_id=user_id)

    
        data = {
            'user_id': profile.user_id,
            'searches': profile.searches,
            'display_settings': profile.display_settings
        }
        json_data = json.dumps(data)
        return HttpResponse({json_data}, content_type='application/json')

模型

代码语言:javascript
复制
class UserProfile(models.Model):
    user_id = models.CharField(max_length=255, unique=True)
    searches = models.ArrayField(model_container=RecentSearch, null=True)
    display_settings = models.ArrayField(model_container=DisplaySetting, null=True)

    objects = models.DjongoManager()
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73441535

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档