食事の管理と計算を簡易化したい
在宅で順調にデブったので人生初の食事管理に取り組んでみたのですが、食品のカロリーや栄養素を教えてくれるサイトやサービスが微妙に自分に合わなかったのでシンプルな計算機をSpreadsheetとGASで自作しました。自分に合わなかったのは以下のような点です。
- 一人前表示だったり、グラム表示だったり、微妙に各サービスによって単位が違う
- 100gあたりのカロリー表示が多く、毎回食べた量から計算しないといけない
- 食品が見つからないこともある
- 頻繁に食べるものを自分で登録しておけない

作ったもの
要は食事したときはおおよそ「これをこれだけ食った」しか認識・記憶できないので、まずこれ。
- 食べたものと食べた量を入力したらあとは自動でやってくれる
次に入力の手間を省きたいのでこれ。
- 食品を自分で自由にリスト登録できる
頭のいい人は画像認識とかAIとかでやってください。
技術要素
- セルにドロップダウンリストを作る
- Spreadsheetのデータを取得してGoogleAppScriptで使う
- シートのデータを配列に入れる、取り出す
結果
- いちいち食品のカロリーを調べなくて済むようになった、時短
- 自分だけの食品データベースを作れてわかりやすくなった、拡張性ばっちり
- 記録が継続しやすく、体重変化等と合わせると改めて自分の代謝量などが把握できるように
実装
- データベース(リスト)作成
「List」とシート名をつけて、適当に食べたものなどをもりもりいれます。B列には1グラム当たりのカロリーを入れていきます。だいたいの栄養系のサイトは100gあたりのカロリー表示なので、それらを100で割った値です。

- プルダウンメニュー作成
食事記録用のシート、例えば「202005」を作成して、食品のプルダウンを表示したいセルを右クリック、「データの入力規則」を選択。



- プログラム作成
- 準備
ツール>スクリプトエディタを選択、エディタ画面を表示します。
プルダウンの選択やグラム入力をトリガーとして計算を走らせたいので、スクリプトエディタ上部のメニューから「トリガー」ボタンをクリック。
「トリガーを追加」ボタン>イベントの種類を選択>変更時とすることで、シート上の値が変更されたタイミングでスクリプトが実行されるようになります。
次にSpreadsheetに対してScriptからのアクセスを許可を確認するダイアログがでますので以下の手順でオーソライズしていきます。まずGoogleにログイン。ログインに使うアカウントを選択。
次に今作成中のScriptのシートへのアクセス許可を与えていきます。詳細をクリック。
「calorie(作成中のScript)に移動」をクリック。
こんな感じで「ScriptからシートにアクセスしますけどOK?」という意味合いのダイアログがでるので許可。これでシートとScriptが連動して動くようになります。食品を入力したり、グラム数を入力したタイミングでScriptが実行されます。
- コード
function myFunction() {
//変更したセルの値の取得
var ss = SpreadsheetApp.getActiveSheet();
var currentRow = ss.getActiveCell().getRow();
var currentColumn = ss.getActiveCell().getColumn();
var currentCell = ss.getActiveCell().getValue();
//グラム数を入力したときの値を取得
var amount=ss.getRange('C'+ currentRow);
amount=amount.getValue();
//計算後に入力されるカロリーのセルを定義
var calorieCell=ss.getRange('D'+ currentRow);
//Listシートのデータを配列に入れる
var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
var list = spreadsheet.getSheetByName('List');
var lastRow = list.getLastRow();
var value = list.getDataRange().getValues();
//取得した二次元配列内の検索用に食品名だけの配列も作る
var name = list.getRange(1, 1, lastRow).getValues();
name=name.flat();//二次元配列を一次元化。ここで結構ハマった。
//プルダウンから選択した食品のカロリーをListシートの中から検索
var food=ss.getRange('B'+ currentRow);
food=food.getValue();
foodIndex=name.indexOf(food);
foodIndex=parseInt(foodIndex);
var calorieValue=value[foodIndex][1];
//グラム数と1グラム当たりのカロリーを乗算
var calorieSum=amount*calorieValue;
//見出し行や食品名・グラムのセル以外の変更を除外
if(currentRow>1){
if(currentColumn==2.0 || currentColumn==3.0){
calorieCell.setValue(calorieSum);//計算結果がカロリーのセルに入る
}
}
}
まとめ
Spreadsheetで簡単に拡張できるカロリー計算機ができました。プログラムに興味のない方はコピペで。Listの方にPCFカラム、ビタミン・ミネラルのカラムを作っても面白いと思います。