Zurück zu Fähigkeiten

build-parameterized-report

pjt222
Aktualisiert 2 days ago
5 Ansichten
17
2
17
Auf GitHub ansehen
Metadesign

Über

Diese Fähigkeit erstellt parametrisierte Quarto- oder R Markdown-Berichte, die mehrere angepasste Variationen aus einer einzigen Vorlage generieren können. Sie übernimmt die Parameterdefinition, das programmatische Rendern und die Stapelgenerierung für automatisierte Berichterstattung. Verwenden Sie sie, wenn Sie Berichte für verschiedene Abteilungen, Regionen, Zeiträume oder Kunden aus einer Vorlage erstellen müssen.

Schnellinstallation

Claude Code

Empfohlen
Primär
npx skills add pjt222/agent-almanac -a claude-code
Plugin-BefehlAlternativ
/plugin add https://github.com/pjt222/agent-almanac
Git CloneAlternativ
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/build-parameterized-report

Kopieren Sie diesen Befehl und fügen Sie ihn in Claude Code ein, um diese Fähigkeit zu installieren

Dokumentation

パラメータ化レポートの構築

パラメータを受け取り、単一テンプレートから複数のカスタマイズされたバリエーションを生成するレポートを作成する。

使用タイミング

  • 異なる部門、地域、または期間で同じレポートを生成する時
  • テンプレートからクライアント固有のレポートを作成する時
  • 特定のサブセットにフィルタリングするダッシュボードを構築する時
  • 異なる入力で繰り返しレポートを自動化する時

入力

  • 必須: レポートテンプレート(QuartoまたはR Markdown)
  • 必須: パラメータ定義(名前、型、デフォルト値)
  • 任意: バッチ生成用のパラメータ値リスト
  • 任意: 生成レポートの出力ディレクトリ

手順

ステップ1: YAMLでパラメータを定義

Quarto(report.qmd)の場合:

---
title: "Sales Report: `r params$region`"
params:
  region: "North America"
  year: 2025
  include_forecast: true
format:
  html:
    toc: true
---

R Markdown(report.Rmd)の場合:

---
title: "Sales Report"
params:
  region: "North America"
  year: 2025
  include_forecast: true
output: html_document
---

期待結果: YAMLヘッダーに名前付きパラメータを含むparams:ブロックがあり、各パラメータが正しい型のデフォルト値を持つ。

失敗時: 「object 'params' not found」でレンダリングが失敗する場合、params:ブロックがYAMLフロントマター下で正しくインデントされていることを確認する。Quartoの場合、paramsはYAMLのトップレベルでなければならず、format:の下にネストしてはならない。

ステップ2: コードでパラメータを使用

```{r}
#| label: filter-data

data <- full_dataset |>
  filter(region == params$region, year == params$year)

nrow(data)
```

## Overview for `r params$region`

This report covers the `r params$region` region for `r params$year`.

```{r}
#| label: forecast
#| eval: !expr params$include_forecast

# This chunk only runs when include_forecast is TRUE
forecast_model <- forecast::auto.arima(data$sales)
forecast::autoplot(forecast_model)
```

期待結果: コードチャンクがparams$nameでパラメータを参照し、条件付きチャンクがQuartoでは#| eval: !expr params$flagを使用する。`r params$region`のようなインラインR式が動的テキストをレンダリングする。

失敗時: params$nameがNULLを返す場合、パラメータ名がYAML定義とコード参照間で正確に一致していることを確認する(大文字小文字を区別)。デフォルト値が正しい型であることを確認する。

ステップ3: カスタムパラメータでレンダリング

単一レンダリング:

# Quarto
quarto::quarto_render(
  "report.qmd",
  execute_params = list(region = "Europe", year = 2025)
)

# R Markdown
rmarkdown::render(
  "report.Rmd",
  params = list(region = "Europe", year = 2025),
  output_file = "report-europe-2025.html"
)

期待結果: カスタムパラメータ値でYAMLデフォルトを上書きして単一レポートが正常にレンダリングされる。出力ファイルが指定パスに作成される。

失敗時: Quartoレンダリングが失敗する場合、quarto CLIがインストールされPATHにあることを確認する。R Markdownレンダリングが失敗する場合、rmarkdownがインストールされていることを確認する。execute_params(Quarto)またはparams(R Markdown)のパラメータ名がYAML定義と正確に一致していることを確認する。

ステップ4: 複数レポートのバッチレンダリング

regions <- c("North America", "Europe", "Asia Pacific", "Latin America")
years <- c(2024, 2025)

# Generate all combinations
combinations <- expand.grid(region = regions, year = years, stringsAsFactors = FALSE)

# Render each
purrr::pwalk(combinations, function(region, year) {
  output_name <- sprintf("report-%s-%d.html",
    tolower(gsub(" ", "-", region)), year)

  quarto::quarto_render(
    "report.qmd",
    execute_params = list(region = region, year = year),
    output_file = output_name
  )
})

期待結果: 地域-年の組み合わせごとに1つのHTMLファイル。

失敗時: パラメータ名がYAMLとコード間で正確に一致していることを確認する。すべてのパラメータ値が有効であることを確認する。

