」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > Infusion 文件產生 CLI 工具

Infusion 文件產生 CLI 工具

發佈於2024-11-08
瀏覽:983

Infusion docs generation cli tool

Infusion 是一个开源工具,用于在代码文件中生成文档。它使用OpenAI gpt-4模型来编写注释。这是我的项目,我用 Python 编写的。

GitHub 链接:
https://github.com/SychAndrii/infusion

explainer.js 是一个开源工具,用于解释代码文件中的代码片段。它使用 Groq 模型来编写注释。这是我的队友 @aamfahim 的一个项目,他用 Node.JS 编写的

GitHub 链接:
https://github.com/aamfahim/explainer.js

我目前正在塞内卡理工学院参加一门开源课程,我们的任务是与另一个人合作,审查彼此的代码,并使用 GitHub 问题提出一些改进建议。我将描述这个过程。

沟通方式

两个存储库生成的大多数问题都是通过 Discord 调用使​​用同步通信完成的。之后,我们使用 Discord 消息进行异步交谈,因为使用 bash 脚本简化项目设置对我来说是一个困难的问题,并且每次我需要测试它是否在他的机器上运行时都打电话给我的队友似乎没有必要。在我的机器上使用 Docker 容器和 WSL Linux 子系统进行的测试与在 Al 的系统上进行的测试不同,它突出显示了重要的错误。

审查某人代码的经历

在检查队友的代码时,我没有遇到任何异常情况,因为我有丰富的 Node.JS 开发经验。我喜欢创造问题,然后立即提出解决方案。我们遇到的一个问题是,我们无法找到一种方法让我在我创建的问题上贴上标签,只有 Al 可以做到,这很烦人。

有人审查我的代码的经历

Al 提出了很大的改进空间,特别是在安装我的 CLI 工具方面。当他第一次分叉我的存储库时,最终用户需要手动安装特定版本的 python,这绝对是一项令人沮丧的任务。此外,他还强调了为了方便使用工具而可能进行的其他改进,例如引入 .env 文件,这样您就不必在每次启动该工具时输入 API 密钥。我喜欢从其他人那里获取对我的代码的输入,因为它使我能够成长为一名开发人员,并且它无疑扩展了我对开发生命周期的看法。

审查和测试期间的问题

我们遇到的大部分问题都与我的工具有关,因为 Al 的 CLI 程序是用 Node.JS 编写的,而且我们都有很多使用它的经验。相比之下,我们都不喜欢Python生态系统,所以我们在与它交互时遇到了很多麻烦。在测试 Al 的存储库时,我发现他的 README 中编写的文档具有误导性或难以理解,尤其是模型和 api-key 选项。我们必须经历反复试验的过程,才能确定他的工具接受哪些 API 密钥和模型。在测试我的存储库时,Al 系统上的 python 版本非常过时(2.7),因此他必须手动安装 3.10.6(使用我的工具所需的版本)。然而,即便如此,问题并没有结束。尽管他安装了它,但我的工具使用 pipelinev 创建的虚拟环境仍然无法识别它。此后,我们每次启动工具时都对输入使用该工具所需的 API 密钥感到沮丧。最后,自述文件对安装没有帮助。我们试图遵循它们,但我们不断收到与 PATH 上无法识别的某些脚本相关的错误。就在那时,我决定我们需要某种自动化工具来为您完成所有安装。我的一个想法是对应用程序进行 docker 化,但随后它需要我以某种方式将 Docker 卷映射到为我的工具指定的输出目录和输入文件,这将使一切变得更加复杂。因此,我记得很多包管理器实际上是命令行工具,如果您通过克隆 GitHub 存储库来安装它们,那么您需要通过执行某种 bash 设置脚本来设置它们。这就是我决定实施的想法。最后,我们都无法找到一种方法来为我们提交的问题分配错误或增强等标签。

我提交的问题

https://github.com/aamfahim/explainer.js/issues/13
https://github.com/aamfahim/explainer.js/issues/12
https://github.com/aamfahim/explainer.js/issues/11
https://github.com/aamfahim/explainer.js/issues/10
https://github.com/aamfahim/explainer.js/issues/9

总结我发现的问题,它们主要涵盖了该项目的自述文件中编写的选项实际上不起作用,或者它们的工作方式被误导性描述的情况。

