3
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

オルトプラスAdvent Calendar 2023

Day 19

モックはChatGPTにサクッと作ってもらいましょう

Last updated at Posted at 2023-12-18

はじめに

こんにちわ。オルトプラスでサーバーサイドエンジニアやってます勝城です。

普段は社内プロジェクトでテックリードをしつつ、サーバーサイドエンジニアの採用担当をしております。

みなさん、ChatGPTを使っていますか?オルトプラスではaiラボというSlackチャンネルがあり、AI関する情報の共有等を積極的に行っています。

さて「モックはChatGPTにサクッと作ってもらいましょう」というタイトルにしましたが、ChatGPTでできることは自分でやる必要はなく、どんどん活用しませんかという布教記事です。

私はエンジニアですが、非エンジニアの方でもChatGPTを活用することでモックレベルなら簡単に作れてしまうでしょう。

この記事でやること

・ChatGPTを使ってローカル環境で動くモックを作る

この記事はこんな人におすすめ

・ChatGPTを活用したい方
・ChatGPTでできる一例を知りたい方
・非エンジニアで簡易なモックを作りたい方

本記事は オルトプラス Advent Calendar 2023 の12/19の記事です。

今年はCEDEC2023で登壇する機会があり、社内の活動やNFTゲーム開発のおける実装と運用のノウハウを紹介することができました。

講演資料はCEDEC Digital Libraryにアップロードされていますので、ご興味のある方はどうぞ。

結論

ローカルや開発環境で動かすモックレベルであれば、ChatGPTを使うことでわずかな時間で作ることができます。

ChatGPTを使うことで自分のやりたいこと、欲しい情報に最短でアクセスし実行可能です。

情報の取り扱いや精度には注意が必要ですが、ChatGPTでできてしまうことはとことん任せてしまって、貴重な時間を他にやるべきことに有効活用したいと思います。

概要

スクリーンショット 2023-12-12 10.37.41.png
ChatGPTを使ってFintech界隈でよく使用されるGo言語とbitFlyerが提供する公開APIを用いて、ビットコインのチャートをローカル環境のブラウザで表示する簡単なモックを作ってみました。

使用するもの

・ChatGPT4
・GoLand
・Go言語
・bitFlyerのHTTP Public API

手順1:ChatGPTにお願いする

スクリーンショット 2023-12-12 9.56.55.png

まずはシンプルにGo言語でbitFlyerのAPIを使ってビットコインの価格を取得したいとお願いしてみました。

するとChatGPTから次のような回答に。

スクリーンショット 2023-12-12 9.57.02.png

提示されたソースコード

main.go
package main

import (
	"encoding/json"
	"fmt"
	"net/http"
)

// TickerResponse はbitFlyerのAPIレスポンスを表します。
type TickerResponse struct {
	Last float64 `json:"ltp"`
}

func main() {
	url := "https://api.bitflyer.com/v1/getticker"
	resp, err := http.Get(url)
	if err != nil {
		panic(err)
	}
	defer resp.Body.Close()

	var ticker TickerResponse
	if err := json.NewDecoder(resp.Body).Decode(&ticker); err != nil {
		panic(err)
	}

	fmt.Printf("現在のビットコイン価格: %f\n", ticker.Last)
}

手順2:ChatGPTが生成したソースコードを実行する

  1. GoLandを開いてchatgpt_bitflyerというプロジェクトを作成
  2. main.goを作って、ソースコードをコピペ
  3. go run main.go
$ touch main.go
$ go run main.go
現在のビットコイン価格: 6103838.000000

ここまでわずか5分程度でビットコインの価格を取得できました。

単純な処理ですが、もし自分でやるとなると最低でも15分以上は必要だと思います。

手順3:もう少し複雑なことをお願いする

スクリーンショット 2023-12-12 11.35.04.png
次のビットコイン以外の価格も取得したいので、お願いしてみました。

するとChatGPTから次のような回答に。
スクリーンショット 2023-12-12 11.36.05.png

