3
3

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.

わがままゴルファーのためのLINE Bot

Last updated at Posted at 2023-11-20

1. ゴルフの要素って多くない!?

こんなどうでもいいことを友達に聞くのもアレなのでChatGPTに同意を求めてみた。
スクリーンショット 2023-11-20 224428.png
プレイするという観点からもゴルフは考えることが多くて複雑であると
改めて教えてもらった。

私が個人的にゴルフをしていく上で気になるのは

  • どうやって練習したらいいのか
  • ラウンドに必要なものは揃っているか
  • 予約はどうやって取ればいいか
  • ラウンドの日の天気はいいのか
    などである。

もちろん時間をかければわかる。

練習の情報もあふれているが、取捨選択の時間があれば
必要で効率のよい練習方法にたどり着けるだろう。

ラウンド前に必要なものが足りていなければ
買いに行けばいい。

ゴルフ場に電話したり
アプリを使えば予約もできる。

ラウンド当日の天気も
webで予報を見ればわかる。

しかし!

やること多すぎないか。
忘れてしまうことや
抜け落ちてしまうことも
ありそうじゃないか。

誰かまとめてくれー!

そうだ。LINE Botでまとめてしまおう。

2. ゴルファー(自分)のためのLINE Botが完成した

PushMessageでテキストを送るコード
'use strict';

const line = require('@line/bot-sdk');
// const dotenv = require('dotenv'); // dotenv使うときにコメントアウト外してください
// dotenv.config();

// Messaging APIを利用するための鍵を設定します。
const config = {
  channelSecret: process.env.CHANNEL_SECRET || '**********',
  channelAccessToken: process.env.CHANNEL_ACCESS_TOKEN || '***********',
};
const client = new line.messagingApi.MessagingApiClient(config)

const main = async () => {

    const messages = [{
        type: 'text',
        text: 'ナイスショット!\nいい調子だね!'
    }];

    try {
        const res = await client.broadcast({messages});
        console.log(res);        
    } catch (error) {
        console.log(`エラー: ${error.statusMessage}`);
        console.log(error.originalError.response.data);
    }
}

main();
PushMessageでスタンプを送るコード
'use strict';

const line = require('@line/bot-sdk');
// const dotenv = require('dotenv'); // dotenv使うときにコメントアウト外してください
// dotenv.config();

// Messaging APIを利用するための鍵を設定します。
const config = {
  channelSecret: process.env.CHANNEL_SECRET || '********',
  channelAccessToken: process.env.CHANNEL_ACCESS_TOKEN || '*********',
};
const client = new line.messagingApi.MessagingApiClient(config)

const main = async () => {

    const messages = [{
        "type": "sticker",
        "packageId": "1070",
        "stickerId": "17849"
      }];

    try {
        const res = await client.broadcast({messages});
        console.log(res);        
    } catch (error) {
        console.log(`エラー: ${error.statusMessage}`);
        console.log(error.originalError.response.data);
    }
}

main();
自動的にゴルフ関連の返答を返すコード
'use strict';

// ########################################
//               初期設定など
// ########################################

// モジュールの読み込み
const line = require('@line/bot-sdk');
const OpenAI = require('openai');
const express = require('express');
// const dotenv = require('dotenv'); //dotenv使うときはコメントアウト外してください
// dotenv.config();

// 設定
const config = {
  channelSecret: process.env.CHANNEL_SECRET || '**********',
  channelAccessToken: process.env.CHANNEL_ACCESS_TOKEN || '**********',
};

// GPTのAPIKEY
const apiKey = process.env.OPENAI_API_KEY || '**********';
const openai = new OpenAI({apiKey});

const makeCompletion = async (userMessage) => {
  const prompt = {
      role: "system", 
      content: "ゴルフに関連させて答えてください" // プロンプトを入力
  };

  const sendMessage = [prompt, userMessage]
  console.log(sendMessage);
  return await openai.chat.completions.create({
    messages: sendMessage,
    model: "gpt-3.5-turbo-1106",
  });
};

