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

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

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

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

Python 3.x

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

Q&A

1回答

6700閲覧

DjangoでCSVを読み込んでテーブルに表示する

mila_411

総合スコア10

Django

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

Python 3.x

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

0グッド

0クリップ

投稿2019/02/26 06:59

編集2019/02/26 07:04

実現したいこと

formでユーザーが選択したCSVファイルを読み込んで、Modelには登録せずに
同一ページ内にあるテーブルで表示したい

ソースコード

python

1# urls.py 2path('import/', views.imports.as_view(), name='import'),

python

1# forms.py 2class CSVUploadForm(forms.Form): 3 file = forms.FileField( 4 label='CSVファイル', 5 help_text='※拡張子csvのファイルをアップロードしてください。' 6 ) 7 8 def clean_file(self): 9 file = self.cleaned_data['file'] 10 if not file.name.endswith('.csv'): 11 raise forms.ValidationError( 12 '拡張子がcsvのファイルをアップロードしてください' 13 ) 14 csv_file = io.TextIOWrapper(file, encoding='utf-8') 15 reader = csv.reader(csv_file) 16 17 self.instances = [] 18 try: 19 for row in reader: 20 csvdata = { 21 "id":row[0], 22 "name":row[1], 23 "type":row[2] 24 } 25 self.instances.append(csvdate) 26 27 return file 28 29 def self.instancesをテンプレートへ渡す関数?? 30

python

1# views.py 2class imports(generic.FormView): 3 template_name = 'app/import.html' 4 success_url = reverse_lazy('app:import') 5 form_class = CSVUploadForm 6 7

html

1{% block content %} 2<p> 3<form action="" method="POST" enctype="multipart/form-data"> 4 {{ form.as_ul }} 5 {% csrf_token %} 6 <button type="submit">内容確認</button> 7</form> 8</p> 9<hr> 10 11<table class="table"> 12 <thead> 13 <tr> 14 <th>ID</th> 15 <th>名前</th> 16 <th>種別</th> 17 </tr> 18 </thead> 19 <tbody> 20 {% for i in instance %} 21 <tr> 22 <td>{{i.id}}</td> 23 <td>{{i.name}}</td> 24 <td>{{i.type}}</td> 25 </tr> 26 {% endfor %} 27 28 </tbody> 29</table> 30 31{% endblock %} 32

 

Django、CSVのインポート・エクスポート

こちらのサイトを参考にしています。
Modelへ登録をする前に一度CSVの内容をテーブルに表示して中身を確認したいのです。
forms.pyの「def self.instancesをテンプレートへ渡す関数??」の部分に関数を作ればいいのかなと
思ったのですが、今までC#でのスタンドアロンなアプリしか作ったことだなくWEBの知識が未熟で
どう引き渡せばいいのかがわかりません。

どんな風にテンプレートへ渡せば良いのか教えていただきたいです。
よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ソースコード読んでませんが、viewsの中で二次元配列作って渡すのはどうですか?

Python

1x=[ 2[1,2], 3[3,4], 4]

あとは、templateの中でforで回す

投稿2019/02/26 07:24

yamato_user

総合スコア2321

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

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

mila_411

2019/02/26 07:51

回答ありがとうございます! views(もしくはforms)からテンプレートに渡す方法がよくわかっていません。。。 def list(request): のように引数にrequestが来ている場合はreturn renderで配列を渡すことができたのですがソースコードのようなrequest以外の引数の時はどうすればテンプレートへ渡すことができますか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問