[解決済み] Python Logging - インポートモジュールからのロギングを無効にする
質問
Pythonのloggingモジュールを使っていますが、インポートしたサードパーティーモジュールが出力するログメッセージを無効にしたいのですが、どうすればいいですか? 例えば、以下のようなものを使っています。
logger = logging.getLogger()
logger.setLevel(level=logging.DEBUG)
fh = logging.StreamHandler()
fh_formatter = logging.Formatter('%(asctime)s %(levelname)s %(lineno)d:%(filename)s(%(process)d) - %(message)s')
fh.setFormatter(fh_formatter)
logger.addHandler(fh)
これは logger.debug("my message!") を実行したときに私のデバッグメッセージを出力しますが、私がインポートしたすべてのモジュール (リクエストや他の多くのもの) からのデバッグメッセージも出力します。
興味のあるモジュールのログメッセージだけを見たいのですが。 loggingモジュールにこれをさせることは可能でしょうか?
理想的には、"ModuleX, ModuleY" からのメッセージを表示し、その他は無視するようにロガーに指示できるようにしたいのですが、可能ですか?
下記を見ましたが、インポートされた関数を呼び出す前に毎回ロギングを無効化/有効化する必要があるのは困ります。 logging - インポートモジュールのログを無視する方法は?
解決方法は?
問題は
getLogger
を引数なしで返します。
ルート
ロガーに設定されます。
logging.DEBUG
は、そのロガーを使用する他のモジュールのレベルも設定することになります。
これを解決するには、単純に ない はルートロガーを使用しています。これを行うには、単に引数として名前を渡します。例えば、モジュールの名前などです。
logger = logging.getLogger('my_module_name')
# as before
これは新しいロガーを作成するので、他のモジュールのロギングレベルを不注意に変更することはありません。
当然ながら
logger.debug
の代わりに
logging.debug
を呼び出す便利な関数なので、後者は
debug
メソッドを使用します。
に記載されています。 ロギング上級者向けチュートリアル . また、どのモジュールがログメッセージをトリガーしたかを簡単に知ることができます。
関連
-
python string splicing.join()とsplitting.split()の説明
-
[解決済み] ファイルにログを記録し、標準出力に印刷するためのロガー設定
-
[解決済み] Pythonには文字列の'contains'サブストリングメソッドがありますか?
-
[解決済み] Pythonで現在時刻を取得する方法
-
[解決済み] Pythonで2つのリストを連結する方法は?
-
[解決済み] ファイルのコピー方法について教えてください。
-
[解決済み] Pythonで例外を手動で発生(スロー)させる
-
[解決済み] Pythonの辞書からキーを削除するにはどうしたらいいですか?
-
[解決済み】ネストされたディレクトリを安全に作成するには?
-
[解決済み】Pythonに三項条件演算子はありますか?
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
Pythonの学習とデータマイニングのために知っておくべきターミナルコマンドのトップ10
-
pyCaret効率化乗算器 オープンソース ローコード Python機械学習ツール
-
[解決済み】「RuntimeError: dictionary changed size during iteration」エラーを回避する方法とは?
-
[解決済み】socket.error: [Errno 48] アドレスはすでに使用中です。
-
[解決済み】"No JSON object could be decoded "よりも良いエラーメッセージを表示する。
-
[解決済み] 'int'オブジェクトに'__getitem__'属性がない。
-
[解決済み】ImportError: bs4という名前のモジュールがない(BeautifulSoup)
-
[解決済み】cアンダースコア式`c_`は、具体的に何をするのですか?
-
[解決済み】django インポートエラー - core.managementという名前のモジュールがない
-
[解決済み] Requestsライブラリからのログメッセージを無効にするにはどうすればよいですか?