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

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

新規登録して質問してみよう
ただいま回答率
85.47%
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google Apps Script

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

Q&A

解決済

2回答

200閲覧

GASで1行の実績を複数行に分割したい

yuki996014

総合スコア2

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google Apps Script

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

0グッド

1クリップ

投稿2024/02/14 03:16

### 実現したいこと
①変形前の表
イメージ説明

②変形後の表
イメージ説明

プレッドシートで①のようなデータを、②のようなデータに変形したいです。

※A-B列に空白は存在しません
※1行すべてが空白のデータも存在する可能性があります
※行数はデータの蓄積で増加します
※列はこれ以上増えない予定です
※変形後の結果は別シートに出力したいです

### 環境
・googleスプレッドシートにて実施

類似の情報がないか探したり、自身で作成もしてみましたが、実現することができませんでした。ご教授よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

※行数はデータの蓄積で増加します

データを頭から記入するのではなく、
なんらかの方法で対象データを選択して、
行末に追記していく方法をお望みですか?

投稿2024/02/14 09:01

YellowGreen

総合スコア731

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

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

0

ベストアンサー

次のようなスクリプトが参考になるでしょうか。
3列目以降の列数が増えても構いませんが、
罫線の処理はしていません。

JavaScript

1// 3列目以降のデータを行データに分割 2function sample20140214() { 3 // 初期設定 4 const ss = SpreadsheetApp.getActiveSpreadsheet(); 5 const sheetFrom = ss.getSheetByName('シート1'); 6 const sheetTo = ss.getSheetByName('シート2'); 7 const dataColumn = 3; // 行に分割するデータの開始列 8 9 // データを取得し見出しから項目名を取り出す 10 const values = sheetFrom.getDataRange().getValues(); 11 const titles = values.shift(); // 見出し行を分離 12 const items = titles.slice(dataColumn - 1); // 3列目以降の項目名を取得 13 14 // データを加工 15 const data = []; 16 for (const value of values) { 17 const key = value.splice(0, dataColumn - 1); // 最初の2項目を分離 18 // 3項目以降のデータがあれば、記入用データに蓄積 19 value.forEach((item, i) => { 20 if (+item > 0) { 21 data.push([...key, items[i], item]); 22 } 23 }); 24 } 25 26 // シートに記入 27 if (data.length > 0) { 28 sheetTo.clearContents(); // シートをクリア 29 data.unshift(['日時', '人', '項目', '数量']); // 見出しを加える 30 sheetTo.getRange(1, 1, data.length, data[0].length).setValues(data); 31 } 32}

投稿2024/02/14 08:22

編集2024/02/14 21:07
YellowGreen

総合スコア731

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

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

yuki996014

2024/02/15 00:56

返信が遅くなり申し訳ありません。 上記コードを実際に走らせてみたところ、思った通りの動作が実現できました。 本当にありがとうございます 行数が増えたときなどに対応できるよう、頂いた物を参考にしつつ、近いしながら引き続きテストしたいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問