質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

7170閲覧

Django 検索フォームで、テーブルからの選択による検索がうまくいきません。

ak_suzuki

総合スコア194

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

1クリップ

投稿2019/07/20 02:06

概要

Djangoで検索機能のあるWebサイトを開発中です。
ブログ記事を投稿して、それをトップ画面でカテゴリごとに検索するものです。

カテゴリにより検索と、フリーワードによる検索をしたいと思っています。

フリーワードによる検索は機能していますが、カテゴリによる絞り込みがうまく機能せず、結果的に全カテゴリのものが出てしまいます。

今のコード(試したコードも含む)

python

1(models.py) 2class Post(models.Model): 3 title = models.CharField('タイトル', max_length=255) 4 text = models.TextField(blank=True) 5 category = models.ForeignKey('posts.Category', on_delete=models.PROTECT) 6 7 8class Category(models.Model): 9 category = models.CharField('カテゴリ', max_length=255) 10 11 def __str__(self): 12 return str(self.category)

python

1(view.py) 2 3class Index(ListView): 4 model = Post 5 template_name = 'posts/index.html' 6 7 def get_context_data(self, *args, **kwargs): 8 searchform = SearchForm() 9 post_list = Post.objects.all() 10 params = { 11 'searchform': searchform, 12 'post_list': post_list, 13 } 14 return params 15 16 17def Search(request): 18 if request.method == 'POST': 19 form = SearchForm(request.POST) 20 21 if form.is_valid(): 22 selected_category = form.cleaned_data['selected_category'] 23 # selected_category = request.POST.get('selected_category', None) 24 # ↑これも試しましたが、やはり検索できずに全件出てきます。 25 freeword = form.cleaned_data['freeword'] 26 search_list = Post.objects.filter(Q(text__icontains = freeword)|Q(category = selected_category)) 27 28 params = { 29 'search_list': search_list, 30 } 31 32 return render (request, 'posts/search.html', params) 33

HTML

1(index.html) 2<form action="{% url 'posts:search' %}" method="POST" novalidate="novalidate"> 3 <select class="form-control search-slt"> 4 <option value="none">カテゴリ</option> 5 {% for item in category_list %} 6 <option name="selected_category" value="{{ item.category }}">{{ item.category }}</option> 7 {% endfor %} 8 </select> 9 10 <input type="search" class="form-control search-slt" name="freeword"> 11 <button type="submit" class="btn btn-danger wrn-btn">Search</button> 12 {% csrf_token %} 13</form>

python

1(context_processor.py) 2from .models import Category 3 4def common(request): 5 context = { 6 'category_list': Category.objects.all(), 7 } 8 9 return context

python

1(urls.py) 2from django.contrib.auth.decorators import login_required 3from . import views 4 5app_name = 'posts' 6 7urlpatterns = [ 8 path('', views.Index.as_view(), name='index'), 9 path('search', views.Search, name='search'), 10]

エラーについて

フリーワードがうまく検索できるので、selected_categoryにうまく値が入っていないような気がします。

ご教授いただけますと幸いです。

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

外部キーでフィルターをかける場合は外部キーのフィールド名まで指定して、モデル単位で比較せず、何と何が一致していればいいのかを明確にしてあげる必要があります。
下記のリンクが参考になるかと思います。
[Django]関連モデルのフィールドで条件指定(Filter)する方法

やり方はアンダーバーを2回挟んだ後にフィールド名を指定します。
livertyさんのコードでやるのであれば、

Python

1search_list = Post.objects.filter(Q(text__icontains=freeword)|Q(category__category=selected_category))

とかになるかと思います。

投稿2019/08/02 12:44

nerianighthawk

総合スコア544

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ak_suzuki

2019/10/14 23:53

ありがとうございます。 参考にさせていただき、解決しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問