2
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【家事時短】10分で作れる!ChatGPTシェフによる献立提案アプリ! #Make

Last updated at Posted at 2023-12-03

今日の夕飯何作ろう?

夕飯のメニューを考える。それは誰しもに等しく訪れる毎日のタスクです。
1日10分でも毎日となるとそれなりの時間になりますし、結局同じメニューになりがち・・・

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

ここはもうAIに任せてしまっても良くないでしょうか!!
その方が時短にもなるし、夕飯のバリエーションも増えるし、一石二鳥!!
という事でITの力を借りて家庭の課題を解消させてみようと思います!

日々のお仕事が忙しい方ご飯のメニューを考えるのが苦手な方に使ってもらえるアプリを目指します!!

【実装目標】
・ ChatGPTで考えたメニューをLINEで通知する
・ いくつかの食材候補からランダムで選択した食材を使う料理を提案する
・ 毎日定刻(帰宅時間の17時頃)にメニューを通知する

作ったものはこちら!

1IMG_E0811.jpg

間違えました!これはChatGPTに提案されて作ったチキンテリヤキ丼です!

本当に作ったものはこちらです!
スケジュールした時間になるとChatGPTが夕飯のメニューを提案してLINEで通知してくれます!

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

他のレシピAPIとは異なる点として、ChatGPTであれば一度に複数のメニュー候補を出してくれますし、どんな食材であってもメニューの候補を出してくれる点が強みとなります!!

構成イメージは以下の通りです。

image.png

用意するモノ

今回使用したは以下の通りです。
・Make(Webhooks / OpenAI(ChatGPT)/ LINE)
・GoogleAppsScript

作り方を紹介!

①Makeの作成

1. Webhookの設定

● まずはMakeのシナリオから、[Webhook]部分の実装説明となります。

image.png

● [Webhook]のトリガーを選択して、[Custom webhook]を追加します。

image.png

● [Add]ボタンから[Create a webhook]を表示し、設定は変更せずにSaveを選択します。

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

● webhookのURLが発行されるため、[Copy address to clipboard]を選択してURLを保存します。
保存が完了したら[OK]を選択します。

image.png

2. OPENAIの設定

● 次に[OpenAI]部分の実装説明となります。

image.png

● 事前準備として、ChatGPTにログインして、APIキーとOrganization IDを取得します。
※ChatGPTの登録が未了の場合は登録作業から実施してください※

■APIキー
● 画面左の[API keys]を選択後、[+ Create new secret key]を選択してAPIキーを取得します。

image.png

■Organization ID
● 画面左の[Settings]-[Organization]を選択後、Organization IDの値を取得します。

image.png

● Makeより、[OpenAI]のトリガーから[Create a Completion]を追加します。

image.png

● connectionの[Add]を選択し、事前に取得したAPIキーとOrganization IDを入力して[Save]を選択します。

image.png

● その他項目は以下の画面の通りに設定します。([Messages]の箇所は、利用環境に合わせて変更してください)

image.png

3. LINEの設定

● 次に[LINE]部分の実装説明となります。

image.png

● Makeより、[LINE]のトリガーから[Send a Notification]を追加します。

image.png

● connectionの[Add]を選択し、変更はせずに[Save]を選択します。

image.png

● 別ウインドウでLINEの認証を求められるため、任意の方法でログオンします。

image.png

● 任意の通知を送信するトークルームを選択して、同意して連携するを選択します。

image.png

● [Message]の箇所を画面の通りに設定して[OK]を選択します。

image.png

4. スケジュール設定

● Makeのシナリオ画面左下より、[SCHEDULING]を[ON]に設定して、[immediately as date arrives]に設定します。(データが届いたら即時実行される設定です)

image.png

②GoogleAppsScriptの作成

1. コーディング

● GoogleAppsScriptのコードは以下の通りです。
webhookURLは上記手順で保存したURLを張り付けてください。

script.gs
  //今日の夕飯BOT
function foodmenu() {

  //makeのwebhookのURL設定
  const url = "https://hook.eu2.make.com/xxxxxxxxxxxxxxxxxxxxxxxxxx";

  //アクティブなシートを取得
  const sheet = SpreadsheetApp.getActiveSheet();

  //夕飯のメインとなる食材を指定
  const food = ["牛肉","豚肉","鶏肉","","野菜"];

  //食材をランダムで選択
  const sendfood = food[Math.floor(Math.random()*food.length)];
  console.log(sendfood);

  //makeのwebhookを実行
  UrlFetchApp.fetch(url + encodeURIComponent(sendfood));
    
}

2. スケジュール設定

● GoogleAppsScriptの画面左より、[トリガー]を選択します。

image.png

● トリガーの追加を選択して、以下の通り設定を行います。
[時間ベースのトリガーのタイプを選択]と[時刻を選択]は利用環境に合わせて変更してください。

image.png

【補足事項】
今回はWebhookをトリガーにしましたが、LINEのメッセージ送信をトリガーにすることで、自身が指定した食材からメニューの候補を考えるようにアレンジする事も可能です!

作ってみた感想

MakeとGoogleAppsScriptのスケジューリング機能が非常に便利!!
そしてChatGPTのご飯提案が面白い!! ビーフストロガノフなど、そんなん作れんわ!って提案もあったりしますw

一方で以下のような課題も見つかりました。

・ 毎回提案のレベルが異なる
   - 調理手順を含んだり含まなかったり
   - 主菜以外、副菜や汁物まで提案してくれたりしなかったり
・ 同じメニューの提案をする確率が高い

ただ、毎日メニューを複数候補で提案してくれる点はありがたく、これ作ってみたいな!明日何提案してくれるかな!という楽しみができました!料理のレパートリーが増える点もGOOD!

10分程度で作れるため、毎日のレシピに悩んでいる方がいればぜひ使ってみてください!!

2
1
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
2
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?