Add mess_log_processing/src/mess_log_processing/cli.py
This commit is contained in:
parent
1ce40ced7e
commit
0759d58605
1 changed files with 80 additions and 0 deletions
80
mess_log_processing/src/mess_log_processing/cli.py
Normal file
80
mess_log_processing/src/mess_log_processing/cli.py
Normal file
|
|
@ -0,0 +1,80 @@
|
|||
import argparse
|
||||
import logging
|
||||
import sys
|
||||
from pathlib import Path
|
||||
|
||||
import pandas as pd
|
||||
|
||||
from mess_log_processing.core import process_logs
|
||||
|
||||
|
||||
def _configure_logging(level: int = logging.INFO) -> None:
|
||||
"""Configure simple logging for CLI execution."""
|
||||
logging.basicConfig(
|
||||
level=level,
|
||||
format="%(asctime)s [%(levelname)s] %(message)s",
|
||||
datefmt="%Y-%m-%d %H:%M:%S",
|
||||
)
|
||||
|
||||
|
||||
def main(argv: list[str] | None = None) -> None:
|
||||
"""Command-line interface for processing measurement logs.
|
||||
|
||||
Uses argparse to receive JSON and CSV input file paths and an optional output path.
|
||||
"""
|
||||
parser = argparse.ArgumentParser(
|
||||
description="Analyse und Aggregation von Messdaten (pinned/unpinned) mit p99-Statistiken."
|
||||
)
|
||||
parser.add_argument(
|
||||
"--json",
|
||||
required=True,
|
||||
help="Pfad zur Eingabe-JSONL-Datei mit Messdaten.",
|
||||
)
|
||||
parser.add_argument(
|
||||
"--csv",
|
||||
required=True,
|
||||
help="Pfad zur Eingabe-CSV-Datei mit Messdaten.",
|
||||
)
|
||||
parser.add_argument(
|
||||
"--out",
|
||||
required=False,
|
||||
help="Pfad zur Ausgabedatei für aggregierte Statistik (CSV).",
|
||||
)
|
||||
|
||||
args = parser.parse_args(argv)
|
||||
|
||||
_configure_logging()
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
json_path = Path(args.json)
|
||||
csv_path = Path(args.csv)
|
||||
output_path = Path(args.out) if args.out else None
|
||||
|
||||
# Validate input paths
|
||||
if not json_path.exists() or not json_path.is_file():
|
||||
logger.error("JSON input file not found or invalid: %s", json_path)
|
||||
sys.exit(1)
|
||||
if not csv_path.exists() or not csv_path.is_file():
|
||||
logger.error("CSV input file not found or invalid: %s", csv_path)
|
||||
sys.exit(1)
|
||||
|
||||
try:
|
||||
logger.info("Processing logs: %s and %s", json_path, csv_path)
|
||||
result_df: pd.DataFrame = process_logs(str(json_path), str(csv_path))
|
||||
logger.info("Processing complete. %d records aggregated.", len(result_df))
|
||||
except Exception as exc: # noqa: BLE001
|
||||
logger.exception("Error during log processing: %s", exc)
|
||||
sys.exit(1)
|
||||
|
||||
if output_path:
|
||||
try:
|
||||
output_path.parent.mkdir(parents=True, exist_ok=True)
|
||||
result_df.to_csv(output_path, index=False)
|
||||
logger.info("Statistics saved to: %s", output_path)
|
||||
except Exception as exc: # noqa: BLE001
|
||||
logger.exception("Failed to write output CSV: %s", exc)
|
||||
sys.exit(1)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
Loading…
Reference in a new issue