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

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

新規登録して質問してみよう
ただいま回答率
87.20%
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による文字列操作をサポートしているため、日本語処理も標準で可能です。

解決済

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

mulberryfields
mulberryfields

総合スコア782

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

1回答

4評価

4クリップ

2136閲覧

投稿2015/12/07 13:57

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

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

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

python

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

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

python

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

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

###ソースコード

python

class Tags(ndb.Model): id = ndb.IntegerProperty(indexed=True) name = ndb.StringProperty(indexed=False) class Questions(ndb.Model): title = ndb.StringProperty(indexed = False) content = ndb.TextProperty(indexed = False) tag = ndb.StringProperty(repeated=True) class MainPage(webapp2.RequestHandler): def get(self): question_query = Questions.query().order(-Questions.date) template_values = { 'questions': questions, } template = JINJA_ENVIRONMENT.get_template('index.html') self.response.write(template.render(template_values))

html

<!--index.html--> {% for question in questions %} {{question.title}}<br> {{question.content}}<br> {% for tag in question.tag %} {{tag}}/ {% endfor %} {% endfor %}

上記により、現状、

タイトル

質問内容

1/2/

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

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

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

言語:Python

Google App Engine利用

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

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

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