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

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

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

Google App Engineは、Googleの管理するデータセンター上でウェブアプリケーションの開発が可能なクラウドコンピュータ技術です。Java、Python、Go用にSDKが用意されています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Python

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

Q&A

解決済

1回答

1412閲覧

idではなく、名前を表示したい。

退会済みユーザー

退会済みユーザー

総合スコア0

Google App Engine

Google App Engineは、Googleの管理するデータセンター上でウェブアプリケーションの開発が可能なクラウドコンピュータ技術です。Java、Python、Go用にSDKが用意されています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Python

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

5グッド

3クリップ

投稿2015/12/03 15:59

Google App Engineで開発をしています。
言語はPythonで、テンプレートエンジンはjinja2です。
質問サイトを作りたいのですが、teratailと同様、各質問に対してタグがつくようにしたいと考えています。
質問文とタグを一つ選択し投稿すると、質問とタグが紐付いた形でデータベースに登録され、質問一覧に質問の内容とそのタグが表示されるというものです。

下記のとおり、QuestionsとTagsの各モデルを定義しています。

python

1class Questions(ndb.Model): 2content = ndb.TextProperty(indexed = False) 3tag = ndb.IntegerProperty(indexed = False) 4 5class Tags(ndb.Model): 6id = ndb.IntegerProperty(indexed=True) 7name = ndb.StringProperty(indexed=False)

Tagsには、
1:英語、2:フランス語、3:中国語、...といった感じで、idとnameが既に登録されています。

質問の投稿画面は、下記のとおりです。

python

1class MainPage(webapp2.RequestHandler): 2 def get(self): 3 template_values = { 4 'tags': tags, 5 } 6 template = JINJA_ENVIRONMENT.get_template('index.html') 7 self.response.write(template.render(template_values)) 8class Question(webapp2.RequestHandler): 9 def post(self): 10 question = Questions() 11 question.tag = int(self.request.get('tag')) 12 question.content = self.request.get('content') 13 question.put() 14app = webapp2.WSGIApplication([ 15 ('/', MainPage), 16 ('/sign',Question), 17], debug = True)

html

1/*index.html*/ 2<form method="post" action="/sign"> 3 <select name="tag"> 4 {% for tag in tags %} 5 <option value={{tag.id}}>{{tag.name}}</option> 6 {% endfor %} 7 </select> 8 <textarea cols=100% name="content" rows="13" placeholder="9 からないこと、解決したいことの詳細を書いてください"></textarea> 10 <button class"btn btn-default" type="submit">submit</button> 11</form>

タグを一つ選択し、質問文を書いて、submitします。
ここまではうまくいっています(質問データは、登録されています。)。

これを受けて、質問一覧を表示する画面は、下記のとおりに書いています。

python

1class MainPage(webapp2.RequestHandler): 2 def get(self): 3 question_query = Questions.query() 4 questions = question_query.fetch(10) 5 template_values = { 6 'questions': questions, 7 } 8 template = JINJA_ENVIRONMENT.get_template('index.html') 9 self.response.write(template.render(template_values))

html

1/*index.html*/ 2{% for question in questions %} 3 {{question.content}} 4 {{question.tag}} 5{% endfor %}

これにより、質問とタグのidが表示されるところまではいきました。

しかし、タグのidではなく、タグ名を表示するにはどうしたらよいでしょうか?
現在は、例えば、idの「1」が表示されていますが、そうではなく、nameの「英語」が表示されて欲しいということです。
どういう仕組みを使えばこれが可能なのか、思いつきません。

お分かりの方、ご教示頂ければ幸いです。
よろしくお願いいたします。

yterpu, TmNm_Bigger, av-, laa👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

分かりづらい質問だったと思いますので、改めて質問を書き直して投稿させていただきました。

idではなく、名前を表示したい。

投稿2015/12/07 14:00

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問