ステップ5: パラメータバリデーションの追加

#| label: validate-params

stopifnot(
  "Region must be a valid region" = params$region %in% valid_regions,
  "Year must be numeric" = is.numeric(params$year),
  "Year must be reasonable" = params$year >= 2020 && params$year <= 2030
)

期待結果: バリデーションコードチャンクが各レンダリングの開始時に実行され、パラメータが範囲外または誤った型の場合に情報的なエラーで停止する。

失敗時: stopifnot()が不明確なエラーメッセージを生成する場合、より明確な診断のために明示的なif (!cond) stop("message")呼び出しに切り替える。

ステップ6: 出力の整理

# Create output directory
output_dir <- file.path("reports", format(Sys.Date(), "%Y-%m"))
dir.create(output_dir, recursive = TRUE, showWarnings = FALSE)

# Render with output path
quarto::quarto_render(
  "report.qmd",
  execute_params = list(region = region),
  output_file = file.path(output_dir, paste0("report-", region, ".html"))
)

期待結果: 出力ファイルが日付スタンプ付きサブディレクトリに記述的な名前で書き込まれる(例: reports/2025-06/report-europe.html)。

失敗時: dir.create()が失敗する場合、親ディレクトリが存在し書き込み可能であることを確認する。Windowsではパス長が260文字を超えていないことを確認する。

バリデーション

  • レポートがデフォルトパラメータでレンダリングされる
  • レポートが各セットのカスタムパラメータでレンダリングされる
  • 処理前にパラメータがバリデーションされる
  • 出力ファイルが記述的に名前付けされている
  • 条件付きセクションがパラメータに基づいて正しくレンダリングされる
  • バッチ生成がすべての組み合わせで完了する

よくある落とし穴

  • パラメータ名の不一致: YAML名はコード内のparams$name参照と正確に一致しなければならない
  • 型変換: YAMLはyear: 2025を整数としてパースするかもしれないが、コードは文字列を期待する場合がある。明示的にする
  • 条件付き評価: Quartoではeval = params$flagではなく#| eval: !expr params$flagを使用する
  • ファイルの上書き: 一意の出力名なしでは、各レンダリングが前のものを上書きする
  • バッチモードでのメモリ: 長いバッチ実行はメモリを蓄積する可能性がある。分離のためにcallr::r()の使用を検討する

関連スキル

  • create-quarto-report -- 基本的なQuartoドキュメントセットアップ
  • generate-statistical-tables -- パラメータに適応するテーブル
  • format-apa-report -- パラメータ化された学術レポート

GitHub Repository

pjt222/agent-almanac
Pfad: i18n/ja/skills/build-parameterized-report
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

Verwandte Skills

content-collections

Meta

Diese Skill bietet eine produktionsgetestete Einrichtung für Content Collections – ein TypeScript-first-Tool, das Markdown/MDX-Dateien in typsichere Datensammlungen mit Zod-Validierung umwandelt. Verwenden Sie ihn beim Erstellen von Blogs, Dokumentationsseiten oder inhaltsstarken Vite + React-Anwendungen, um Typsicherheit und automatische Inhaltsvalidierung zu gewährleisten. Er behandelt alles von der Vite-Plugin-Konfiguration und MDX-Kompilierung bis hin zur Deployment-Optimierung und Schema-Validierung.

Skill ansehen

polymarket

Meta

Diese Fähigkeit ermöglicht es Entwicklern, Anwendungen mit der Polymarket-Prognosemärkte-Plattform zu erstellen, einschließlich API-Integration für Handel und Marktdaten. Sie bietet außerdem Echtzeit-Datenstreaming über WebSocket, um Live-Trades und Marktaktivitäten zu überwachen. Nutzen Sie sie zur Implementierung von Handelsstrategien oder zur Erstellung von Tools, die Live-Marktaktualisierungen verarbeiten.

Skill ansehen

creating-opencode-plugins

Meta

Diese Fähigkeit unterstützt Entwickler dabei, OpenCode-Plugins zu erstellen, die in über 25 Ereignistypen wie Befehle, Dateien und LSP-Operationen eingreifen. Sie bietet die Plugin-Struktur, Event-API-Spezifikationen und Implementierungsmuster für JavaScript/TypeScript-Module. Nutzen Sie sie, wenn Sie den Lebenszyklus des OpenCode KI-Assistenten mit benutzerdefinierter ereignisgesteuerter Logik abfangen, überwachen oder erweitern müssen.

Skill ansehen

sglang

Meta

SGLang ist ein hochperformantes LLM-Serving-Framework, das sich auf schnelle, strukturierte Generierung für JSON, Regex und agentenbasierte Workflows unter Verwendung seines RadixAttention-Prefix-Cachings spezialisiert. Es bietet deutlich schnellere Inferenz, insbesondere für Aufgaben mit wiederholten Präfixen, was es ideal für komplexe, strukturierte Ausgaben und Mehrfachdialoge macht. Wählen Sie SGLang gegenüber Alternativen wie vLLM, wenn Sie constrained decoding benötigen oder Anwendungen mit umfangreicher Präfix-Weitergabe entwickeln.

Skill ansehen