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

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

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

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

Q&A

1回答

5301閲覧

python loggerのStreamHandlerで標準出力のフォーマット変更

noz_awsinf_sp

総合スコア62

Python

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

0グッド

1クリップ

投稿2020/09/03 11:16

以下のように[logger.py]でロギング設定をしているのですが
handler2のようにfileとstream両方出力する場合に
FileHandlerとStreamHandlerでFormatterを分けることは可能でしょうか?

python:logger.py

1 2# -*- coding: utf-8 -*- 3import logging 4import os 5import datetime 6 7 8logger = logging.getLogger("logger") #logger名loggerを取得 9logger.setLevel(logging.DEBUG) #loggerとしてはDEBUGで 10 11#handler1を作成 12handler1 = logging.FileHandler(filename="test.log") 13 14handler1.setFormatter(logging.Formatter("%(asctime)s %(levelname)8s %(message)s")) 15 16#handler2を作成 17handler2 = logging.FileHandler(filename="test.log") #handler2はファイル出力 18handler2 = logging.StreamHandler() 19handler2.setLevel(logging.WARN) #handler2はLevel.WARN以上 20handler2.setFormatter(logging.Formatter("%(asctime)s %(levelname)8s %(message)s")) 21 22#loggerに2つのハンドラを設定 23logger.addHandler(handler1) 24logger.addHandler(handler2) 25 26#出力処理 27logger.debug("debug message") 28logger.info("info message") 29logger.warn("warn message") 30logger.error("error message") 31

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

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

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

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

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

guest

回答1

0

fileとstream両方出力する場合にFileHandlerとStreamHandlerでFormatterを分けることは可能でしょうか?

示して頂いたソースコードで実は完成しています。問題がある部分は以下の部分です。

python

1handler2 = logging.FileHandler(filename="test.log") #handler2はファイル出力 2handler2 = logging.StreamHandler()

handler2は1行目でFileHandler()が設定されていますが、2行目のStreamHandler()で上書きされていますので、1行目は使われていません。そのためhandler2はファイル出力をしていません。

ログのフォーマッタにhandler1, handler2と入れるとその動作が分かると思います(ほとんど変えていません)。

python

1import logging 2import os 3import datetime 4 5 6logger = logging.getLogger("logger") 7logger.setLevel(logging.DEBUG) 8 9#handler1を作成 10handler1 = logging.FileHandler(filename="test.log") 11handler1.setFormatter(logging.Formatter("handler1: %(asctime)s %(levelname)8s %(message)s")) 12 13#handler2を作成 14handler2 = logging.StreamHandler() 15handler2.setLevel(logging.WARN) 16handler2.setFormatter(logging.Formatter("handler2: %(asctime)s %(levelname)8s %(message)s")) 17 18#loggerに2つのハンドラを設定 19logger.addHandler(handler1) 20logger.addHandler(handler2) 21 22#出力処理 23logger.debug("debug message") 24logger.info("info message") 25logger.warning("warn message") 26logger.error("error message")

投稿2020/09/04 11:06

yymmt

総合スコア1615

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問