質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
Google Cloud Storage

Google Cloud Storageは、グーグル社が提供しているクラウドベースのデベロッパー・企業向けストレージサービス。可用性に優れ、APIで操作可能なため、データのアーカイブ保存やアプリケーションのコンテンツ提供など様々な用途に活用できます。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

460閲覧

Googleスプレッドシートの値を種類別に合算する

mbcztpw

総合スコア30

Google Cloud Storage

Google Cloud Storageは、グーグル社が提供しているクラウドベースのデベロッパー・企業向けストレージサービス。可用性に優れ、APIで操作可能なため、データのアーカイブ保存やアプリケーションのコンテンツ提供など様々な用途に活用できます。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

1クリップ

投稿2023/05/16 09:46

下記のように倉庫別に入出庫の数を計算するプログラムを作成しています。
まず一か月の期間で計算するものを作りました。

GAS

1function warehouseCalc() { 2 const ss = SpreadsheetApp.getActiveSpreadsheet(); 3 const st = ss.getSheetByName("倉庫"); 4 const warehouseA = { 5 loading: 0, 6 unloading: 0, 7 }; 8 const warehouseB = { 9 loading: 0, 10 unloading: 0, 11 }; 12 const warehouseC = { 13 loading: 0, 14 unloading: 0, 15 }; 16 const data = st.getRange(2, 1, st.getLastRow() - 1, st.getLastColumn()).getValues(); 17 let warehouse; 18 for (let i = 0; i < data.length; i++) { 19 switch (data[i][0]) { 20 case "A": 21 warehouse = warehouseA; 22 break; 23 case "B": 24 warehouse = warehouseB; 25 break; 26 case "C": 27 warehouse = warehouseC; 28 break; 29 } 30 if(data[i][2]=="入庫"){ 31 warehouse.loading += data[i][3]; 32 } else { 33 warehouse.unloading += data[i][3]; 34 } 35 } 36 console.log(warehouseA,warehouseB,warehouseC) 37}

イメージ説明

次いで前月と来月の分も計算する必要があるので編集しようとしたのですが、先に進めなくなりました。
どうプログラムを変更したら良いでしょうか。よろしくお願いします。
イメージ説明

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

元のスクリプトをできるだけそのままの形で各月の入出庫数を集計できるようにしたスクリプトの例です。
入庫、出庫ともに4月から3月までの配列として集計するようにしてあります。

JavaScript

1function warehouseCalc() { 2 const ss = SpreadsheetApp.getActiveSpreadsheet(); 3 const st = ss.getSheetByName("倉庫"); 4 //4月から3月までの各倉庫の入出庫数の配列[4月, 5月, ... 2月, 3月]を用意 5 const warehouseA = { 6 loading: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 7 unloading: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 8 }; 9 const warehouseB = { 10 loading: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 11 unloading: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 12 }; 13 const warehouseC = { 14 loading: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 15 unloading: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 16 }; 17 const data = st.getRange(2, 1, st.getLastRow() - 1, st.getLastColumn()).getValues(); 18 let warehouse; 19 for (let i = 0; i < data.length; i++) { 20 switch (data[i][0]) { 21 case "A": 22 warehouse = warehouseA; 23 break; 24 case "B": 25 warehouse = warehouseB; 26 break; 27 case "C": 28 warehouse = warehouseC; 29 break; 30 } 31 //日付の月から配列のインデックスを生成(4月 -> 0, ... 3月 -> 11) 32 const month = new Date(data[i][1]).getMonth(); 33 const index = month < 3 ? month + 9 : month - 3; 34 if(data[i][2]=="入庫"){ 35 warehouse.loading[index] += data[i][3]; 36 } else { 37 warehouse.unloading[index] += data[i][3]; 38 } 39 } 40 console.log(warehouseA); 41 console.log(warehouseB); 42 console.log(warehouseC); 43}

投稿2023/05/17 06:04

YellowGreen

総合スコア791

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mbcztpw

2023/05/17 06:27

ありがとうございます。配列を利用する方法があるのですね。
guest

0

先に進めないとはどういう意味でしょう?
月別に集計できないという意味でしょうか?

そういう意味でしたら連想配列を使ったりするといいかもです。

let data = {}; data["4月"] = [warehouseA, warehouseB, warehouseC]; data["5月"] = [warehouseA, warehouseB, warehouseC];

とか

投稿2023/05/16 14:08

kzy53

総合スコア32

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mbcztpw

2023/05/17 06:11

ありがとうございます。連想配列も検討します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問