検索
ホームページバックエンド開発Python チュートリアルPython ロギングをマスターする: 基本から高度なテクニックまで

Python でのログインは単なるデバッグではなく、アプリケーションの動作を追跡、監視、理解することを意味します。初心者でも経験豊富な開発者でも、このガイドでは基本的なセットアップから高度なテクニックまで、ロギングのあらゆる側面をカバーしています。

Mastering Python Logging: From Basics to Advanced Techniques

はじめに
ロギングとは何ですか?
ロギングは、プログラムの実行中にイベントを記録および追跡するメカニズムであり、開発者がアプリケーションを効果的にデバッグ、監視、分析できるようにします。

ログ記録が重要なのはなぜですか?
印刷とは異なり、ログ記録は柔軟性、拡張性、構成可能性を備えているため、小規模なスクリプトと大規模なアプリケーションの両方にとって強力な選択肢となります。

このブログの内容
基本的なログの設定
ログをファイルに書き込む
カスタムロガーの作成
ログ出力のフォーマット
ログのローテーションや構成などの高度なテクニック
ベストプラクティスとよくある間違い

Python のロギングとは何ですか?
ロギングモジュールを紹介します。
ログレベルの説明:
デバッグ: 問題を診断するための詳細情報。
情報: プログラムが期待どおりに動作していることの確認。
警告: 予期しない問題が発生しましたが、プログラムは引き続き実行できます。
エラー: 問題により操作が失敗しました。
クリティカル: プログラムを停止する可能性がある重大なエラー。

基本的なログのセットアップ
logging.basicConfig.
を導入します。 簡単な例を示します:

import logging

# Basic configuration
logging.basicConfig(level=logging.INFO)

# Logging messages
logging.debug("Debug message")
logging.info("Info message")
logging.warning("Warning message")
logging.error("Error message")
logging.critical("Critical message")

出力
デフォルトでは、WARNING レベル以上のメッセージのみがコンソールに表示されます。上記の例では次のものが生成されます:

警告:root:警告メッセージ
エラー:ルート:エラーメッセージ
CRITICAL:root:クリティカルメッセージ

ファイルへのログの書き込み

logging.basicConfig(filename="app.log", 
                    level=logging.DEBUG, 
                    format="%(asctime)s - %(levelname)s - %(message)s")

logging.info("This will be written to a file.")

basicConfig の共通パラメータについて説明します:
filename: ログ ファイルを指定します。
ファイルモード: 上書きする場合は 'w'、追加する場合は 'a'。
format: ログ メッセージの構造をカスタマイズします。

カスタム ロガーの作成
カスタム ロガーを使用する理由モジュール化され、より制御されたロギング用。
例:

import logging

# Create a custom logger
logger = logging.getLogger("my_logger")
logger.setLevel(logging.DEBUG)

# Create handlers
console_handler = logging.StreamHandler()
file_handler = logging.FileHandler("custom.log")

# Set levels for handlers
console_handler.setLevel(logging.INFO)
file_handler.setLevel(logging.ERROR)

# Create formatters and add them to handlers
formatter = logging.Formatter("%(name)s - %(levelname)s - %(message)s")
console_handler.setFormatter(formatter)
file_handler.setFormatter(formatter)

# Add handlers to the logger
logger.addHandler(console_handler)
logger.addHandler(file_handler)

# Log messages
logger.info("This is an info message.")
logger.error("This is an error message.")

** ログのフォーマット**
ログレコード属性の説明:
%(asctime)s: タイムスタンプ。
%(levelname)s: ログ メッセージのレベル。
%(message)s: 実際のログ メッセージ。
%(name)s: ロガーの名前。
高度な書式設定:

logging.basicConfig(format="%(asctime)s - %(name)s - %(levelname)s - %(message)s",
                    datefmt="%Y-%m-%d %H:%M:%S",
                    level=logging.DEBUG)

ログローテーション
ログ ファイル サイズを管理するための RotatingFileHandler を導入します。
例:

from logging.handlers import RotatingFileHandler

# Create a logger
logger = logging.getLogger("rotating_logger")
logger.setLevel(logging.DEBUG)

# Create a rotating file handler
handler = RotatingFileHandler("app.log", maxBytes=2000, backupCount=3)
formatter = logging.Formatter("%(asctime)s - %(levelname)s - %(message)s")
handler.setFormatter(formatter)

logger.addHandler(handler)

# Log messages
for i in range(100):
    logger.info(f"Message {i}")

複雑な構成でのlogging.configの使用
構成辞書の使用方法を示します:

import logging

# Basic configuration
logging.basicConfig(level=logging.INFO)

# Logging messages
logging.debug("Debug message")
logging.info("Info message")
logging.warning("Warning message")
logging.error("Error message")
logging.critical("Critical message")

