Skip to main content

A custom logging utility and other utilities with Rich console output, file handling, Slack notification, etc.

Project description

agesuta

README.txtはAIによる生成ファイルです。(README.txt is a file generated by AI.)

Python標準のloggingモジュールをベースにしたカスタムロギングユーティリティです。richによる色付きコンソール出力、カスタムローテーションハンドラによるファイルロギング、ログファイルのエンコーディング処理機能を備えています。

注記: 現在のバージョンに含まれるカスタムファイルローテーションハンドラ(CustomLevelRotatingFileHandler, CustomDateRotatingFileHandler)は、CustomLogger.log_mainで生成されるファイル名との間に論理的な不整合がある可能性があります。これにより、一部の設定でログファイルが正しくローテーションされない場合があります。使用には注意が必要か、ハンドラの実装を確認してください。

インストール

ロギング機能および設定管理機能のみを使用する(オフライン環境や、余計な外部依存パッケージをインストールしたくない)場合:

pip install agesuta

Slack通知連携機能(SlackPoster)も併せて使用したい場合:

pip install agesuta[slack]

使用方法

基本的な使用例を以下に示します:

import logging
from agesuta import CustomLogger, log_decorator

# ロガーの初期設定を行うインスタンスを作成します
# これにより、ルートロガーにハンドラが設定されます
Cl_logger = CustomLogger(
    flag_datelog=False, # 日付ベース of 単一ログファイルにする場合は True に設定
    dir_path="./Log",
    log_encode="utf-8",
    showlevel="INFO", # コンソール出力の最小レベル
    maxBytes=5 * 1024 * 1024, # ログファイルを5MBでローテーション
    backupCount=5 # バックアップファイルを最大5世代保持
)
Cl_logger.log_main() # ロギング設定を適用します

# 標準のlogging.getLogger()を使ってロガーインスタンスを取得します
# これは Cl_logger.log_main() で設定されたハンドラを使用します
logger = logging.getLogger(__name__)

logger.debug("これはデバッグメッセージです。")
logger.info("これは情報メッセージです。")
logger.warning("これは警告メッセージです。")
logger.error("これはエラーメッセージです。")
logger.critical("これはクリティカルメッセージです。")

# log_decorator の使用例
# from agesuta import log_decorator # パッケージ名に合わせて変更してください

# @log_decorator(logger)
# def my_function(arg1, arg2):
#     logger.info("関数の中で何か処理しています")
#     return arg1 + arg2

# result = my_function(10, 20)
# print(f"関数の結果: {result}")

flag_datelogFalse の場合、異なるレベル(例: my_script_0_debug.log, my_script_1_info.log など)ごとに個別のログファイルが dir_path に作成されます。 flag_datelogTrue の場合、日付を含む単一のログファイル(例: my_script_YYYY-MM-DD.log)が作成されます。

CustomLogger パラメータ

  • flag_datelog (bool): Trueの場合、日付ベースのログファイル命名規則(basename_YYYY-MM-DD.log)を使用し、CustomDateRotatingFileHandlerを使用します。False(デフォルト)の場合、レベルベースのログファイル命名規則(basename_level.log)を使用し、CustomLevelRotatingFileHandlerを使用します。
  • dir_path (str): ログファイルが保存されるディレクトリです(デフォルト: ./Log)。
  • log_encode (str): ログファイルのエンコーディングです(デフォルト: "utf-8")。初期化時に、異なるエンコーディングの既存ログファイルは変換されます。
  • maxBytes (int): ログファイルがローテーションされるまでの最大バイト数です(デフォルト: 10 * 1024 * 1024 バイト、つまり 10MB)。
  • backupCount (int): ローテーション後に保持するバックアップログファイルの数です(デフォルト: 10)。
  • showlevel (str): コンソール(RichHandlerを使用)に表示するログの最小レベルです。 "DEBUG", "INFO"(デフォルト), "WARNING", "ERROR", "CRITICAL", "NOTSET" を受け付けます。大文字小文字は区別されません。
  • flag_unnecessary_loggers_to_error (bool): True(デフォルト)の場合、一般的で詳細なサードパーティライブラリ(例: werkzeug, urllib3, httpx など)のロガーレベルを ERROR に設定し、コンソールのノイズを減らします。

