Python (2.7) での最初のロギング実験では、基本的なロギング モジュールを作成しています。これにより、ロガーがすばやく作成されます (モジュール/クラスごとに設定する必要はありません)。
私がやりたいことは、レベル INFO 以上のすべてのメッセージをコンソールに表示し、すべての DEBUG レベル情報をテキスト ファイルに移動するロガーを作成することです。
ここまでで、INFO をコンソールに出力し、すべてのログ メッセージをテキスト ファイルに出力するロガーを作成しました。ただし、すべての INFO 以上のメッセージをテキスト ファイルに含める必要はありません。
コードを保持するPython Fiddleを作成しました。
チュートリアルから次のデバッグ メッセージを使用しました。
log.debug('All systems operational')
log.info('Airspeed 300 knots')
log.warn('Low on fuel')
log.error('No fuel. Trying to glide.')
log.critical('Glide attempt failed. About to crash.')
コンソール上で次のものが生成されます。
[INFO] root: Airspeed 300 knots
[WARNING] root: Low on fuel
[ERROR] root: No fuel. Trying to glide.
[CRITICAL] root: Glide attempt failed. About to crash.
そして私の debug_log.txt ファイルで:
2013-06-14 14:51:46,963:DEBUG:root:All systems operational
2013-06-14 14:51:46,964:INFO:root:Airspeed 300 knots
2013-06-14 14:51:46,964:WARNING:root:Low on fuel
2013-06-14 14:51:46,964:ERROR:root:No fuel. Trying to glide.
2013-06-14 14:51:46,964:CRITICAL:root:Glide attempt failed. About to crash.
上記のブロックでは、後半の 4 行をファイルに含めないでください。私がやろうとしていることは可能ですか?どうすれば望ましい結果が得られますか?