[解決済み】ロガーにハンドラが見つからない
2022-01-27 22:10:53
質問
Pythonの初心者です。私はpythonでログを取ろうとしたとき、私は遭遇しました。 logger に対応するハンドラが見つかりませんでした。 というエラーが発生しました。以下は、私が試したコードです。
import logging
logger=logging.getLogger('logger')
logger.warning('The system may break down')
そして、このようなエラーが発生します。 logger "logger"のハンドラが見つかりませんでした。
何が問題かというと、最初に警告を表示しようとしたときに
logging
を使用し、次に
logger
のように、正常に動作します。
>>> import logging
>>> logging.warning('This is a WARNING!!!!')
WARNING:root:This is a WARNING!!!!
>>>
>>> logger.warning('WARNING!!!!')
WARNING:logger:WARNING!!!!
2番目のシナリオで何が起こっているのか、どなたか教えてください。
どのように解決するのですか?
メッセージのロギングを行うには
logger
Python では、少なくとも一つのハンドラを
logger
オブジェクトを作成します。デフォルトでは
debug
,
warn
にある関数など
logging
モジュールは
basicConfig
を追加し、さらに
StreamHandler
を
root logger
.
それは、いつも おすすめ を使用して、必要なハンドラをモジュール用に書いているロガーオブジェクトに追加します。
を参照することができます。 Python公式ドキュメント があり、その中に すごいチュートリアル または、自分でloggingモジュールのソースコードをチェックアウトするのがよいでしょう。
単純に、Pythonのシェルでソースを確認することもできます。
import logging
import inspect
print(inspect.getsource(logging))
最後に
basicConfig
を明示的に指定すれば解決します。
import logging
logging.basicConfig()
logger = logging.getLogger('logger')
logger.warning('The system may break down')
関連
-
Python LeNetネットワークの説明とpytorchでの実装
-
[解決済み] 'DataFrame' オブジェクトに 'sort' 属性がない
-
[解決済み】"No JSON object could be decoded "よりも良いエラーメッセージを表示する。
-
[解決済み] TypeError: 'DataFrame' オブジェクトは呼び出し可能ではない
-
[解決済み】Python - "ValueError: not enough values to unpack (expected 2, got 1)" の修正方法 [閉店].
-
[解決済み] for'ループでインデックスにアクセスする?
-
[解決済み] __init__.py は何のためにあるのですか?
-
[解決済み] パラメータに**(ダブルスター/アスタリスク)、*(スター/アスタリスク)がありますが、これはどういう意味ですか?
-
[解決済み] 最近のPythonでカスタム例外を宣言する適切な方法?
-
[解決済み】forループを使った辞書の反復処理
最新
-
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 call matlab メソッドの詳細
-
Python百行で韓服サークルの画像クロールを実現する
-
[解決済み】お使いのCPUは、このTensorFlowバイナリが使用するようにコンパイルされていない命令をサポートしています。AVX AVX2
-
[解決済み】csv.Error:イテレータはバイトではなく文字列を返すべき
-
[解決済み】TypeError: 系列を <class 'float'> に変換することができません。
-
[解決済み] 'DataFrame' オブジェクトに 'sort' 属性がない
-
[解決済み】インポートエラー。モジュール名 urllib2 がない
-
[解決済み】IndexError: invalid index to scalar variableを修正する方法
-
[解決済み】SyntaxError: デフォルト以外の引数がデフォルトの引数に続く
-
[解決済み】cアンダースコア式`c_`は、具体的に何をするのですか?