create-r-package
について
このClaudeスキルは、最新のベストプラクティスに従った完全な本番環境対応のRパッケージ構造を足場として構築します。DESCRIPTION、NAMESPACE、テスト(testthat)、ドキュメント(roxygen2)、依存関係管理(renv)、CI/CD(GitHub Actions)などの必須ファイルを自動生成します。新規パッケージをゼロから開始する場合、ルーズなスクリプトを構造化パッケージに変換する場合、または共同プロジェクトの骨格を設定する場合にご利用ください。
クイックインストール
Claude Code
推奨npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/create-r-packageこのコマンドをClaude Codeにコピー&ペーストしてスキルをインストールします
ドキュメント
造 R 套件
以現代工具與最佳實踐腳手架一全配之 R 套件。
適用時機
- 由頭造新 R 套件
- 將鬆散 R 腳本轉為結構化套件
- 為協作開發立套件骨架
輸入
- 必要:套件名(小寫,除
.外無特殊字元) - 必要:套件目的之一句描述
- 選擇性:授權類型(預設:MIT)
- 選擇性:作者資訊(名、郵、ORCID)
- 選擇性:是否初始化 renv(預設:是)
步驟
步驟一:造套件骨架
usethis::create_package("packagename")
setwd("packagename")
預期: 已造目錄,含 DESCRIPTION、NAMESPACE、R/、man/ 子目錄。
失敗時: 確保已裝 usethis(install.packages("usethis"))。察目錄未既存。
步驟二:配 DESCRIPTION
編 DESCRIPTION 以準確元資料:
Package: packagename
Title: What the Package Does (Title Case)
Version: 0.1.0
Authors@R:
person("First", "Last", , "[email protected]", role = c("aut", "cre"),
comment = c(ORCID = "0000-0000-0000-0000"))
Description: One paragraph describing what the package does. Must be more
than one sentence. Avoid starting with "This package".
License: MIT + file LICENSE
Encoding: UTF-8
Roxygen: list(markdown = TRUE)
RoxygenNote: 7.3.2
URL: https://github.com/username/packagename
BugReports: https://github.com/username/packagename/issues
預期: 有效之 DESCRIPTION,通過 R CMD check 而無元資料警告。
失敗時: 若 R CMD check 對 DESCRIPTION 欄告警,驗 Title 為 Title Case、Description 多於一句、Authors@R 用有效之 person() 語法。
步驟三:立基礎設施
usethis::use_mit_license()
usethis::use_readme_md()
usethis::use_news_md()
usethis::use_testthat(edition = 3)
usethis::use_git()
usethis::use_github_action("check-standard")
預期: LICENSE、README.md、NEWS.md、tests/ 目錄、.git/ 已初始化、.github/workflows/ 已造。
失敗時: 若某 usethis::use_*() 函式敗,裝缺之依賴並重行。若 .git/ 已存,use_git() 跳初始化。
步驟四:造開發配置
造 .Rprofile:
if (file.exists("renv/activate.R")) {
source("renv/activate.R")
}
if (requireNamespace("mcptools", quietly = TRUE)) {
mcptools::mcp_session()
}
造 .Renviron.example:
RSTUDIO_PANDOC="C:/Program Files/RStudio/resources/app/bin/quarto/bin/tools"
# GITHUB_PAT=your_github_token_here
造 .Rbuildignore 項:
^\.Rprofile$
^\.Renviron$
^\.Renviron\.example$
^renv$
^renv\.lock$
^CLAUDE\.md$
^\.github$
^.*\.Rproj$
預期: .Rprofile、.Renviron.example、.Rbuildignore 已造。開發檔已排於建構之套件外。
失敗時: 若 .Rprofile 於啟動致誤,察語法。確保 requireNamespace() 守防選擇性套件缺時之敗。
步驟五:初始化 renv
renv::init()
預期: renv/ 目錄與 renv.lock 已造。項目本地庫已激活。
失敗時: 以 install.packages("renv") 裝 renv。若 renv 於初始化時懸,察網路連通或設 options(timeout = 600)。
步驟六:造套件文件檔
造 R/packagename-package.R:
#' @keywords internal
"_PACKAGE"
## usethis namespace: start
## usethis namespace: end
NULL
預期: R/packagename-package.R 存,含 "_PACKAGE" 哨標。行 devtools::document() 生套件層之說明。
失敗時: 確保檔名合 R/<packagename>-package.R 模式。"_PACKAGE" 字串須為獨立表式,非函式內。
步驟七:造 CLAUDE.md
於項目根造 CLAUDE.md,含 AI 助手之項目專屬指示。
預期: CLAUDE.md 存於項目根,含項目專屬編輯慣例、建構命令、架構注記。
失敗時: 疑應含何,始於套件名、一句描述、常開發命令(devtools::check()、devtools::test())、任何不顯之慣例。
驗證
-
devtools::check()返 0 誤、0 警告 - 套件結構合期望佈局
-
.Rprofile載入無誤 -
renv::status()無問題 - Git 倉已初始化,含當之
.gitignore - GitHub Actions 工作流檔存
常見陷阱
- 套件名衝突:定名前以
available::available("packagename")察 CRAN - 缺 .Rbuildignore 項:開發檔(
.Rprofile、.Renviron、renv/)須排於建構之套件外 - 忘 Encoding:DESCRIPTION 中恒含
Encoding: UTF-8 - RoxygenNote 不合:DESCRIPTION 中之版本須合已裝之 roxygen2
範例
# Minimal creation
usethis::create_package("myanalysis")
# Full setup in one session
usethis::create_package("myanalysis")
usethis::use_mit_license()
usethis::use_testthat(edition = 3)
usethis::use_readme_md()
usethis::use_git()
usethis::use_github_action("check-standard")
renv::init()
相關技能
write-roxygen-docs- 為造之函式寫文件write-testthat-tests- 為套件加測試setup-github-actions-ci- 詳 CI/CD 配置manage-renv-dependencies- 管套件依賴write-claude-md- 造有效之 AI 助手指示
GitHub リポジトリ
関連スキル
content-collections
メタこのスキルは、Content Collections(Markdown/MDXファイルを型安全なデータコレクションに変換するTypeScriptファーストのツール)の本番環境でテストされた設定を提供します。Zodバリデーションによる型安全性を実現し、ブログ、ドキュメントサイト、コンテンツ重視のVite + Reactアプリケーション構築時にご利用ください。Viteプラグインの設定、MDXコンパイルから、デプロイ最適化、スキーマバリデーションまで、すべてを網羅しています。
polymarket
メタこのスキルは、開発者がPolymarket予測市場プラットフォームを活用したアプリケーション構築を可能にします。API統合による取引や市場データの取得に加え、WebSocketを介したリアルタイムデータストリーミングにより、ライブ取引や市場活動を監視できます。取引戦略の実装や、ライブ市場更新を処理するツールの作成にご利用ください。
creating-opencode-plugins
メタこのスキルは、開発者がコマンド、ファイル、LSP操作など25種類以上のイベントタイプにフックするOpenCodeプラグインを作成することを支援します。JavaScript/TypeScriptモジュール向けに、プラグイン構造、イベントAPI仕様、および実装パターンを提供します。カスタムイベント駆動ロジックでOpenCode AIアシスタントのライフサイクルをインターセプト、監視、または拡張する必要がある場合にご利用ください。
sglang
メタSGLangは、高性能なLLMサービングフレームワークであり、RadixAttentionプレフィックスキャッシュを活用したJSON、正規表現、エージェントワークフロー向けの高速で構造化された生成を特長とします。特にプレフィックスが繰り返されるタスクにおいて、大幅に高速な推論を実現し、複雑な構造化出力やマルチターン対話に最適です。制約付きデコードが必要な場合や、広範なプレフィックス共有を伴うアプリケーションを構築する場合は、vLLMなどの代替案ではなくSGLangを選択してください。