カスタムファイルハンドラ

このパッケージには、logging.handlers.RotatingFileHandler をベースにしたカスタムハンドラが含まれています:

  • NoColorFormatter: ANSIエスケープシーケンスを取り除くロギングフォーマッターです。RichHandler使用時のプレーンテキストログファイルに有用です。
  • CustomLevelRotatingFileHandler: サイズベースのローテーションを意図したカスタムハンドラで、flag_datelogFalse の場合に使用されます。
  • CustomDateRotatingFileHandler: 日付を意識した命名規則を持つサイズベースのローテーションを意図したカスタムハンドラで、flag_datelogTrue の場合に使用されます。 ローテーションに関する注記: 上記で述べたように、カスタムハンドラのローテーションロジックと CustomLogger.log_main で生成されるファイル名との間に問題がある可能性があります。

log_decorator

関数への入退室およびエラーを自動的にDEBUGレベルとERRORレベルでログに記録するためのシンプルなデコレーター(log_decorator)が提供されています。

ライセンス

このプロジェクトはMITライセンスの下で提供されます - 詳細については LICENSE ファイルを参照してください。

Antigravityによる改善プロジェクト (2026-05-23)

ライブラリの全体的なスキャンを行い、堅牢性と使いやすさを向上させるための改善タスクを定義し、実行しました。

改善タスク一覧

  • 開発仮想環境(venv)の再作成(Python 3.13 への追従)
  • com.py: CustomLevelRotatingFileHandler のファイル名パースバグ修正(ファイル名に . が含まれる場合の崩壊防止)
  • com.py: CustomDateRotatingFileHandler の日付またぎ時のローテーション不整合修正(日付変更時に自動で新ファイルを作成)
  • com.py: ファイル操作時の Windows PermissionError に対する例外ハンドリングの強化
  • com.py: クラス/インスタンスメソッドにも対応した高度な log_decorator の再実装
  • slackapi.py: get_channelid でチャンネルIDが直接渡された際の即時返却対応(API呼び出しの削減)
  • slackapi.py: get_channelid のページネーション(100件超のチャンネル対応)
  • slackapi.py: 改善された log_decorator の適用とロギングの最適化
  • 全体の black フォーマット適用とテストコードによる動作確認

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

agesuta-0.1.19.tar.gz (26.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

agesuta-0.1.19-py3-none-any.whl (24.4 kB view details)

Uploaded Python 3

File details

Details for the file agesuta-0.1.19.tar.gz.

File metadata

  • Download URL: agesuta-0.1.19.tar.gz
  • Upload date:
  • Size: 26.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for agesuta-0.1.19.tar.gz
Algorithm Hash digest
SHA256 985d39b52a16dea08c78d579b7b7f498d2d3f07d648ff02ae342b6cb1abc17ba
MD5 c30fdc6ee22e7630b6ec6a3dabcb4e79
BLAKE2b-256 0e42710ae3805da941b02ca09697cbd1550ce2e125e6827fc543b6a4dc90576c

See more details on using hashes here.

File details

Details for the file agesuta-0.1.19-py3-none-any.whl.

File metadata

  • Download URL: agesuta-0.1.19-py3-none-any.whl
  • Upload date:
  • Size: 24.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for agesuta-0.1.19-py3-none-any.whl
Algorithm Hash digest
SHA256 bb07cc75bb36b3ecb8757b5ed9624c871bc242daa35720a0f7a732502efa2fd5
MD5 c45debf1bbed01523ee189d502a0e439
BLAKE2b-256 72fd99434174b374bed399f325a8335e49c41f97b0be322afe0e04165f5f1014

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page