前提・実現したいこと
Python FlaskにてWEBサイトを作成中です。
ラジオボタンを使い、DBから得られるデータの抽出方法を変えています。
抽出後、ラジオボタンは選択した場所ではなく初期値に戻ってしまう為
これを防ぎたい。
(どのような条件で抽出したか確認し辛くなってしまう)
発生している問題・エラーメッセージ
下記のソースコードのようにラジオボタンは「code」「info」の2つがあります。
productテーブルからcode列を表示させるかinfo列を表示させるかを選択しています。
infoを選択し、実行するとinfo列の値が表示されます。
しかし、ラジオボタンはcodeを選択した状態になってしまいます。
該当のソースコード
app.pyとsearch.htmlで構成されています。
---------------------<app.py>----------------------------------
from flask import Flask, render_template, request
import mysql.connector as mydb
app = Flask(name, template_folder='./templates')
@app.route('/search', methods=['GET', 'POST'])
def kensaku():
radio1 = request.values.get('radio1')
print(radio1)
data = []
if request.method == 'POST':
conn = conn_db()
cur = conn.cursor()
sql = f"select {radio1} from product"
print(sql)
cur.execute(sql)
data = cur.fetchall()
return render_template('search.html', radio1=radio1, data=data)
def conn_db():
conn = mydb.connect(
host = '172.29.126.88',
user = 'user',
password = 'password',
port = '3306',
database = 'db'
)
return conn
if name == 'main':
app.run(debug=True)
---------------------<search.html>----------------------------------
<!doctype html> <html> <head></head> <body> <form action="/search" method="post"> <input type="radio" name="radio1" value="code" checked>code <input type="radio" name="radio1" value="info">info <input type="submit" value="実行"> </form> <ul> {% for row in data %} <li><input type="radio" name="code" value="{{ row[0] }}">{{ row[0] }}</li> {% endfor %} </ul> </body> </html>試したこと
テキストボックスであれば値をそのままHTMLへ返し表示させればよいのですが
ラジオボタンはそのようにはいかず、inputタグの中にif文を書いてみましたが
機能しませんでした。
補足情報
Pythonのバージョンは3.9.5
OSはWindows
ブラウザはChrome
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。