[解決済み] ログのsetLevelが無視される
2023-05-22 02:39:50
質問
以下のコードは、ドキュメントからコピーしたものです。私はすべての情報ログを見ることができるはずです。しかし、私はそうしません。setLevelをINFOにしたのに、warn以上しか見ることができません。
なぜこのようなことが起こるのでしょうか?
foo.py
:
import logging
logger = logging.getLogger(__name__)
logger.setLevel(logging.DEBUG)
logger.debug('debug message')
logger.info('info message')
logger.warn('warn message')
logger.error('error message')
logger.critical('critical message')
出力します。
workingDirectory$ python foo.py
warn message
error message
critical message
infoとdebugのメッセージはどこに行ったのでしょうか?
どのように解決するのですか?
行を置き換える
logger.setLevel(logging.DEBUG)
で
logging.basicConfig(level=logging.DEBUG, format='%(message)s')
とすれば、期待通りに動作するはずです。もし、ハンドラを使ってロギングを設定しなかった場合 (あなたの投稿のように、ロガーのレベルだけを設定して、ハンドラをどこにも設定しなかった場合)、内部ハンドラである
"最後の手段"
にメッセージだけを出力するように設定されています (他の書式はありません)。
WARNING
レベルで出力するように設定されています。
関連
-
[解決済み] Python Logging - インポートモジュールからのロギングを無効にする
-
[解決済み] SQLAlchemy: セッションの作成と再利用
-
[解決済み] django.db.migrations.exceptions.InconsistentMigrationHistory
-
[解決済み] dict を txt ファイルに書き、それを読み取る?
-
[解決済み] あるオブジェクトが数であるかどうかを確認する、最もパイソン的な方法は何でしょうか?
-
[解決済み] djangoフレームワークでフォームフィールドから値を取得するには?
-
[解決済み] if 節の終了方法
-
[解決済み] Pythonでファイルの読み込みと上書きをする
-
[解決済み] Pythonでランダムなファイル名を生成する最良の方法
-
[解決済み] Alembicアップグレードスクリプトでインサートやアップデートを実行するにはどうすればよいですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] DataFrameの文字列、dtypeがobjectの場合
-
[解決済み] スペースがないテキストを単語のリストに分割する方法
-
[解決済み] pandasのタイムゾーンに対応したDateTimeIndexを、特定のタイムゾーンに対応したナイーブなタイムスタンプに変換する。
-
[解決済み] オブジェクトのリストに特定の属性値を持つオブジェクトが含まれているかどうかをチェックする
-
[解決済み] サブフォルダからのインポートモジュール
-
[解決済み] subprocess.run()の出力を抑制またはキャプチャするには?
-
[解決済み] Flaskで非同期タスクを作る
-
[解決済み] Pythonでランダムなファイル名を生成する最良の方法
-
[解決済み] djangoのQueryDictをPythonのDictに変更するには?
-
[解決済み] Pythonの辞書にあるスレッドセーフについて