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

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

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

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

Python 3.x

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

PyCharm

エディター・開発ツール

Q&A

解決済

1回答

525閲覧

複数の選択肢から該当するものを選ぶフォームを作り、入力を簡単にしたい

yohida19

総合スコア52

Django

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

Python 3.x

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

PyCharm

エディター・開発ツール

0グッド

0クリップ

投稿2022/05/29 02:24

編集2022/05/29 12:36

前提

動かして学ぶ!Python Django開発入門を参考に、DjangoでWebアプリを作成しています。
開発環境で日記(家事記録)の作成、編集、削除、一覧表示は問題なく動作しました。

実現したいこと

日記の作成フォームを改善し、買った物を事前に登録した複数の選択肢の中から選んで入力できるようにしたいです。
(最終的にteratailの質問作成時のタグ入力のような機能にしたいですが、まずは見た目が不格好でも選択肢から選んで入力できることを目指しています。)

日記編集ページとは別に、買った物の選択肢を登録するページ(purcharses_create.html)を作っています。

発生している問題・エラーメッセージ

Traceback (most recent call last): File "C:\test\venv_done_housework\lib\site-packages\django\core\handlers\exception.py", line 55, in inner response = get_response(request) File "C:\test\venv_done_housework\lib\site-packages\django\core\handlers\base.py", line 197, in _get_response response = wrapped_callback(request, *callback_args, **callback_kwargs) File "C:\test\venv_done_housework\lib\site-packages\django\views\generic\base.py", line 84, in view return self.dispatch(request, *args, **kwargs) File "C:\test\venv_done_housework\lib\site-packages\django\contrib\auth\mixins.py", line 73, in dispatch return super().dispatch(request, *args, **kwargs) File "C:\test\venv_done_housework\lib\site-packages\django\views\generic\base.py", line 119, in dispatch return handler(request, *args, **kwargs) File "C:\test\venv_done_housework\lib\site-packages\django\views\generic\edit.py", line 180, in get return super().get(request, *args, **kwargs) File "C:\test\venv_done_housework\lib\site-packages\django\views\generic\edit.py", line 144, in get return self.render_to_response(self.get_context_data()) File "C:\test\venv_done_housework\lib\site-packages\django\views\generic\edit.py", line 74, in get_context_data kwargs["form"] = self.get_form() File "C:\test\venv_done_housework\lib\site-packages\django\views\generic\edit.py", line 39, in get_form return form_class(**self.get_form_kwargs()) TypeError: 'str' object is not callable

該当のソースコード

python

1# views.py 2class PurchasesCreateView(LoginRequiredMixin, generic.CreateView): 3 model = Purchases 4 template_name = 'purchases_create.html' 5 form_class = 'PurchasesCreateForm' 6 success_url = reverse_lazy('housework:housework_list') 7 8 def form_valid(self, form): 9 purchase = form.save(commit=False) 10 purchase.user = self.request.user 11 purchase.save() 12 messages.success(self.request, '買ったものリストを作成しました。') 13 return super().form_valid(form) 14 15 def form_invalid(self, form): 16 messages.error(self.request, '買ったものリストの作成に失敗しました。') 17 return super().form_invalid(form)

python

1# forms.py 2class PurchasesCreateFofrm(forms.ModelForm): 3 class Meta: 4 model = Purchases 5 fields = ('my_purchases',) 6 def __init__(self, *args, **kwargs): 7 super().__init__(*args, **kwargs) 8 for field in self.fields.values(): 9 field.widget.attrs['class'] = 'form-control'

python

1# models.py 2class Purchases(models.Model): 3 """買ったものモデル""" 4 5 my_purchases = models.CharField(verbose_name='商品', max_length=10, blank=True, null=True) 6 7 def __str__(self): 8 return self.my_purchases

html

1# purchases_create.html 2{% block contents %} 3<div class="container"> 4 <div class="row"> 5 <div class="my-div-style w-100"> 6 <form method="POST" enctype="multipart/form-data"> 7 {% csrf_token %} 8 <table class="table"> 9 {{ form.as_table }} 10 </table> 11 <button class="btn btn-primary" type="submit">完了</button> 12 </form> 13 </div> 14 </div> 15</div> 16{% endblock %}

試したこと

このエラーに関して以下2つが複数のサイトで原因とされていたので確認
・strを変数として使用している
・関数名と変数名を同じにして使用している
⇒purchase を Purchasesクラスと PurchasesCreateViewクラスの両方で使用していたので、Purchasesクラスでmy_purchases に変更

・models.py の__str__ を __repr__に変更
・PyCharm、Postgresql、PCを再起動

補足情報(FW/ツールのバージョンなど)

Django 4.0.4
PostgreSQL 14.0
python 3.9.6
Windows 10 home

ご回答よろしくお願いいたします。

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

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

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

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

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

TakaiY

2022/05/29 12:18

エラーメッセージは最後の行だけでなく、その前にあるものも省略せずにすべて載せてください。 そこには問題な派生箇所などの情報が書いてありますので、それが泣ければほとんど意味がありません。
yohida19

2022/05/29 12:39

ご指摘ありがとうございます。修正しました。 何かヒントを頂けると幸いです。
guest

回答1

0

ベストアンサー

エラーの内容からすると、

text

1return form_class(**self.get_form_kwargs())

結局これがエラーです。
で、

python

1class PurchasesCreateView(LoginRequiredMixin, generic.CreateView): 2 model = Purchases 3 template_name = 'purchases_create.html' 4 form_class = 'PurchasesCreateForm'

こうなっていてform_classに「文字列」設定してますね。

継承元でこれは「関数」であることを期待しているのに、文字列が入っているので、

text

1TypeError: 'str' object is not callable

「文字列は(関数のように)呼び出すことはできません」というエラーになっているのでしょう。

ざっとしか見ていませんが、他にも適切な方法で設定されいないように見えるものが沢山ありそうなので、全般的に実装を見直したほうがいいんじゃないかと思います。

投稿2022/05/29 13:27

TakaiY

総合スコア12765

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

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

yohida19

2022/05/29 13:58

丁寧な解説をありがとうございます! ご指摘通り、form_class = PurchasesCreateForm としても、forms.pyでも誤字があったので修正要でした。 自分が全く理解していないところに原因があると思い込み、見当違いなことばかり考えてハマっていました。 冷静に書いたコードをもっと見直すべきでした。 期待した動作とはなりませんでしたが、エラーは解消されたので、もう少し考えてみます。 この度はご回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問