Code2Prompt: 将代码库转化为AI友好的提示工具

RayRay
code2prompt命令行工具生成LLM提示代码库模板自定义Github开源项目

Code2Prompt: 智能代码分析的得力助手

在人工智能和机器学习快速发展的今天,开发者们越来越多地借助大型语言模型(LLMs)来提高工作效率。然而,如何有效地向这些AI模型传递复杂的代码库信息,一直是一个挑战。Code2Prompt应运而生,它是一款创新的命令行工具,旨在解决这一难题,为开发者和AI模型之间搭建一座智能的桥梁。

什么是Code2Prompt?

Code2Prompt是一个强大的命令行工具(CLI),它能够将整个代码库转换成一个结构化的、AI友好的提示。这个工具的核心功能包括生成源代码树结构、支持提示模板定制,以及进行令牌计数。它的设计初衷是为了充分利用像Claude 3.0这样拥有20万令牌上下文窗口的大型语言模型,使得开发者能够更加高效地与AI进行代码相关的交互。

Code2Prompt Screenshot

Code2Prompt的主要特性

  1. 全面的代码库分析:Code2Prompt可以遍历整个目录,生成一个包含源代码树结构和所有代码的格式良好的Markdown提示。

  2. 灵活的模板系统:使用Handlebars模板,用户可以自定义提示生成过程,以适应不同的使用场景。

  3. 智能文件过滤:支持使用glob模式来过滤和排除文件,同时尊重.gitignore规则。

  4. 令牌计数:显示生成提示的令牌数量,帮助用户控制提示的长度,以适应不同AI模型的限制。

  5. Git集成:可选择性地在生成的提示中包含Git差异输出(针对已暂存的文件)。

  6. 便捷的输出选项:自动将生成的提示复制到剪贴板,或保存到输出文件中。

  7. 代码美化:可以为源代码块添加行号,提高可读性。

如何安装Code2Prompt?

Code2Prompt的安装非常简单,支持多种方式:

  1. 使用Cargo安装(推荐):

    cargo install code2prompt
    
  2. 从GitHub仓库克隆并编译:

    git clone https://github.com/mufeedvh/code2prompt.git
    cd code2prompt/
    cargo build --release
    
  3. 下载预编译的二进制文件: 访问GitHub Releases页面,下载适合你操作系统的最新版本。

Code2Prompt的实际应用

Code2Prompt的应用场景非常广泛,以下是几个典型的使用案例:

  1. 代码重写:将整个项目的代码提供给AI,要求其将代码重写为另一种编程语言。

  2. 安全审计:生成包含整个代码库的提示,让AI模型查找潜在的安全漏洞和bug。

  3. 代码文档生成:利用AI分析代码结构和功能,自动生成高质量的代码文档。

  4. 性能优化:让AI分析代码并提供性能优化建议。

  5. 新功能实现:基于现有代码库,要求AI提供新功能的实现方案。

深入了解Code2Prompt的工作原理

Code2Prompt的核心功能是将复杂的代码库转换为结构化的提示。它的工作流程大致如下:

  1. 遍历代码库:工具会递归地遍历指定的目录,收集所有相关的源代码文件。

  2. 构建源代码树:基于收集到的文件,Code2Prompt会生成一个清晰的源代码树结构,帮助AI理解项目的整体架构。

  3. 应用模板:用户可以使用预定义的模板或自定义Handlebars模板来格式化输出。这允许用户根据特定需求定制提示的结构和内容。

  4. 令牌计数:使用tiktoken-rs库实现令牌化,支持多种编码方式,如cl100k_base(用于ChatGPT模型)、p50k_base(用于代码模型)等。

  5. 生成输出:最终,Code2Prompt会生成一个格式化的Markdown文档,包含源代码树、文件内容和其他相关信息。

自定义模板:释放Code2Prompt的全部潜力

Code2Prompt的一大亮点是其灵活的模板系统。通过自定义模板,用户可以精确控制生成的提示内容和格式。以下是几个预定义模板的示例:

  • document-the-code.hbs:用于生成代码文档的提示。
  • find-security-vulnerabilities.hbs:专门用于安全审计的模板。
  • clean-up-code.hbs:用于代码清理和改进的模板。
  • fix-bugs.hbs:针对bug修复的专用模板。

使用自定义模板非常简单,只需在运行Code2Prompt时使用-t参数指定模板文件路径即可:

code2prompt path/to/codebase -t templates/document-the-code.hbs

与其他工具的集成

Code2Prompt不仅可以独立使用,还可以与其他工具无缝集成,进一步扩展其功能:

  1. 与LLM CLI工具集成: Code2Prompt可以与Simon Willison的llmCLI工具集成,实现更强大的代码分析功能:

    code2prompt --path /path/to/your/project | llm "分析这个代码库并提供关于其结构和潜在改进的见解"
    
  2. GitHub Actions集成: 通过在GitHub Actions工作流中使用Code2Prompt,可以实现自动化的代码分析和文档生成:

    name: Code Analysis on: [push] jobs: analyze-code: runs-on: ubuntu-latest steps: - uses: actions/checkout@v2 - name: Set up Python uses: actions/setup-python@v2 with: python-version: '3.x' - name: Install dependencies run: | pip install code2prompt llm - name: Analyze codebase run: | code2prompt --path . | llm "执行全面的代码库分析。识别需要改进的地方,潜在的bug,并提出优化建议。" > analysis.md - name: Upload analysis uses: actions/upload-artifact@v2 with: name: code-analysis path: analysis.md

未来展望

Code2Prompt的开发团队有着宏伟的规划,未来的发展方向包括:

  • 实现交互式过滤功能
  • 在模板中支持系统包含,以提高子模板的可重用性
  • 支持输入变量
  • 为Anthropic模型、LLama3或Mistral等其他模型提供令牌计数
  • 基于令牌计数为主要LLM提供商提供成本估算
  • qllm(Quantalogic LLM)集成
  • 在SQL-Lite中嵌入文件摘要
  • 基于LLM的智能文件选择
  • Git增强工具(Git差异集成/PR辅助审查)

结语

Code2Prompt是一个强大而灵活的工具,它为开发者和AI模型之间的交互提供了一个智能的桥梁。通过自动化代码库到AI提示的转换过程,它大大提高了开发效率,使得复杂的代码分析、重构和优化任务变得更加简单。无论是个人开发者还是大型团队,Code2Prompt都能为您的开发流程带来显著的改进。

如果您对提高代码质量、加速开发过程或者探索AI辅助编程感兴趣,不妨尝试一下Code2Prompt。它可能会成为您工具箱中不可或缺的一员,帮助您在AI时代的软件开发中保持竞争力。

🚀 立即访问Code2Prompt的GitHub仓库,开始您的智能编程之旅吧!如果您觉得这个项目有用,别忘了给它一个星标⭐,这将是对开发者最好的支持和鼓励。

编辑推荐精选

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

下拉加载更多