曾經辛苦造的輪子,現在能否用 ChatGPT 替代呢?

来源:https://www.cnblogs.com/jaycewu/archive/2023/06/23/17500048.html
-Advertisement-
Play Games

上一篇文章 [我在 vscode 插件里接入了 ChatGPT,解決了代碼變數命名的難題](https://www.cnblogs.com/jaycewu/p/17476198.html) 中,展示瞭如何在 vscode 插件中使用 ChatGPT 解決代碼變數命名的問題。vscode 插件市場中有 ...


上一篇文章 我在 vscode 插件里接入了 ChatGPT,解決了代碼變數命名的難題 中,展示瞭如何在 vscode 插件中使用 ChatGPT 解決代碼變數命名的問題。vscode 插件市場中有很多的翻譯插件,但是在一些使用場景里是遠遠比不上 ChatGPT 的,比如只翻譯一段 json 數據里的指定欄位。那麼 ChatGPT 還能做什麼呢?能否取代已經存在的輪子?

以 lowcode 插件中的功能為例,看看能不能用 ChatGPT 替代。

根據 JSON 生成 API 請求方法

首先複製一段 json,比如:

{
    "code": 200,
    "msg": "",
    "result": {
        "records": [
            {
                "id": "1a2b3c4d5",
                "costCenterCode": "ccx002",
                "costCenterName": "財務部",
                "accountingCode": "ac0887",
                "bankAccountingCode": "bk1290",
                "orderNumber": "od1089",
                "orderAmount": "6158.36",
                "confirmedTime": "2023-02-07T13:47:34.552Z",
                "laborCostExcludingTax": "4629.05"
            }
        ],
        "total": 200
    }
}

不使用 ChatGPT

1.gif

使用 ChatGPT

2.gif

可以發現,幾乎達到了一樣的效果,只是 ChatGPT 會慢一點。不使用 ChatGPT 時,插件內部是直接調用庫將 json 轉成 ts 類型,還做了一些邊界處理,比如如果複製的是 json 變數而不是標準的 json 數據,需要將 json 變數變成 json 數據。使用 ChatGPT 對數據就沒有很嚴格的要求,可以是 json 變數,也可以是 json 數據。

非 ChatGPT 的模板

<%- type %>

export interface I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Params {
  id: number;
}
  
export interface I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Data {
	xx: string;
}
  
export function <%= rawSelectedText %>(
  params: I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Params,
  data: I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Data,
) {
  return request<I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Result>({
    url: `xxxx`,
    method: 'GET',
    params,
    data,
  });
}

ChatGPT 的模板

<%- rawClipboardText %> 
根據這段 json 生成 ts 類型,名字為 I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Result
和下麵的代碼一起返回
export interface I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Params {
	id: number;
}
export interface I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Data {
	xx: string;
}
export function <%= rawSelectedText %>(
	params: I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Params,
	data: I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Data,
) {
    return request<I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Result>({
        url: `xxxx`,
        method: 'GET',
        params,
        data,
    });
}
返回 markdown 代碼塊

模板會使用 ejs 進行編譯。

根據 JSON 生成 MOCK 方法

也是先複製一段 json 數據。

不使用 ChatGPT

3.gif

插件內部是直接遍歷 json,把這一段代碼通過字元串拼出來。

使用 ChatGPT

4.gif

這裡使用 ChatGPT 的時候,很難讓它輸出不需要修改就能直接使用的代碼,如上的代碼里輸出了一段無關的內容。

// 調用方法 
getMockData().then(data => { console.log(data); });

ChatGPT 使用的模板:

<%- rawClipboardText %> 
生成一個 js 方法,方法名為 <%= rawSelectedText || 'getRandomData' %>,
方法內部使用 mock.js 生成跟上面的 json 一樣欄位的數據,如果有數組則生成10個元素,
最終的數據使用 Promise.resolve 返回
返回 markdown 代碼塊

根據 JSON 生成 TS 類型

先複製一段 json 數據

不使用 ChatGPT

5.gif

使用 ChatGPT

6.gif

根據 JSON 生成 TS 類型-去除介面名稱

這個用處是:後端介面可以連調的時候替換原有自己預先寫的介面類型。

不使用 ChatGPT

7.gif

使用 ChatGPT

8.gif

根據 TS 類型生成 API 請求方法

使用場景:後端沒有給介面文檔,前端根據原型和設計稿抽象出數據模型,根據數據模型生成 mock 的 API 請求方法(mock數據通過真實後端服務提供)。

只複製類型體,不要類型名稱,比如:

{
    records: {
      id: string;
      costCenterCode: string;
      costCenterName: string;
      accountingCode: string;
      bankAccountingCode: string;
      orderNumber: string;
      orderAmount: string;
      confirmedTime: string;
      laborCostExcludingTax: string;
    }[];
    total: number;
  }

不使用 ChatGPT

9.gif

使用 ChatGPT

因為只是將剪貼板里的內容在模板里做了一下拼裝,完全用不到 ChatGPT。

模板如下:

export interface I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Result {
	code: number;
	msg: string;
	result: <%- rawClipboardText %>
}

export interface I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Params {
	id: number;
}
  
export interface I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Data {
	xx: string;
}
  
export function <%= rawSelectedText %>(
	params: I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Params,
	data: I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Data,
) {
    return request<I<%= rawSelectedText.slice(0, 1).toUpperCase() + rawSelectedText.slice(1) %>Result>({
        url: `xxxx`,
        method: 'GET',
        params,
        data,
    });
}

根據 TS 類型生成 MOCK 方法

使用場景:後端沒有給介面文檔,前端根據原型和設計稿抽象出數據模型,根據數據模型生成 mock 方法(mock 數據沒有通過後端服務提供)。

只複製類型體,不要類型名稱,比如:

{
    records: {
      id: string;
      costCenterCode: string;
      costCenterName: string;
      accountingCode: string;
      bankAccountingCode: string;
      orderNumber: string;
      orderAmount: string;
      confirmedTime: string;
      laborCostExcludingTax: string;
    }[];
    total: number;
  }

不使用 ChatGPT

10.gif

使用 ChatGPT

11.gif

根據 JSON 生成 KOA MOCK

使用場景:mock 數據由 koa 服務提供,根據 json 生成 koa 路由。

不使用 ChatGPT

使用 ChatGPT

根據 TS 類型生成 MOCK

使用場景:後端沒有給介面文檔,前端根據原型和設計稿抽象出數據模型,根據數據模型生成 koa mock 服務。

只複製類型體,不要類型名稱,比如:

{
    records: {
      id: string;
      costCenterCode: string;
      costCenterName: string;
      accountingCode: string;
      bankAccountingCode: string;
      orderNumber: string;
      orderAmount: string;
      confirmedTime: string;
      laborCostExcludingTax: string;
    }[];
    total: number;
  }

不使用 ChatGPT

使用 ChatGPT

根據 TS 類型生成組件文檔

這也是曾經造的輪子 typescript-to-markdown,一個 utools 插件。

效果如圖:

使用 ChatGPT

可以看出來,並不是很完美。

總結

ChatGPT 很難輸出不需要修改直接粘貼到編輯器中就能用的代碼,相比於我們硬編碼寫的插件,在效率上還是有所欠缺。但是藉助插件來管理 ChatGPT Prompt 模板,複製粘貼還是比上官網或者其它客戶端快很多的。

文章沒有提到拉取 YAPI 介面文檔生成代碼的功能,因為 ChatGPT 並不能去拉取介面獲取數據,最近在研究 LangChain,藉助這玩意兒或許可以實現。

Prompt 模板

上面所有的模板已經共用,通過如下方式可以下載到你的項目中:


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、簡單演示 與C指針類似 1)指針變數存的是一個地址,地址指向的空間存的才是值 2)獲取指針類型所指向的值,使用 * 二、使用細節 1)值類型,都有對應的指針類型,形式為*數據類型,比如int的對應指針就是*int 2)值類型包括:基本數據類型int系列,float系列,bool,string,數 ...
  • 基於java房屋租賃系統設計與實現,可適用於java租房網站java房子租用,房屋租用,租房網站,租房管理系統,房屋預約系統,預約看房,房屋資訊,線上房屋信息管理系統等 ...
  • > 內容摘自我的學習網站:topjavaer.cn ## 一面 - kafka在應用場景以及 項目 里的實現 - bitmap底層 - object里有哪些方法 - hashmap相關 - sychronized和reentrantlock相關問題以及鎖升級 - cas和volatile - 線程幾 ...
  • # Java基礎複習筆記 ## 第01章:Java語言概述 ### 1. Java基礎學習的章節劃分 ``` 第1階段:Java基本語法 Java語言概述、Java的變數與進位、運算符、流程式控制制語句(條件判斷、迴圈結構)、break\continue、 IDEA開發工具的使用、數組 第2階段:面向對 ...
  • 一、變數的聲明方式(三種) 1、var a int = num 2、var a = num 3、a := num 二、字元類型使用細節 *Golang的字元使用UTF-8. 英文 -1 位元組;漢字-3個位元組 1、字元常量用單引號括起來。 eg: var c1 byte='a' 2、在Go中,字元的本 ...
  • 見過好多大項目,一個解決方案好多個項目,網站、動態庫、測試等。放在不同的文件夾下,感覺很好。下麵介紹一下方法。 首先創建一個空白解決方案 會自動創建MultiFolder解決方案目錄。 ![img](https://img2023.cnblogs.com/blog/108012/202306/108 ...
  • 產品設計出來之後啊,大家使用的時候覺得反過來使用更加便捷。但是屏幕顯示是反的。那怎麼辦那????? 修改硬體費時費工,那能否軟體實現那????? 如果純軟體使用那就太費系統資源了。於是就想到了使用全志R528 自帶的G2D功能(硬體加速功能)。 使用它進行旋轉,後又發現uboot階段系統沒有G2D導 ...
  • 1. 背景 日誌領域是Elasticsearch(ES)最重要也是規模最大的應用場景之一。這得益於 ES 有高性能倒排索引、靈活的 schema、易用的分散式架構,支持高吞吐寫入、高性能查詢,同時有強大的數據治理生態、端到端的完整解決方案。但原生 ES 在高吞吐寫入、低成本存儲、高性能查詢等方面還有 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...