bugfix> python > 投稿

django view.pyファイルで作成しているクエリがあります。クエリで「or」および「and」ステートメントを使用します。 「or_」が定義されていないというメッセージが表示されますが、そのためのインポートステートメントはどこにあるのかわからないので、それが何なのか疑問に思っていました。

クエリは次のとおりです。

@login_required(login_url='/login/')
def user_profile(request, username):
    user = request.user
    view = User.objects.filter(username = username).first()
    view_profile = Profile.objects.filter(user = view).first()
    friends = Friends.objects.filter(or_(
                                        and_(user = user.username, friends = view),
                                        and_(user = view.username, friends = user)
                                    ))
    print(friends)
    parameters = {
        'user':user,
        'view':view,
        'view_profile':view_profile,
        'friends':friends,
    }
    return render(request, 'users/view_profile.html', parameters)

エラーは次のとおりです。

Internal Server Error: /assad/
Traceback (most recent call last):
  File "/Users/omarjandali/anaconda3/envs/MySplit/lib/python3.6/site-packages/django/core/handlers/exception.py", line 35, in inner
    response = get_response(request)
  File "/Users/omarjandali/anaconda3/envs/MySplit/lib/python3.6/site-packages/django/core/handlers/base.py", line 128, in _get_response
    response = self.process_exception_by_middleware(e, request)
  File "/Users/omarjandali/anaconda3/envs/MySplit/lib/python3.6/site-packages/django/core/handlers/base.py", line 126, in _get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "/Users/omarjandali/anaconda3/envs/MySplit/lib/python3.6/site-packages/django/contrib/auth/decorators.py", line 21, in _wrapped_view
    return view_func(request, *args, **kwargs)
  File "/Users/omarjandali/Desktop/demo/mysplit/users/views.py", line 174, in user_profile
    friends = Friends.objects.filter(or_(
NameError: name 'or_' is not defined

回答 1 件
  • 推測では、インポートはおそらくstdlib operator からのものです。  モジュール。しかし、コードには必要な Q がありません  このような方法で演算子関数を使用するオブジェクト。

    これは、Django ORMの使い方をよく知らない人が書いたコードのように思えます。このように書き直してください、 Q はありません  また、 operator  このような単純なクエリには関数が必要です。

    friends  = Friends.objects.filter(user=user.username, friends=view) 
    friends |= Friends.objects.filter(user=view.username, friends=user)
    
    

あなたの答え