在我的存储库中提交的问题

https://github.com/SychAndrii/infusion/issues/11
https://github.com/SychAndrii/infusion/issues/10
https://github.com/SychAndrii/infusion/issues/9
https://github.com/SychAndrii/infusion/issues/8

总结一下我的存储库中发现的问题,它们主要与我的工具使用的便利性有关。此外,当您向我的工具提供语法正确的源代码的文件时,存在一个错误,它会将其识别为不包含有效源代码的文件。

我设法解决的问题

我解决了所有问题。所有这些问题都花了不到 30 分钟的时间来修复,但有一个问题,我花了 2-3 个小时才修复:
https://github.com/SychAndrii/infusion/issues/8

这看起来很奇怪,因为自述文件的增强应该很容易实现,但是 Al 的第一个建议要求我完全重新制作我的工具的安装过程,这需要我引入 2 个安装脚本 - 一个用于 bash 和一个用于 Powershell。我大部分时间无法解决的问题是,即使这些安装脚本正确安装了所需版本的python,但该版本的python并没有传递到虚拟环境,您需要在使用我的工具之前进入虚拟环境。最终,我解决了这个问题。

我学到了什么

我确实提高了我的 README 技能。我提供示例用法的方式让最终用户感到非常困惑。此外,我终于使用 bash 和 powershell 语言自己做了一些事情,不是为了学校作业,不是因为这是一项要求,而是因为我想简化与我的工具交互的过程。最后,我决定面对我绝对无法忍受的语言——那就是Python。使用它对我来说绝对不是一件愉快的事,但我认为如果你今天想找到工作,能够使用它是至关重要的,尤其是在人工智能趋势方面。