main.go
package main

import (
	"encoding/json"
	"fmt"
	"net/http"
)

// TickerResponse はbitFlyerのAPIレスポンスを表します。
type TickerResponse struct {
	Last float64 `json:"ltp"`
}

func getTicker(url string) (TickerResponse, error) {
	resp, err := http.Get(url)
	if err != nil {
		return TickerResponse{}, err
	}
	defer resp.Body.Close()

	var ticker TickerResponse
	err = json.NewDecoder(resp.Body).Decode(&ticker)
	return ticker, err
}

func main() {
	bitcoinURL := "https://api.bitflyer.com/v1/getticker?product_code=BTC_JPY"
	ethereumURL := "https://api.bitflyer.com/v1/getticker?product_code=ETH_JPY"

	bitcoinTicker, err := getTicker(bitcoinURL)
	if err != nil {
		panic(err)
	}

	ethereumTicker, err := getTicker(ethereumURL)
	if err != nil {
		panic(err)
	}

	fmt.Printf("ビットコイン価格: %f\n", bitcoinTicker.Last)
	fmt.Printf("イーサリアム価格: %f\n", ethereumTicker.Last)
}

実行結果

$ go run main.go
ビットコイン価格: 6097662.000000
イーサリアム価格: 325782.000000

処理が汎用的ではなかったので複数のproduct_codeを含むスライスを定義し、それぞれの通貨ペアの価格情報を取得するためにループを使用するようにお願いしてみました。

※本来はGET /v1/getmarketsエンドポイントを使用して、利用可能なproduct_codeを取得して各通貨ペアの価格情報を取得するコードを作成することができます。

main.go
package main

import (
	"encoding/json"
	"fmt"
	"net/http"
)

// TickerResponse はbitFlyerのAPIレスポンスを表します。
type TickerResponse struct {
	Last float64 `json:"ltp"`
}

func getTicker(productCode string) (TickerResponse, error) {
	url := fmt.Sprintf("https://api.bitflyer.com/v1/getticker?product_code=%s", productCode)
	resp, err := http.Get(url)
	if err != nil {
		return TickerResponse{}, err
	}
	defer resp.Body.Close()

	var ticker TickerResponse
	err = json.NewDecoder(resp.Body).Decode(&ticker)
	return ticker, err
}

func main() {
	productCodes := []string{"BTC_JPY", "ETH_JPY", "XRP_JPY"} // ここに必要な通貨ペアを追加

	for _, code := range productCodes {
		ticker, err := getTicker(code)
		if err != nil {
			fmt.Printf("%s の価格取得中にエラー: %s\n", code, err)
			continue
		}
		fmt.Printf("%s 価格: %f\n", code, ticker.Last)
	}
}

このように指摘や改善策を提示することでペアプログラミングのように実装することもできます。

手順4:ビットコインのチャートをブラウザで見れるようにお願いする

スクリーンショット 2023-12-12 10.37.41.png
この後も同様にChatGPTにお願いしてみると無事ビットコインのチャートを表示できました。

ここまで約15分程度です。

途中CORS errorになりその解決策を提示してくれたり、質問に対して意図した回答でなければ、詳細に質問してあげると正確な回答をもらえます。

これは人間同士と同じでこちらが欲しい情報に対して相手に伝わる適切な質問をすることを心がけると良いでしょう。

html/chart.html
<!DOCTYPE html>
<html>
<head>
    <title>ビットコイン価格チャート</title>
    <script src="https://cdn.jsdelivr.net/npm/chart.js"></script> <!-- Chart.jsライブラリ -->
</head>
<body>

