🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

Python

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

1回答

2240閲覧

HTMLの複数のinputに入力された値をpython側のリストに渡す

utiii

総合スコア0

Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

Python

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2021/09/17 05:56

編集2021/09/17 08:53

イメージ説明
イメージ説明
このように個数nに応じてinput欄を可変にして,そのinputに入力された値をpythonに渡してリストを作りたいです.フレームワークはflaskを使っています。
HTML内でforを使ってinput欄を可変にしているのですが,そのnameに変数iを加えたものを入れたいです.   
(ex:element_i)

こうすることによってinputの呼び出し毎にnameやlabelを変更したいのですが方法はありますか?
できればPHPなどを使いたくはないのですが

html

1{% extends 'base.html' %} 2 3{% block body %} 4<h1 class="text-center">Least Squares</h1> 5<section class="calc_xy"> 6 <form action="/calc" method="POST"> 7 <div class="container d-flex text-center justify-content-center"> 8 <div class="calc_x"> 9 {% for i in range(element) %} 10 <label for="elements">xの{{ i + 1 }}番目の要素の値</label> 11 <p><input type="text" name="elements" class="text-center calcs"></p> 12 {% endfor %} 13 </div> 14 <div class="calc_y"> 15 {% for i in range(element) %} 16 <label for="elements">yの{{ i + 1 }}番目の要素の値</label> 17 <p><input type="text" name="elements" class="text-center calcs"></p> 18 {% endfor %} 19 </div> 20 </div> 21 <p class="text-center"><input type="submit" value="計算"></p> 22 </form> 23</section> 24{% endblock %}

python

1from flask import Flask, render_template, request, redirect, url_for 2from flask_sqlalchemy import SQLAlchemy 3 4 5app = Flask(__name__) 6app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///todo.db' 7db = SQLAlchemy(app) 8 9class Post(db.Model): 10 id = db.Column(db.Integer, primary_key=True) 11 element = db.Column(db.String(30), nullable=False) 12 13class F: 14 def __init__(self): 15 self.x = 0 16 def __call__(self): 17 self.x += 1 18 return self.x 19 20 21@app.route('/', methods=['GET', 'POST']) 22def index(): 23 if request.method =='GET': 24 posts = Post.element 25 return render_template('index.html', posts=posts) 26 27 else: 28 element = int(request.form.get('element')) 29 30 new_post = Post(element=element) 31 32 print(str(element)) 33 db.session.add(new_post) 34 db.session.commit() 35 36 return render_template('calc.html', element=element) 37 38@app.route('/calc', methods=['GET', 'POST']) 39def calc(): 40 if request.method == 'GET': 41 print('a') 42 return redirect('/calc') 43 44 else: 45 data =[] 46 f = F() 47 count = f() 48 print(count) 49 elements = request.form.get('elements') 50 51 print(elements) 52 result = elements#テスト 53 return render_template('result.html', result=result, count=count)

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

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

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

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

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

Lhankor_Mhy

2021/09/17 06:04

普通に name="elements_{{i+1}}" とすればよさそうな気がするのですが、すでにお試しになりましたか?
utiii

2021/09/17 06:45

python側では"elments_{{i+1}}"をどのように記述すればよいでしょうか?
Lhankor_Mhy

2021/09/17 06:46

いえ、HTML(テンプレート)です。
utiii

2021/09/17 06:52

HTMLではそのように記述したときにpython側では for i in range(element): data.append(request.form.get('elements_i')) という感じで書きたいのですが,pythonでは'elements_i'をどのように記述すればよいでしょうか?
Lhankor_Mhy

2021/09/17 07:00

request.form.items などで処理をしてはどうでしょうか?
quickquip

2021/09/17 08:09

質問文に書いてあることとこの欄のやりとりが食い違っているので戸惑っています。 質問を読んで Lhankor_Mhy さんと同じことを思いましたが、質問したいことはどうも別のようです。
utiii

2021/09/17 08:13

調べたのですがrequest.form.itemsの使い方がわかりませんでした。data.append(request.form.items())の引数には何を入れればいいのでしょうか?
utiii

