前提・実現したいこと
格言データベースWEBアプリケーションを作ってみようと思っています。
HTMLファイルでフォームデータ入力ページまでは作っているので、
次にそのデータをデータベースに保存するようにしたいと思っています。
いろいろググっているのですが、いまいちこれが参考になるという検索結果が出てきません。
pythonでsqlite3を使ってやってみようと思っています。
参考になるHPを知っている方教えていただけないでしょうか。
発生している問題・エラーメッセージ
エラーメッセージ
該当のソースコード
Python
1print("Content-type: text/html; charset=utf-8") 2 3print( 4 5""" 6<!DOCTYPE html> 7<html lang="ja"> 8 <head> 9 <meta charset="utf-8"> 10 <meta name="viewport" content="width=device-width, initial-scale=1.0"> 11 <meta name="description" content="・・・"> 12 <meta name="format-detection" content="telephone=no,address=no,email=no"> 13 <meta http-equiv="X-UA-Compatible" content="IE=edge"> 14 <meta name="robots" content="noindex,nofollow"><!--検索されたくない--> 15 <title>格言--Maxim--</title> 16 <link rel="shortcut icon" href="・・・" > 17 <link rel="stylesheet" href="styles.css"> 18 </head> 19 <body> 20 <header> 21 22 </header> 23 <main> 24 <div class="title"> 25 <h1>格言--Maxim--</h1> 26 </div> 27 28 <div class="container"> 29 <div class="box input"> 30 <h2>入力フィールド</h2> 31 <form name="form" method="post" action="confirm.py"> 32 <div class="contributor"> 33 <label for="contributor">投稿者:</label> 34 <select type="text" id="contributor" name="contributor" required> 35 <option value="0">ジロウさん</option> 36 <option value="1">さおちゃん</option> 37 <option value="2">あいこちゃん</option> 38 <option value="3">さえちゃん</option> 39 <option value="4">サァシャさん</option> 40 <option value="5">ヨシノさん</option> 41 <option value="6">リベラさん</option> 42 <option value="7">しーちゃん</option> 43 <option value="8">Mちゃん</option> 44 <option value="9">くぅちゃん</option> 45 <option value="10">りくなさん</option> 46 <option value="11">カメさん</option> 47 <option value="12">マキさん</option> 48 <option value="13">フナちゃん</option> 49 <option value="14">ブラべさん</option> 50 <option value="15">ピンキーさん</option> 51 <option value="16">あけみんさん</option> 52 <option value="17">キムラさん</option> 53 </select> 54 </div> 55 <div class="person_name"> 56 <label for="person_name">人物名:</label> 57 <input type="text" id="person_name" name="personName" required> 58 </div> 59 <div class="maxim"> 60 <label for="maxim">格 言:</label> 61 <textarea type="text" id="maxim" name="maxim" required></textarea> 62 </div> 63 <div class="meaning"> 64 <label for="meaning">意 味:</label> 65 <textarea type="text" id="meaning" name="meaning" required></textarea> 66 </div> 67 <div class="importance"> 68 <label for="importance">重要度:</label> 69 <select type="text" id="importance" name="importance" required> 70 <option value="0">0</option> 71 <option value="1">1</option> 72 <option value="2">2</option> 73 <option value="3">3</option> 74 <option value="4">4</option> 75 <option value="5">5</option> 76 <option value="6">6</option> 77 <option value="7">7</option> 78 <option value="8">8</option> 79 <option value="9">9</option> 80 <option value="10">10</option> 81 </select> 82 </div> 83 <div class="submit_reset"> 84 <p> 85 <input type="submit" value="送信"><input type="reset" value="リセット"> 86 </p> 87 </div> 88 </form> 89 90 91 </div> 92 93 94 <div class="box output"> 95 <h2>出力フィールド</h2> 96 <h3>投稿者:<output name="contributor">格言 太郎</output></h3> 97 <h3>人物名:<output name="person_name">渋沢 栄一</output></h3> 98 <h3>格言:<output name="maxim">もうこれで満足だという時は、すなわち衰える時である</output></h3> 99 <h3>意味:<output name="meaning">チャレンジをし続けて変化・進化を求め続けなければなりません。</output></h3> 100 <h3>重要度:<output name="importance">10</output></h3> 101 102 </div> 103 104 105 <div class="box random"> 106 <h2>ランダム出力フィールド</h2> 107 <h3>投稿者:<output name="contributor">格言 太郎</output></h3> 108 <h3>人物名:<output name="person_name">渋沢 栄一</output></h3> 109 <h3>格言:<output name="maxim">もうこれで満足だという時は、すなわち衰える時である</output></h3> 110 <h3>意味:<output name="meaning">チャレンジをし続けて変化・進化を求め続けなければなりません。</output></h3> 111 <h3>重要度:<output name="importance">10</output></h3> 112 </div> 113 </div> 114 115 </main> 116 <footer> 117 118 </footer> 119 </body> 120</html> 121 122""" 123 124) 125 126 127#!/usr/bin/env python3 128# -*- coding: utf-8 -*- 129 130 131import sys 132import io 133import sqlite3 134import cgi 135 136# windoesにおける文字化け回避 137sys.stdout = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8') 138 139#データベースに接続する 140conn = sqlite3.connect('maxim.db') 141c = conn.cursor() 142 143# テーブルの作成 144c.execute('CREATE TABLE IF NOT EXISTS maxims (id integer PRIMARY KEY, contributor text, personName text, maxim text, meaning text, importance integer);') 145
試したこと
この先が知りたいのです。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
あなたの回答
tips
プレビュー