ロギングのベストプラクティス
意味のあるログ メッセージを使用してください。
ログ内の機密データは避けてください。
開発では DEBUG レベルを使用し、実稼働ではそれ以上のレベルを使用します。
ストレージの問題を防ぐためにログ ファイルをローテーションします。
異なるモジュールには一意のロガー名を使用してください。

よくある間違い
本番環境で DEBUG を使いすぎています。
ファイル ハンドラーを閉じるのを忘れています。
エラー用に別のログ ファイルを使用しません。

高度なトピック
非同期ロギング
高パフォーマンスのアプリケーションの場合は、QueueHandler を使用してロギング タスクを非同期にオフロードします。

構造化ロギング
特に ELK スタックのようなシステムの場合は、メッセージを JSON としてログに記録して、機械で読み取り可能にします。

サードパーティのライブラリ
よりシンプルかつ強力なロギングを実現する loguru などのツールを探索してください。

結論
ロギングは単なるデバッグではなく、アプリケーションを理解することにもつながります。 Python のロギング モジュールをマスターすることで、プロジェクトが堅牢で保守しやすく、デバッグが簡単であることを確認できます。

ご質問やご提案がありますか?以下のコメント欄でご意見を共有してください!

以上がPython ロギングをマスターする: 基本から高度なテクニックまでの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
リストと配列の選択は、大規模なデータセットを扱うPythonアプリケーションの全体的なパフォーマンスにどのように影響しますか?リストと配列の選択は、大規模なデータセットを扱うPythonアプリケーションの全体的なパフォーマンスにどのように影響しますか?May 03, 2025 am 12:11 AM

forhandlinglaredataSetsinpython、usenumpyArrays forbetterperformance.1)numpyarraysarememory-effictientandfasterfornumericaloperations.2)nusinnnnedarytypeconversions.3)レバレッジベクトル化は、測定済みのマネージメーシェイメージーウェイズデイタイです

Pythonのリストと配列にメモリがどのように割り当てられるかを説明します。Pythonのリストと配列にメモリがどのように割り当てられるかを説明します。May 03, 2025 am 12:10 AM

inpython、listsusedynamicmemoryallocation with allocation、whilenumpyArraysalocatefixedmemory.1)listsallocatemorememorythanneededededinitivative.2)numpyArrayasallocateexactmemoryforements、rededicablebutlessflexibilityを提供します。

Pythonアレイ内の要素のデータ型をどのように指定しますか?Pythonアレイ内の要素のデータ型をどのように指定しますか?May 03, 2025 am 12:06 AM

inpython、youcanspecthedatatypeyfelemeremodelernspant.1)usenpynernrump.1)usenpynerp.dloatp.ploatm64、フォーマーpreciscontrolatatypes。

Numpyとは何ですか、そしてなぜPythonの数値コンピューティングにとって重要なのですか?Numpyとは何ですか、そしてなぜPythonの数値コンピューティングにとって重要なのですか?May 03, 2025 am 12:03 AM

numpyisessentialfornumericalcomputinginpythonduetoitsspeed、memory efficiency、andcomprehensivematicalfunctions.1)それは、performsoperations.2)numpyArraysaremoremory-efficientthanpythonlists.3)Itofderangeofmathematicaloperty

「隣接するメモリ割り当て」の概念と、配列にとってその重要性について説明します。「隣接するメモリ割り当て」の概念と、配列にとってその重要性について説明します。May 03, 2025 am 12:01 AM

contiguousMemoryAllocationisucial forArraysは、ForeffienceAndfastelementAccess.1)iteenablesConstantTimeAccess、O(1)、DuetodirectAddresscalculation.2)itemprovesefficiencyByAllowingMultiblementFechesperCacheLine.3)itimplifieMememm

Pythonリストをどのようにスライスしますか?Pythonリストをどのようにスライスしますか?May 02, 2025 am 12:14 AM

slicingapythonlistisdoneusingtheyntaxlist [start:stop:step] .hore'showitworks:1)startisthe indexofthefirstelementtoinclude.2)spotisthe indexofthefirmenttoeexclude.3)staptistheincrementbetbetinelements

Numpyアレイで実行できる一般的な操作は何ですか?Numpyアレイで実行できる一般的な操作は何ですか?May 02, 2025 am 12:09 AM

numpyallows forvariousoperationsonarrays:1)basicarithmeticlikeaddition、減算、乗算、および分割; 2)AdvancedperationssuchasmatrixMultiplication;

Pythonを使用したデータ分析では、配列はどのように使用されていますか?Pythonを使用したデータ分析では、配列はどのように使用されていますか?May 02, 2025 am 12:09 AM

Arraysinpython、特にnumpyandpandas、aresentialfordataanalysis、offeringspeedandeficiency.1)numpyarraysenable numpyarraysenable handling forlaredatasents andcomplexoperationslikemoverages.2)Pandasextendsnumpy'scapabivitieswithdataframesfortruc

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。