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

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

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

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Python

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

HTML

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

Q&A

0回答

681閲覧

フォームデータをデータベースに保存したい

hirohitohomma

総合スコア0

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Python

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

HTML

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

0グッド

0クリップ

投稿2021/02/03 18:39

前提・実現したいこと

格言データベース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/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

meg_

2021/02/04 00:56

> いろいろググっているのですが、いまいちこれが参考になるという検索結果が出てきません。 ・具体的な検索ワードは何でしょうか? ・゛参考にならない゛というのは、解説記事がひとつも見つからなかったのでしょうか?それとも内容が難しくて理解が出来なかったということでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問