0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Xplenty : Google Sheetからデータを取得する

Last updated at Posted at 2020-10-19

このブログではXplentyのRest API Componentを使用して、Google Sheetからデータを読み込む方法について解説します。

#Rest API コンポーネントの設定

##認証(Authentication)の設定
あらかじめ接続画面で作成したGoogle Sheetの認証を選択する。
image.png

##URLの指定方法

URL:
https://sheets.googleapis.com/v4/spreadsheets/シートID/values:batchGet?ranges=セル範囲&majorDimension=ROWS

  • シートID:
    Google SheetのURLからシートIDを取得
    image.png

  • セル範囲:
    例)A1:G1000 (A列の1行目からG列の1000行目まで)

##Responseの設定
「$..values[*]」と入力
image.png

##フィールドの選択
image.png

#取得したJSONのフラット化
##変換1:BAG型からTuple型に変換する
Selectコンポーネントを使用し、BagToTuple関数を使いTuple型に変換する
image.png

##変換2:各列を配列番号を指定し、それぞれ取得する
それぞれの列を配列番号($0)を指定し取得するとともに、Chararray関数で文字列型に変換する
image.png

##ヘッダ行をフィルターで除外
1行目にヘッダ行が含まれている場合、フィルタで除外する(Rest API側のセルの範囲指定でヘッダ行を除外する方法もあり。)
(例)id列に「Id」という文字が含まれていないデータのみ抽出
image.png

#ロード先のコンポーネントをセットし、ジョブを実行して確認
最後にデータベース、DWH、ストレージなどにロードすれば完了です。
##パッケージ全体図
例)Snowflakeがロード先の場合、以下のようなフローになります。
image.png

##データが正しく反映されたことを確認
image.png

#Google Sheetへの書き込みも可能です
Xpelntyでは、Selectコンポーネントの中でCurlリクエストを書くことで、Google Sheetへの書き込みが可能です。
image.png

書き込みリクエスト例:
CCurl(CONCAT('https://sheets.googleapis.com/v4/spreadsheets/', '$spreadsheetId', '/values:batchUpdate'),'POST','{"Accept":"application/json"}',CONCAT('{"valueInputOption":"RAW","data":[{"range":"','$range','","majorDimension": "ROWS","values": [', BagToString(data, ','), ',]}]}'), '$connection_id')

上記リクエストで使用している変数について

  • $spreadsheetId:GoogleSheetのIDを指定
  • $connection_id:XplentyのコネクションIDを指定 (コネクション画面で確認することができます。)
    例:GOOGLESHEETS_CONNECTION_9215
  • $range:シート名およびセル範囲を指定。
    例:campaign!A1:N100000
0
0
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
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?