Skip to main content
Glama
using-repomix-as-a-library.md2.36 kB
# 作为库使用 Repomix 除了作为 CLI 工具使用 Repomix 外,您还可以将其功能直接集成到 Node.js 应用程序中。 ## 安装 在您的项目中安装 Repomix 作为依赖项: ```bash npm install repomix ``` ## 基本用法 使用 Repomix 最简单的方法是通过 `runCli` 函数,它提供与命令行界面相同的功能: ```javascript import { runCli, type CliOptions } from 'repomix'; // 使用自定义选项处理当前目录 async function packProject() { const options = { output: 'output.xml', style: 'xml', compress: true, quiet: true } as CliOptions; const result = await runCli(['.'], process.cwd(), options); return result.packResult; } ``` `result.packResult` 包含有关处理文件的信息,包括: - `totalFiles`:处理的文件数量 - `totalCharacters`:总字符数 - `totalTokens`:总令牌数(对 LLM 上下文限制有用) - `fileCharCounts`:每个文件的字符数 - `fileTokenCounts`:每个文件的令牌数 ## 处理远程仓库 您可以克隆并处理远程仓库: ```javascript import { runCli, type CliOptions } from 'repomix'; // 克隆并处理 GitHub 仓库 async function processRemoteRepo(repoUrl) { const options = { remote: repoUrl, output: 'output.xml', compress: true } as CliOptions; return await runCli(['.'], process.cwd(), options); } ``` ## 使用核心组件 要获得更多控制,您可以直接使用 Repomix 的低级 API: ```javascript import { searchFiles, collectFiles, processFiles, TokenCounter } from 'repomix'; async function analyzeFiles(directory) { // 查找并收集文件 const { filePaths } = await searchFiles(directory, { /* 配置 */ }); const rawFiles = await collectFiles(filePaths, directory); const processedFiles = await processFiles(rawFiles, { /* 配置 */ }); // 计算令牌 const tokenCounter = new TokenCounter('o200k_base'); // 返回分析结果 return processedFiles.map(file => ({ path: file.path, tokens: tokenCounter.countTokens(file.content) })); } ``` ## 实际示例 Repomix 网站([repomix.com](https://repomix.com))使用 Repomix 作为库来处理远程仓库。您可以在 [website/server/src/remoteRepo.ts](https://github.com/yamadashy/repomix/blob/main/website/server/src/remoteRepo.ts) 中查看实现。

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/yamadashy/repomix'

If you have feedback or need assistance with the MCP directory API, please join our Discord server