🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
terminal

Terminalは、Apple社のmacOSに標準で付属しているUNIX端末エミュレータ。UNIXコマンドによってMacの操作および設定を行うことができます。

Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

SQLAlchemy

SQLAlchemyとはPython 用のORMライブラリです。MIT Licenceのオープンソースとして提供されています。

Python

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

Q&A

解決済

1回答

2637閲覧

SQLAlchemyとFlaskを使って文字列を表示させる際にエラーが出て表示できない

退会済みユーザー

退会済みユーザー

総合スコア0

terminal

Terminalは、Apple社のmacOSに標準で付属しているUNIX端末エミュレータ。UNIXコマンドによってMacの操作および設定を行うことができます。

Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

SQLAlchemy

SQLAlchemyとはPython 用のORMライブラリです。MIT Licenceのオープンソースとして提供されています。

Python

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

0グッド

0クリップ

投稿2019/10/15 12:53

前提・実現したいこと

Flaskで「Hello World!」の代わりに、World!の部分をSQLAlchemyで指定した名前にしてブラウザで表示させようとしています。

今回の場合

Hello Jack

となれば正解です。

発生している問題・エラーメッセージ

実行後すぐにはエラーメッセージが出ないのですが、ブラウザでインターナルサーバエラーが表示されてしまうのと、index() missing 1 required positional argument: 'Person'が理解できずどのように修正すれば良いかわかりません。

ブラウザ上

Internal Server Error The server encountered an internal error and was unable to complete your request. Either the server is overloaded or there is an error in the application.

ターミナル上

* Serving Flask app "app.py" * Environment: production WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead. * Debug mode: off /Users/username/.pyenv/versions/3.6.0/lib/python3.6/site-packages/flask_sqlalchemy/__init__.py:814: UserWarning: Neither SQLALCHEMY_DATABASE_URI nor SQLALCHEMY_BINDS is set. Defaulting SQLALCHEMY_DATABASE_URI to "sqlite:///:memory:". 'Neither SQLALCHEMY_DATABASE_URI nor SQLALCHEMY_BINDS is set. ' /Users/username/.pyenv/versions/3.6.0/lib/python3.6/site-packages/flask_sqlalchemy/__init__.py:835: FSADeprecationWarning: SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and will be disabled by default in the future. Set it to True or False to suppress this warning. 'SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and ' * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit) ---ブラウザでアクセス後--- TypeError: index() missing 1 required positional argument: 'Person'

該当のソースコード

実行コマンド

bash

1$ FLASK_APP=app.py flask run

app.py

python

1from flask import Flask 2from flask_sqlalchemy import SQLAlchemy 3 4app = Flask(__name__) 5db = SQLAlchemy(app) 6class Person: 7 def __init__(self, name): 8 self.name = name 9 10name = Person(name='Jack') 11 12 13@app.route('/') 14def index(self.name): 15 return 'Hello' + Person.name

試したこと

「Hellow World!」は以下のコードで問題なくできました。

python

1from flask import Flask 2 3app = Flask(__name__) 4 5@app.route('/') 6def index(): 7 return 'Hello World!'

補足情報(FW/ツールのバージョンなど)

Flask 1.1.1
sqlalchemy 1.3.10

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

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

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

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

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

guest

回答1

0

ベストアンサー

以下のような具合です。
SQLAlchemy 関係ないコードになってしまいましたが...

python

1from flask import Flask 2from flask_sqlalchemy import SQLAlchemy 3 4app = Flask(__name__) 5db = SQLAlchemy(app) 6 7class Person: 8 def __init__(self, name): 9 self.name = name 10 11# name = Person(name='Jack') 12person = Person(name='Jack') 13 14# @app.route('/') 15# def index(self.name): 16# return 'Hello' + Person.name 17@app.route('/') 18def index(): 19 return 'Hello' + person.name

Python のクラス, Flask, SQLAlchemy の3つの理解が、
すこしごっちゃになっている印象があります。

クラスはここを

Flask と SQLAlchemy は、有料になってしまいますが、ここを

個人的にオススメしたいです。

投稿2019/10/15 17:28

nico25

総合スコア830

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問