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

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

新規登録して質問してみよう
ただいま回答率
85.37%
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回答

2575閲覧

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による文字列操作をサポートしているため、日本語処理も標準で可能です。

4グッド

4クリップ

投稿2015/12/07 13:57

以前、同内容を質問させていただいたのですが、少しでもわかりやすいように、改めて書き直して質問させていただきます。

###前提・実現したいこと
Google App Engine(Python)で、質問投稿サイトを作成しています。
ユーザーには、質問投稿時にフォーム上のcheckboxで複数のタグを選んでもらいます。選んでもらったタグをデータベースに登録したいです。 (teratailのタグのようなものです。)

###発生している問題・エラーメッセージ
タグを扱うTagsモデルは、下記のように、idとタグ名から成っています。

python

1class Tags(ndb.Model): 2 id = ndb.IntegerProperty(indexed=True) 3 name = ndb.StringProperty(indexed=False)

質問自体を扱うQuestionsモデルは、下記のように、タイトル、質問内容、タグ「id」から成っています。タグ「id」は、複数選択できるようになっています。

python

1class Questions(ndb.Model): 2 title = ndb.StringProperty(indexed = False) 3 content = ndb.TextProperty(indexed = False) 4 tag = ndb.StringProperty(repeated=True)

質問一覧を表示するページに、タイトル、質問内容、タグ「名」を表示したいです。
現状では、タグの「id」が表示されているのですが、TagsモデルとQuestionsモデルを紐付ける方法が分かりません。

###ソースコード

python

1class Tags(ndb.Model): 2 id = ndb.IntegerProperty(indexed=True) 3 name = ndb.StringProperty(indexed=False) 4 5class Questions(ndb.Model): 6 title = ndb.StringProperty(indexed = False) 7 content = ndb.TextProperty(indexed = False) 8 tag = ndb.StringProperty(repeated=True) 9 10class MainPage(webapp2.RequestHandler): 11 def get(self): 12 question_query = Questions.query().order(-Questions.date) 13 template_values = { 14 'questions': questions, 15 } 16 template = JINJA_ENVIRONMENT.get_template('index.html') 17 self.response.write(template.render(template_values))

html

1<!--index.html--> 2{% for question in questions %} 3{{question.title}}<br> 4{{question.content}}<br> 5{% for tag in question.tag %} 6 {{tag}}/ 7{% endfor %} 8{% endfor %}

上記により、現状、

タイトル

質問内容

1/2/

という形で表示されるようになっています。
この1や2という形でタグのidが表示されているのを、タグの名前にしたいというのが希望です。

###補足情報(言語/FW/ツール等のバージョンなど)
Webフレームワーク:webapp2

テンプレートエンジン:Jinja2

言語:Python

Google App Engine利用

おそらく、私の基本的な部分の理解が不足しているのだと思いますが、お分かりの方みえましたら、よろしくお願いいたします。

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

このサイトに詳しく載っていますよ。

MemberDataをQuestions、
MessageDataをTagsに読み替えれば問題ないかと。

投稿2015/12/08 00:31

moredeep

総合スコア1507

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

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

Lhankor_Mhy

2015/12/08 02:31

この回答のサイトは内容が古い(たとえば、`db.ReferenceProperty`は動くけど`ndb.ReferenceProperty`にすると動作しないはず)ので、そのままコピペしてもたぶん動きませんのでご注意ください。>質問者
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問