エントリポイント

packages/analysis-core/pyproject.toml:

[project.scripts]
kouchou-analyze = "analysis_core.__main__:main"

つまり:

  • pip install kouchou-ai-analysis-core すると kouchou-analyze コマンド が PATH に入る
  • 等価に python -m analysis_core でも起動可能(API サーバはこちらを使う)

PyPI 上の パッケージ名は kouchou-ai-analysis-core(ハイフン)、import 時の モジュール名は analysis_core(アンダースコア)。新規利用者が混乱しやすい。

フラグ

packages/analysis-core/src/analysis_core/__main__.py:

フラグ意味
--config / -c PATH設定 JSON(必須)
--force / -f完了済みステップも強制再実行
--only / -o STEP特定ステップのみ
--output-dir PATH出力ベースディレクトリ
--input-dir PATH入力ベースディレクトリ
--dry-run実行計画のみ表示
--version / -vバージョン表示
--skip-interaction対話プロンプトをスキップ(既定 True)
--without-htmlHTML 生成をスキップ(既定 False)

ハマりどころ:--skip-interaction は CLI から無効化できない

current main では --without-htmldefault=False へ直っており、CLI 既定で自己完結型 report.html が出る。これは PR #825 で入った変更。pr-825-standalone-html-observation-2026-05-19より

一方、--skip-interaction はなお action="store_true" + default=True で定義されている:

parser.add_argument("--skip-interaction", action="store_true", default=True,
                    help="Skip interactive prompts (default: True)")

= コマンドラインから False に戻せない。対話確認を明示的に有効化したい用途にはまだ向かない。gotchas にも記載。

ライブラリとしての利用

from analysis_core import PipelineOrchestrator
orchestrator = PipelineOrchestrator.from_config(config_path=Path("config.json"))
result = orchestrator.run()

公開 export(analysis_core/__init__.py):

  • PipelineOrchestrator — CLI の中身
  • PipelineConfig, PipelineResult, StepResult
  • __version__

実行モードは 2 系統(pipeline 参照):

  • orchestrator.run() — 既定。レガシーの run_step ループ
  • orchestrator.run_workflow()plugin-system 経由の workflow 実行。実装はあるが CLI からは呼ばれない

ただし 2026-05-20 時点の open PR #840 では、run_workflow() 側に初期 comments artifact、status 永続化、rerun artifact 再利用まで段階的に持ち込み中であり、CLI default 化に向けた地ならしは進んでいる。pr-840-workflow-defaultization-observation-2026-05-20より

API サーバとの境界

apps/api/src/services/report_launcher.pysubprocess で CLI を起動する:

subprocess.Popen(["python", "-m", "analysis_core",
                  "--config", str(config_path),
                  "--output-dir", str(settings.REPORT_DIR), ...])

API は analysis_core を import しない。python -m analysis_core が canonical な境界面。これにより apps/api/packages/analysis-core/ は依存方向が一方向(API→core)に整理されている。

ただしこれは CLI / 手動実行向けの観察用HTML の話であり、Web の主経路を置き換えるものではない。current apps/api/src/routers/report.pyhierarchical_result.json を返し、apps/public-viewer はその JSON を fetch して描画する。apps/api/src/services/report_launcher.py が subprocess 起動時に --without-html を付けているのも、現行 Web 経路では HTML が配信対象ではないから、と読むのが自然。pr-825-standalone-html-observation-2026-05-19より

2026-05-23 の maintainer 判断でも、この report.html は Web canonical にしない。したがって CLI の観察用HTMLと Web の JSON viewer は、「あとで統一されるはずの半端状態」ではなく、現在の artifact 契約として分けて読む。report-html-non-web-canonical-decision-2026-05-23より

新しい読者向けには、ここを 「CLI 既定と API 挙動が食い違っている未解決問題」ではなく、「利用モードごとに artifact 契約を分けている」 と明記しておく方が混乱が少ない。CLI は手元で完結して読める report.html を重視し、Web は hierarchical_result.json + public-viewer を canonical path としている。判断の全体像は analysis-core-and-web-uiusage-modesより

関連ドキュメント

  • docs/user-guide/cli-quickstart.md — 公式 quickstart。config.json 例とトラブルシューティング(Job already runningrm -rf outputs/config
  • なお pyproject.tomlDocumentation URL は古い docs/CLI_QUICKSTART.md を指していて壊れている(実体は docs/user-guide/cli-quickstart.md

クラスタ数デフォルト

2026-05-18 の Issue #830 / PR #832 では、CLI / analysis-corehierarchical_clustering.cluster_nums省略可能 にし、未指定時は extraction 後の argument 数から cube-root rule で推奨値を自動計算する方向が整理された。
背景には、quickstart の [3, 6] 例が AI コーディングエージェントにそのまま転用され、300 件規模でも粗いまとめを生みやすかったという実務上の問題がある。issue-830-pr-832-auto-cluster-defaults-2026-05-18より

ただし source repo 全体では、README や docs/getting-started/quickstart.md が「コメント数ベース」の説明を残している一方、analysis-core 実装は「argument 数ベース」に寄っている。2026-05-18 時点では、Web docs の語り口と CLI 実装の基準はまだ完全一致していないissue-830-pr-832-auto-cluster-defaults-2026-05-18より

”vive 広聴AI” 用途

meeting-minutes 2025-07-09 で命名された「AI コーディングエージェントから叩く CLI 利用パターン」のメイン経路。議事メモ 2026-05-18 見出しの nishio の社内 300 件分析でも、Claude Code がこの CLI を直接叩いている。

Open Questions

  • --skip-interaction を CLI から False に戻せない問題の解決
  • kouchou-analyze PyPI 公開と GitHub Actions 自動リリース(refactoring-status 参照)

Updates

  • 2026-05-17: 初回作成(コードリーディング結果から)
  • 2026-05-18: Issue #830 / PR #832 により、cluster_nums 省略時は cube-root rule で推奨値を自動算出する方向が具体化したことを追記
  • 2026-05-19: PR #825 merge 後の current main に合わせ、--without-html は既定 False へ直ったが、これは CLI 向け観察用HTMLの話であり Web の主経路は JSON + public-viewer のままだと補正
  • 2026-05-20: open PR #840 により、run_workflow() default 化へ向けた下回り実装が branch 上で進んでいることを追記
  • 2026-05-23: maintainer 判断 report-html-non-web-canonical-decision-2026-05-23 を反映し、report.html は Web canonical にしないと明記