<canvas id="myChart" width="400" height="400"></canvas>
<script>
    // ビットコイン価格データを取得する関数
    function fetchBitcoinData() {
        fetch('/api/bitflyer')
            .then(response => response.json())
            .then(data => {
                const price = data.ltp; // 最終取引価格
                const timestamp = new Date(data.timestamp); // タイムスタンプ

                updateChart(timestamp, price);
            })
            .catch(error => console.error('Error:', error));
    }

    // チャートを更新する関数
    function updateChart(timestamp, price) {
        if (chart.data.labels.length > 20) { // 保持するデータポイントの数を制限
            chart.data.labels.shift();
            chart.data.datasets[0].data.shift();
        }

        chart.data.labels.push(timestamp.toLocaleTimeString());
        chart.data.datasets[0].data.push(price);
        chart.update();
    }

    // チャートの初期化
    var ctx = document.getElementById('myChart').getContext('2d');
    var chart = new Chart(ctx, {
        type: 'line',
        data: {
            labels: [],
            datasets: [{
                label: 'ビットコイン価格 (JPY)',
                backgroundColor: 'rgba(255, 99, 132, 0.2)',
                borderColor: 'rgb(255, 99, 132)',
                data: []
            }]
        },
        options: {}
    });

    // 定期的にデータの取得とチャートの更新
    setInterval(fetchBitcoinData, 5000); // 5秒ごとに更新
</script>

</body>
</html>

chart.html は、ビットコインの価格チャートを表示するためのフロントエンドのページです。

このページでは、Chart.jsというJavaScriptライブラリを使用して、グラフの表示を行っています。

ページに含まれるJavaScriptコードは定期的に main.go のサーバー経由で /api/bitflyer エンドポイントにアクセスし、bitFlyerから取得したビットコインの価格情報を取得しています。

その後、このデータをチャートに反映させて現在のビットコインの価格動向を表示します。

main.go
package main

import (
	"io"
	"net/http"
)

func main() {
	// bitFlyer APIへのリクエストを処理するエンドポイント
	http.HandleFunc("/api/bitflyer", func(w http.ResponseWriter, r *http.Request) {
		// bitFlyer APIへのリクエスト
		resp, err := http.Get("https://api.bitflyer.com/v1/getticker?product_code=BTC_JPY")
		if err != nil {
			http.Error(w, err.Error(), http.StatusInternalServerError)
			return
		}
		defer resp.Body.Close()

		// レスポンスをクライアントに転送
		w.Header().Set("Content-Type", "application/json")
		w.Header().Set("Access-Control-Allow-Origin", "*")
		io.Copy(w, resp.Body)
	})

	// chart.html を配信するエンドポイント
	http.HandleFunc("/chart", func(w http.ResponseWriter, r *http.Request) {
		http.ServeFile(w, r, "html/chart.html")
	})

	// サーバーを起動
	http.ListenAndServe(":5000", nil)
}

main.goには2つの主要な機能があります。

1つ目は、bitFlyer APIへのプロキシエンドポイントとして機能する /api/bitflyer です。このエンドポイントは、内部でbitFlyerのgetticker APIを呼び出してビットコインの最新の取引価格情報を取得し、フロントエンドに返します。

2つ目は、/chart エンドポイントを通じて chart.htmlファイルをクライアントに配信する機能です。これによりブラウザでビットコインの価格チャートを表示するページにアクセスできます。

$ go run main.go
# http://localhost:5000/chartにアクセス

まとめ

この記事では、ChatGPTにビットコインのチャートを表示するモックを作ってもらました。

初めのビットコイン価格の取得はわずか5分、ビットコインのチャート表示は15分程度です。

今回は比較的作りやすいモックをお願いしているので短時間でしたが、それでも人間がやるよりは圧倒的に効率的だということが分かります。

エンジニアであればペアプログラミングのように精度の高いモックを効率的に作成できたり、非エンジニアでも対話形式で質問するだけで簡単なモックであれば作れてしまいます。

ChatGPTを使用に関するルールや制限に関して様々な議論があるものの、この先AIは切っても切れない関係になることは必然的です。

use AIからwith AIになる時代。ChatGPTでできることは自分でやる必要はなく、どんどん活用し貴重な時間を有効活用できればと思います。

参考

bitFlyer API

3
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?