版本聲明 本文轉載於:https://dev.to/sych_andrii/infusion-docs-generation-cli-tool-ipg?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    將pandas dataframe列轉換為dateTime格式示例:使用column(mycol)包含以下格式的以下dataframe,以自定義格式:})指定的格式參數匹配給定的字符串格式。轉換後,MyCol列現在將包含DateTime對象。 date oped filtering > = ...
    程式設計 發佈於2025-04-09
  • 找到最大計數時,如何解決mySQL中的“組函數\”錯誤的“無效使用”?
    找到最大計數時,如何解決mySQL中的“組函數\”錯誤的“無效使用”?
    如何在mySQL中使用mySql 檢索最大計數,您可能會遇到一個問題,您可能會在嘗試使用以下命令:理解錯誤正確找到由名稱列分組的值的最大計數,請使用以下修改後的查詢: 計數(*)為c 來自EMP1 按名稱組 c desc訂購 限制1 查詢說明 select語句提取名稱列和每個名稱...
    程式設計 發佈於2025-04-09
  • 如何使用替換指令在GO MOD中解析模塊路徑差異?
    如何使用替換指令在GO MOD中解析模塊路徑差異?
    在使用GO MOD時,在GO MOD 中克服模塊路徑差異時,可能會遇到衝突,其中3個Party Package將另一個PAXPANCE帶有導入式套件之間的另一個軟件包,並在導入式套件之間導入另一個軟件包。如迴聲消息所證明的那樣: go.etcd.io/bbolt [&&&&&&&&&&&&&&&&...
    程式設計 發佈於2025-04-09
  • Java是否允許多種返回類型:仔細研究通用方法?
    Java是否允許多種返回類型:仔細研究通用方法?
    在Java中的多個返回類型:一種誤解類型:在Java編程中揭示,在Java編程中,Peculiar方法簽名可能會出現,可能會出現,使開發人員陷入困境,使開發人員陷入困境。 getResult(string s); ,其中foo是自定義類。該方法聲明似乎擁有兩種返回類型:列表和E。但這確實是如此嗎...
    程式設計 發佈於2025-04-09
  • 為什麼Microsoft Visual C ++無法正確實現兩台模板的實例?
    為什麼Microsoft Visual C ++無法正確實現兩台模板的實例?
    在Microsoft Visual C 中,Microsoft consions用戶strate strate strate strate strate strate strate strate strate strate strate strate strate strate strate st...
    程式設計 發佈於2025-04-09
  • 如何克服PHP的功能重新定義限制?
    如何克服PHP的功能重新定義限制?
    克服PHP的函數重新定義限制 但是,PHP工具腰帶中有一個隱藏的寶石:runkit擴展。它使您能夠靈活地重新定義函數。 runkit_function_renction_rename() runkit_function_redefine() //重新定義'this'以返回“新和...
    程式設計 發佈於2025-04-09
  • 如何使用Python有效地以相反順序讀取大型文件?
    如何使用Python有效地以相反順序讀取大型文件?
    在python 反向行讀取器生成器 == ord('\ n'): 緩衝區=緩衝區[:-1] 剩餘_size- = buf_size lines = buffer.split('\ n'....
    程式設計 發佈於2025-04-09
  • 大批
    大批
    [2 數組是對象,因此它們在JS中也具有方法。 切片(開始):在新數組中提取部分數組,而無需突變原始數組。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    程式設計 發佈於2025-04-09
  • PHP陣列鍵值異常:了解07和08的好奇情況
    PHP陣列鍵值異常:了解07和08的好奇情況
    PHP數組鍵值問題,使用07&08 在給定數月的數組中,鍵值07和08呈現令人困惑的行為時,就會出現一個不尋常的問題。運行print_r($月)返回意外結果:鍵“ 07”丟失,而鍵“ 08”分配給了9月的值。 此問題源於PHP對領先零的解釋。當一個數字帶有0(例如07或08)的前綴時,PHP將...
    程式設計 發佈於2025-04-09
  • 為什麼使用固定定位時,為什麼具有100%網格板柱的網格超越身體?
    為什麼使用固定定位時,為什麼具有100%網格板柱的網格超越身體?
    網格超過身體,用100%grid-template-columns 為什麼在grid-template-colms中具有100%的顯示器,當位置設置為設置的位置時,grid-template-colly修復了? 問題: 考慮以下CSS和html: class =“ snippet-code”> ...
    程式設計 發佈於2025-04-09
  • 為什麼我的CSS背景圖像出現?
    為什麼我的CSS背景圖像出現?
    故障排除:CSS背景圖像未出現 ,您的背景圖像儘管遵循教程說明,但您的背景圖像仍未加載。圖像和样式表位於相同的目錄中,但背景仍然是空白的白色帆布。 而不是不棄用的,您已經使用了CSS樣式: bockent {背景:封閉圖像文件名:背景圖:url(nickcage.jpg); 如果您的html,cs...
    程式設計 發佈於2025-04-09
  • 如何使用組在MySQL中旋轉數據?
    如何使用組在MySQL中旋轉數據?
    在關係數據庫中使用mySQL組使用mySQL組進行查詢結果,在關係數據庫中使用MySQL組,轉移數據的數據是指重新排列的行和列的重排以增強數據可視化。在這裡,我們面對一個共同的挑戰:使用組的組將數據從基於行的基於列的轉換為基於列。 Let's consider the following ...
    程式設計 發佈於2025-04-09
  • 如何使用Java.net.urlConnection和Multipart/form-data編碼使用其他參數上傳文件?
    如何使用Java.net.urlConnection和Multipart/form-data編碼使用其他參數上傳文件?
    使用http request 上傳文件上傳到http server,同時也提交其他參數,java.net.net.urlconnection and Multipart/form-data Encoding是普遍的。 Here's a breakdown of the process:Mu...
    程式設計 發佈於2025-04-09
  • 如何將MySQL數據庫添加到Visual Studio 2012中的數據源對話框中?
    如何將MySQL數據庫添加到Visual Studio 2012中的數據源對話框中?
    在Visual Studio 2012 儘管已安裝了MySQL Connector v.6.5.4,但無法將MySQL數據庫添加到實體框架的“ DataSource對話框”中。為了解決這一問題,至關重要的是要了解MySQL連接器v.6.5.5及以後的6.6.x版本將提供MySQL的官方Visual...
    程式設計 發佈於2025-04-09
  • 如何使用Python的請求和假用戶代理繞過網站塊?
    如何使用Python的請求和假用戶代理繞過網站塊?
    如何使用Python的請求模擬瀏覽器行為,以及偽造的用戶代理提供了一個用戶 - 代理標頭一個有效方法是提供有效的用戶式header,以提供有效的用戶 - 設置,該標題可以通過browser和Acterner Systems the equestersystermery和操作系統。通過模仿像Chro...
    程式設計 發佈於2025-04-09

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3