初心者でもできる!Google Apps Scriptでスプレッドシートのテーブルデータを簡単に取得する方法

パソコンパソコン・スマホ教室
スポンサーリンク

Google スプレッドシートに入力されたデータを、Google Apps Script(GAS)を使って効率的に扱いたいと思ったことはありませんか?特に、テーブル形式で整理されたデータをプログラムで取得・操作する方法は、業務効率化や自動化に非常に役立ちます。今回は、初心者の方でもわかりやすいように、GASを使ってスプレッドシートのテーブルデータを取得する方法を解説します。

スポンサーリンク

GASでスプレッドシートのテーブルデータを取得する基本の流れ

Googleスプレッドシートのイメージ

Googleスプレッドシートのイメージ

まずは、スプレッドシートからデータを取得する基本的な流れを押さえておきましょう。

  1. スプレッドシートを開く
  2. 対象のシートを選択する
  3. データ範囲を指定して取得する

具体的なコード例を見てみましょう。

function getData() {
const ss = SpreadsheetApp.getActiveSpreadsheet(); // スプレッドシートを取得
const sheet = ss.getSheetByName("Sheet1"); // シート名「Sheet1」を取得
const data = sheet.getDataRange().getValues(); // データ範囲を取得
Logger.log(data); // ログに出力して確認
}

このコードでは、現在開いているスプレッドシートから「Sheet1」を取得し、そのシートのデータ範囲を取得しています。取得したデータは二次元配列として格納され、ログに出力されます。

テーブルデータをオブジェクト形式で取得する方法

取得したデータをそのまま扱うのも良いですが、よりわかりやすく操作するためには、オブジェクト形式で取得する方法がおすすめです。以下のコード例では、ヘッダー行をキーとして、各行のデータをオブジェクトとして取得しています。

function getTableData() {
const ss = SpreadsheetApp.getActiveSpreadsheet();
const sheet = ss.getSheetByName("Sheet1");
const values = sheet.getDataRange().getValues();
const headers = values.shift(); // ヘッダー行を取得
const data = values.map(row => {
let obj = {};
row.forEach((cell, i) => {
obj] = cell;
});
return obj;
});
Logger.log(data); // ログに出力して確認
}

この方法では、例えば以下のようなデータが取得できます。

[
{ID: 1, 名前: "田中", メール: "tanaka@example.com"},
{ID: 2, 名前: "佐藤", メール: "sato@example.com"}
]

このように、データをオブジェクト形式で取得することで、各項目に名前でアクセスできるようになり、コードの可読性が向上します。

複数条件でのデータ検索方法

取得したデータから特定の条件に合致するものを検索したい場合、以下のようなコードで実現できます。

function searchData() {
const ss = SpreadsheetApp.getActiveSpreadsheet();
const sheet = ss.getSheetByName("Sheet1");
const values = sheet.getDataRange().getValues();
const headers = values.shift();
const data = values.map(row => {
let obj = {};
row.forEach((cell, i) => {
obj] = cell;
});
return obj;
});

const result = data.filter(item => item.名前 === "田中" && item.メール === "tanaka@example.com");
Logger.log(result); // ログに出力して確認
}

このコードでは、名前が「田中」でメールが「(mailto:tanaka@example.com)」のデータを検索しています。`filter`メソッドを使用することで、複数の条件に合致するデータを簡単に取得できます。

よくある質問や疑問

Q1: GASのスクリプトエディタはどこから開けますか?

スプレッドシートを開いた状態で、上部メニューの「拡張機能」から「Apps Script」を選択すると、スクリプトエディタが開きます。

Q2: データを取得する際、特定の列だけを取得することはできますか?

はい、`getRange`メソッドを使用して、特定の範囲を指定することで、必要な列だけを取得することができます。

Q3: 取得したデータを別のシートに書き込むことはできますか?

はい、`setValues`メソッドを使用することで、取得したデータを別のシートに書き込むことができます。

今すぐ解決したい!どうしたらいい?

LINE公式

いま、あなたを悩ませているITの問題を解決します!
「エラーメッセージ、フリーズ、接続不良…もうイライラしない!」

あなたはこんな経験はありませんか?

✅ ExcelやWordの使い方がわからない💦
✅ 仕事の締め切り直前にパソコンがフリーズ💦
✅ 家族との大切な写真が突然見られなくなった💦
✅ オンライン会議に参加できずに焦った💦
✅ スマホの重くて重要な連絡ができなかった💦

平均的な人は、こうしたパソコンやスマホ関連の問題で年間73時間(約9日分の働く時間!)を無駄にしています。あなたの大切な時間が今この悩んでいる瞬間も失われています。

LINEでメッセージを送れば即時解決!

すでに多くの方が私の公式LINEからお悩みを解決しています。

最新のAIを使った自動応答機能を活用していますので、24時間いつでも即返信いたします。

誰でも無料で使えますので、安心して使えます。

問題は先のばしにするほど深刻化します。

小さなエラーがデータ消失重大なシステム障害につながることも。解決できずに大切な機会を逃すリスクは、あなたが思う以上に高いのです。

あなたが今困っていて、すぐにでも解決したいのであれば下のボタンをクリックして、LINEからあなたのお困りごとを送って下さい。

相談しに行く

ぜひ、あなたの悩みを私に解決させてください。

まとめ

Google Apps Scriptを使うことで、スプレッドシートのデータを効率的に取得・操作することができます。初心者の方でも、基本的なコードを覚えることで、業務の自動化や効率化に役立てることができます。ぜひ、今回紹介した方法を試してみてください。

他にも疑問やお悩み事があれば、お気軽にLINEからお声掛けください。

コメント

タイトルとURLをコピーしました