前提・実現したいこと
- DjangoでWebアプリを作っています。
- エクセルの表データを、アプリにコピペしてデータベースに登録できるようにしたいです。
- Django Funky Sheetsというサードパーティのパッケージがまさにそういうことをやってくれそうだったので、それを適用しようと考えています。
https://github.com/trco/django-funky-sheets
発生している問題・エラーメッセージ
- 実装してみると、下記のようにフォームは表示され、エクセルからコピペすることもできました。
- しかし、Createボタンを押すと、success_urlに指定したURLに飛ぶものの、実際にはデータは保存されていませんでした。
- 何らのエラー画面も生じないので、どこで失敗しているのかが掴めておりません。
- Django Funky Sheetsによって出力されたページを見てみると、
html
1<form id="form_hot" method="post" action="" onsubmit="return constructFormset();">
となっており、actionの所が設定されていないので、ここが原因なのかもしれません。
該当のソースコード
下記のDetailというModelについて、Django Funky Sheetsによって登録したいと考えています。
python
1# models.py 2class Detail(models.Model): 3 name = models.CharField(max_length=100, verbose_name='名称') 4 shape_dimension = models.CharField(max_length=100, verbose_name='形状寸法', null=True, blank=True) 5 quantity = models.FloatField(null=True, blank=True, verbose_name='数量') 6 unit = models.CharField(max_length=20, verbose_name='単位', null=True, blank=True) 7 unit_price = models.FloatField(null=True, blank=True, verbose_name='単価') 8 amount = models.IntegerField(null=True, blank=True, verbose_name='金額') 9 10 def __str__(self): 11 return self.name
- 下記のCreateDetailViewで、Django Funky Sheetsを動かしています。
python
1# views.py 2from .models import Detail 3from funky_sheets.formsets import HotView 4 5 6class CreateDetailView(HotView): 7 model = Detail 8 template_name = 'sites/detail.html' 9 prefix = 'table' 10 success_url = reverse_lazy('sites:site_list') 11 fields = ( 12 'name', 13 'shape_dimension', 14 'quantity', 15 'unit', 16 'unit_price', 17 'amount', 18 ) 19 hot_settings = { 20 'contextMenu': 'true', 21 'language': 'ja-JP', 22 'licenseKey':'non-commercial-and-evaluation', 23 'autoWrapRow': 'true', 24 'rowHeaders': 'true', 25 'search': 'true', 26 # When value is dictionary don't wrap it in quotes 27 'headerTooltips': { 28 'rows': 'false', 29 'columns': 'true' 30 }, 31 # When value is list don't wrap it in quotes 32 'dropdownMenu': [ 33 'remove_col', 34 '---------', 35 'make_read_only', 36 '---------', 37 'alignment' 38 ] 39 }
- テンプレートは、下記のものです。
html
1{% include hot_template %}
補足情報(FW/ツールのバージョンなど)
- python 3.7
- Django 3.0.5
- django-funky-sheets 0.2.0
何か、お気づきの点がありましたら、何か手がかりをご教示頂ければ大変ありがたいです。
よろしくお願い致します。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。