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

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

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

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

Python 3.x

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

SQLAlchemy

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

ユニットテスト

ユニットテストは、システムのテスト手法の一つで、個々のモジュールを対象としたテストの事を指します。対象のモジュールが要求や性能を満たしているか確認する為に実行します。

Q&A

0回答

1865閲覧

KeyError: 'formatters'がででmigrationを実行できない。

sequelanonymous

総合スコア123

Flask

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

Python 3.x

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

SQLAlchemy

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

ユニットテスト

ユニットテストは、システムのテスト手法の一つで、個々のモジュールを対象としたテストの事を指します。対象のモジュールが要求や性能を満たしているか確認する為に実行します。

0グッド

0クリップ

投稿2018/08/06 03:49

編集2022/01/12 10:55

flask db init を実行したときに自動生成されるmigrationディレクトリのenv.pyにて fileConfig(config.config_file_name)という記載があります。その処理が原因でエラーがでます。
configにアクセスするために必要なコードだとおもっているのですが、自信がないです。

migrationファイルがある状態でbash-3.2$ flask db migrateを実行しても下記のようなエラーがでてしまう。
いくつか、webの情報を探ってみたが解決に至りません。ご教示頂けませんでしょうか?

ディレクトリの問題かなと思いましたが、色々試したところそうでもなさそうです。
下記コードの fileConfig(config.config_file_name)をコメントアウトすると上手く実行できますが、必要なコードだと思うので他の方法を探しています。

下記、関係ありそうなURL
https://flask-migrate.readthedocs.io/en/latest/
https://stackoverflow.com/questions/42427487/using-alembic-config-main-redirects-log-output
https://stackoverflow.com/questions/23161745/python-logging-file-config-keyerror-formatters
https://teratail.com/questions/126050

該当箇所のコード(env.py)

from logging.config import fileConfig import logging from c.config import test config = context.config # Interpret the config file for Python logging. # This line sets up loggers basically. fileConfig(config.config_file_name) logger = logging.getLogger('alembic.env')

エラー

File "migrations/env.py", line 13, in <module> fileConfig(config.config_file_name) File "/Users/t/.pyenv/versions/3.6.5/lib/python3.6/logging/config.py", line 76, in fileConfig formatters = _create_formatters(cp) File "/Users/t/.pyenv/versions/3.6.5/lib/python3.6/logging/config.py", line 109, in _create_formatters flist = cp["formatters"]["keys"] File "/Users/t/.pyenv/versions/3.6.5/lib/python3.6/configparser.py", line 959, in __getitem__ raise KeyError(key) KeyError: 'formatters'

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

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

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

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

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

quickquip

2018/08/06 05:03 編集

これはなにをしている(つもりの)ソースですか? パッと見て、全部削除してしまったら? と思いますが(まったく必要そうに見えない。loggerを使ってるなら logger = logging.getLogger('alembic.env') だけあればよさそう)
sequelanonymous

2018/08/06 06:53

確かに、説明が不足しておりました。上記追記しました。> "パッと見て、全部削除してしまったら? と思いますが"についてですが、なぜ、全く必要そうにみえないのか教えて頂けると助かります。
quickquip

2018/08/06 07:03

該当のソースがないですが、loggingは標準のloggingモジュールで、fileConfigがlogging.config.fileConfigクラスに見えるからです。どっちもログの設定なので、動作に影響はないのではと想像しました
quickquip

2018/08/06 07:10

あ、"自動生成されたファイルに書いてあるから無視できない"という質問の趣旨は理解しましたよ。
sequelanonymous

2018/08/06 07:20

ありがとうございます!env.pyファイルでfrom logging.config import fileConfigとimport loggingが記載されています。つまり、fileconfig()関数とlogging.getLogger()関数は同じことをしているからfileconfigの記述はいらないという意味でしょうか?
sequelanonymous

2018/08/06 08:00

すみません、ドキュメントを読んでいますが言っている意味がわかりません。ルートかラストリゾートのログ設定というのは、具体的にどのファイルのことをおっしゃていますか?
sequelanonymous

2018/08/06 08:06 編集

ドキュメントのこの辺のことについて言及していますでしょうか? > ロギングの環境設定¶(原文) プログラマは、ロギングを 3 種類の方法で設定できます: 1) 上述の設定メソッドを呼び出す Python コードを明示的に使って、ロガー、ハンドラ、そしてフォーマッタを生成する。 2) ロギング設定ファイルを作り、それを fileConfig() 関数を使って読み込む。 3) 設定情報の辞書を作り、それを dictConfig() 関数に渡す。
quickquip

2018/08/06 09:08

logging全体の設計がそうなっているという趣旨で"どこ"というポイントは難しいです。多分、読んだだけではわけがわからないと思います。コードと設定を実験しないと挙動を把握するのは大変かと。
sequelanonymous

2018/08/06 09:51

すみません、私が言っているのは、"ルートかラストリゾートのログ設定に従ってログが出力されるからです。" の意味がわからないです。ルートかラストリゾートのログ設定とは、configか何かが私が見ているコードのアプリケーションのどこかにあって記載されているという意味でしょうか?その場合、どういうコードでかかれているような箇所をさしていますか?
quickquip

2018/08/06 10:23 編集

いっさい記載されてないならラストリゾートが使われます。ルートを設定するコードか、設定を読み込むコードがあるならその時のルート設定が使われると期待できます。(たぶん前者になるだろうと思って書いてますが、flaskがどう設定を差し挟むか覚えてないので予防線を張ってます)https://docs.python.jp/3/library/logging.html#logging.lastResort
quickquip

2018/08/06 13:18

ロガー階層のルートという意味です。 https://docs.python.jp/3.6/library/logging.html#logging.getLogger "指定された名前のロガーを返します。名前が None であれば、ロガー階層のルート (root) にあるロガーを返します。" 自動生成されたコードだと最初思ってなかったから書かなかったのですね。すみません。
sequelanonymous

2018/08/07 00:57

結局のところ、 fileConfig(config.config_file_name)がなくてもlogger = logging.getLogger('alembic.env')の記述があり、ルートかラストリゾートのログ設定に従ってログが出力されるため、fileConfig() の記述箇所のコードは不要という意味でしょうか?
quickquip

2018/08/07 01:26

そうです。ですがそれでは解決にならないでしょうから、回答にしてません。自動生成されたコードがエラーになっているのですから、別のところ(コードの書き方かファイルの構成)がおかしいはずなので、そちらを直さないと意味がないでしょう。もともとそういう趣旨が質問に書いてあって、それは追記された情報で理解しました、という状況です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問