2021/09/17 08:22

quickquipさん 私の質問が戸惑いを生む表現で、的確でないことにお詫び申し上げます。 やりたいことはHTMLのinputに入力された値をpython側のリストに渡すということです。 その上でinputのnameに変数を付け加えることによってinputを区別すればいいのではないかと思い質問しました。inputのnameに変数を付け加える方法は分かりましたが、新たにそれらをpython側でどのように受け取ればいいかという疑問が出てきたためにこのようなやりとりをさせていただいております。
Lhankor_Mhy

2021/09/17 08:30 編集

request.form.items() には引数は必要ないです。 リクエストパラメータのキーとバリューの配列になります(と記憶しています)。 値をログってみてはどうですか?
quickquip

2021/09/17 08:40 編集

ここは 質問への追記・修正の依頼 欄ですよ。(コメントだと思われた?) 質問を編集してください。
Lhankor_Mhy

2021/09/17 08:43

よく読むと、同じnameが存在する場合には、True を引数に持たせる必要があるようです。 たびたびすみませんでした。
utiii

2021/09/17 09:07

python側で for item in request.form.items(True): print(item) によって(name, value)の形で取り出すことができました. Lhankor_Mhyさん本当にありがとうございました!
utiii

2021/09/17 09:07

quickquipさん 修正いたしました
Lhankor_Mhy

2021/09/17 09:22

ご解決されて何よりです。 お手数ですが、自己解決の処理をお願いいたします。
guest

回答1

0

自己解決

html

1{% extends 'base.html' %} 2 3{% block body %} 4<h1 class="text-center">Least Squares</h1> 5<section class="calc_xy"> 6 <form action="/calc" method="POST"> 7 <div class="container d-flex text-center justify-content-center"> 8 <div class="calc_x"> 9 {% for i in range(element) %} 10 <label for="elements_{{i+1}}">xの{{ i + 1 }}番目の要素の値</label> 11 <p><input type="text" name="elements_{{i+1}}" class="text-center calcs"></p> 12 {% endfor %} 13 </div> 14 <div class="calc_y"> 15 {% for i in range(element) %} 16 <label for="elements_{{i+1}}">yの{{ i + 1 }}番目の要素の値</label> 17 <p><input type="text" name="elements_{{i+1}}" class="text-center calcs"></p> 18 {% endfor %} 19 </div> 20 </div> 21 <p class="text-center"><input type="submit" value="計算"></p> 22 </form> 23</section> 24{% endblock %}

python

1from flask import Flask, render_template, request, redirect, url_for 2from flask_sqlalchemy import SQLAlchemy 3 4 5app = Flask(__name__) 6app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///todo.db' 7db = SQLAlchemy(app) 8 9class Post(db.Model): 10 id = db.Column(db.Integer, primary_key=True) 11 element = db.Column(db.String(30), nullable=False) 12 13 14@app.route('/', methods=['GET', 'POST']) 15def index(): 16 if request.method =='GET': 17 posts = Post.element 18 return render_template('index.html', posts=posts) 19 20 else: 21 element = int(request.form.get('element')) 22 23 new_post = Post(element=element) 24 25 print(str(element)) 26 db.session.add(new_post) 27 db.session.commit() 28 29 return render_template('calc.html', element=element) 30 31@app.route('/calc', methods=['GET', 'POST']) 32def calc(): 33 if request.method == 'GET': 34 print('a') 35 return redirect('/calc') 36 37 else: 38 data = request.form.items(True) 39 40 data_x = [] 41 data_y = [] 42 i = 0 43 for item in data: 44 if i % 2 == 0: 45 data_x.append(int(item[1])) 46 else: 47 data_y.append(int(item[1])) 48 i += 1 49 50 result = data#テスト 51 return render_template('result.html', result=result)

HTMLのnameを都度変更するのではなくてrequest.form.itemsを用いることによってforで呼び出したinputの値をpython側に渡すことができました。

投稿2021/09/17 10:00

utiii

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問