ロギング、StreamHandler、標準ストリーム
2023-10-27 21:30:48
質問
情報レベルのメッセージを標準出力に、それ以外を標準エラー出力に記録する方法がわかりません。私はすでにこれを読んだ http://docs.python.org/library/logging.html . 何か提案はありますか?
どのように解決するのですか?
次のようなスクリプトです。
log1.py
:
import logging, sys
class SingleLevelFilter(logging.Filter):
def __init__(self, passlevel, reject):
self.passlevel = passlevel
self.reject = reject
def filter(self, record):
if self.reject:
return (record.levelno != self.passlevel)
else:
return (record.levelno == self.passlevel)
h1 = logging.StreamHandler(sys.stdout)
f1 = SingleLevelFilter(logging.INFO, False)
h1.addFilter(f1)
rootLogger = logging.getLogger()
rootLogger.addHandler(h1)
h2 = logging.StreamHandler(sys.stderr)
f2 = SingleLevelFilter(logging.INFO, True)
h2.addFilter(f2)
rootLogger.addHandler(h2)
logger = logging.getLogger("my.logger")
logger.setLevel(logging.DEBUG)
logger.debug("A DEBUG message")
logger.info("An INFO message")
logger.warning("A WARNING message")
logger.error("An ERROR message")
logger.critical("A CRITICAL message")
を実行すると、次のような結果が得られます。
C:\temp>log1.py DEBUGメッセージ INFOメッセージ 警告メッセージ ERRORメッセージ CRITICALメッセージ
期待通り、ターミナルでは
sys.stdout
と
sys.stderr
は同じです。では、stdoutをファイルにリダイレクトしてみましょう。
tmp
:
C:\temp>log1.py >tmp DEBUGメッセージ 警告メッセージ ERRORメッセージ CRITICALメッセージ
つまり、INFOメッセージは端末に出力されませんが、端末の
sys.stderr
には
が印刷されています。の中身を見てみましょう。
tmp
:
C:\temp>type tmp INFOメッセージ
というわけで、この方法で望みのものができるようです。
関連
-
[解決済み] 関数デコレータを作成し、それらを連鎖させるには?
-
[解決済み] staticmethodとclassmethodの違いについて
-
[解決済み] Pythonのリストメソッドであるappendとextendの違いは何ですか?
-
[解決済み] 最小限の驚き」と「変更可能なデフォルトの引数
-
[解決済み] 億の相対的輸入
-
[解決済み] collections.defaultdictはどのように機能するのですか?
-
[解決済み] pandasのデータフレームのインデックスをカラムに変換する方法
-
[解決済み】__str__と__repr__の違いは何ですか?
-
[解決済み] Pandasのデータフレームでタプルの列を分割するにはどうしたらいいですか?
-
[解決済み] 文字列のリストを内容に基づいてフィルタリングする
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] pandasのDataFrameから空のセルを含む行を削除する
-
[解決済み] Flaskで1時間ごとに関数を実行するようにスケジュールするには?
-
[解決済み] django.db.migrations.exceptions.InconsistentMigrationHistory
-
[解決済み] Pandasの'Freq'タグにはどのような値が有効ですか?
-
[解決済み] Pythonのargparseを使った隠し引数の作成
-
[解決済み] 値で列挙名を取得する [重複]。
-
[解決済み] サブフォルダからのインポートモジュール
-
[解決済み] Cythonのコードを含むPythonパッケージはどのように構成すればよいのでしょうか?
-
[解決済み] Flask でグローバル変数はスレッドセーフか?リクエスト間でデータを共有するには?
-
[解決済み] Python Empty Generator 関数