const client = new line.messagingApi.MessagingApiClient(config);
// メッセージイベントの処理
async function handleEvent(event) {
  // テキストメッセージ以外は無視
  if (event.type !== 'message' || event.message.type !== 'text') {
    return Promise.resolve(null);
  }

  const userMessage = {
    role: "user",
    content: event.message.text
  };

  // ChatGPT APIにリクエストを送る
  try {
    const completion = await makeCompletion(userMessage);
    // レスポンスから返答を取得
    console.log(completion.choices[0].message.content); // レスポンスをみたいときにコメントアウトを外してください
    const reply = completion.choices[0].message.content;
    // 返答をLINEに送る
    return client.replyMessage({
      replyToken: event.replyToken, 
      messages:[{
        type: 'text',
        text: reply
      }]
    });
  } catch (error) {
    // エラーが発生した場合はログに出力
    console.error(error);
    return Promise.resolve(null);
  }
}
//以下サーバーを使うためのコード
const port = process.env.PORT || 3000;
const app = express()
  .get('/', (_, res) => res.send('hello LINE Bot'))
  .post('/webhook', line.middleware(config), (req, res) => {
    if (req.body.events.length === 0) {
      res.send('Hello LINE BOT! (HTTP POST)');
      console.log('検証イベントを受信しました');
      return
    } else {
      console.log(req.body.events);
    }
    Promise
      .all(req.body.events.map(handleEvent))
      .then((result) => res.json(result));
  })
app.listen(port);
console.log(`PORT${port}番でサーバーを実行中です`)
リッチメニューの実装

231121ラインスクショ3.jpg

LINE Botとの会話

231121ラインスクショ1.jpg

231121ラインスクショ2.jpg

すごい!!
LINEのリッチメニューから練習のためになる動画を見に行けて
足りなくなったボールやティーなどをオンラインで購入しに行けて
ゴルフ場の予約を取りにWebサイトに行けて
天気を簡単に出してくれる。

会話の内容はすべてゴルフに紐づけられる。
自然とゴルフのモチベーションが上がること間違いなし!

LINEの友達が
自分の好きなことに関連した
超便利なLINE Botだけになる日も近い。

3. LINE Bot作成の手順

  • LINE Developersにログイン
  • プロバイダーを作成
  • リッチメニューを作成
  • ChatGPTのAPIを利用
  • チャネルシークレットやアクセストークンのコードへの組み込み

3-1. LINE Developersにログインする。

スクリーンショット 2023-11-21 005916.png

ここで新規にプロバイダーを作成する。

3-2. リッチメニューを作成する

このWebサイトを参考にオリジナルのリッチメニューを作成することができる。
画像やイラストを用意しておくとよりオリジナリティーが出る。

3-3. ChatGPTのAPI利用

超絶わかりやすく解説してくれている記事なので参考にして
ChatGPT/OpenAIのAPIを利用できるようにAPIキーを発行する。

3-4. コードに必要な情報を組み込む

プッシュメッセージでテキストやスタンプを送るには

const messages = [{
        type: 'text',
        text: 'ナイスショット!\nいい調子だね!'
    }];
const messages = [{
        "type": "sticker",
        "packageId": "1070",
        "stickerId": "17849"
      }];

コードのこれらの部分を変えることで可能だ。
スタンプの情報は以下のページに詳しく記載されている。

ChatGTPの応答能力にプロンプトを加えることで
返答内容に味をつけることができる。

const makeCompletion = async (userMessage) => {
  const prompt = {
      role: "system", 
      content: "ゴルフに関連させて答えてください" // プロンプトを入力
  };

今回は返答内容をすべてゴルフに関連するように指示をしてみた。
結果的には何を話しているかわからないような内容でもゴルフのことだと認識して
返事をしてくれるようになった。

まさにゴルフのためだけの
いや、私のためだけのLINE Botである。

4. まとめ

  • LINE Botは大多数の人に情報発信をしていくツールとして便利である。
  • テキスト形式の情報であれば簡単に発信ができる。
  • 自分好みにカスタマイズができる。
  • 欲しい分野の情報をすぐに受け取れる形の自分好みのLINE Botを個人利用するという選択肢もある。
  • 必要な情報が多く煩雑な分野について情報を整理しておくことができる。
  • ChatGPTの実装により指定した分野に関する対話をLINE上でパーソナリティのない相手とできる。
  • 情報があふれて増加していく社会の中でこういったLINEBotはその情報に制限をかけてくれる。

こんなわがままLINEBotの友達は私しかいない

3
3
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
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?