Google ドキュメントのスプレッドシートのデータを変換して Firebase に読み込む

広告:超オススメUnity Asset
  広告:超オススメUnity Asset

Firebaseのデータベースのことについてはまだ何も書いていないのですが、その先でFirebaseにデータを持ってくる方法としてどういう流れがあるのかを試してみます。

Googleドキュメントは、複数人で同時に同じデータを編集するにはとても便利なサービスですね。ここに作り上げたデータをFirebaseに持っていくには、書き出した後、JSON形式にしてインポートする必要があります。いくつか方法はあると思いますが、とりあえずこんな方法でうまくいったのでMEMOしておきます。

スプレッドシート上にデータを作成。一番上の行はアルファベットでキー名を名付けておきます。ここがJSONの各キーになります。
「ファイル>形式を指定してダウンロード>カンマ区切りの値(.csv、現在のシート)」を選ぶと、csvファイルがダウンロードフォルダにダウンロードされます。

00

csvをjsonに変換する方法はたくさんあると思いますが、僕はこのユーティリティを使いました。

01

先ほどダウンロードしたcsvを選択して、fromをcsv、toをJSONにして「Convert」

02

各キーに対して型を細かく設定できますが、僕はたいていのものはStringにして、アプリの方で型変換しちゃいます。

03

OKを押してjsonファイルの保存先を指定して保存。

04

次にFirebaseの方でこのJSONをインポートしてみます。Firebaseのインポートは一見ややこしいのですが、「読み込みたい階層に移動してからその階層以下をごっそり読み込んだJSONで上書きする」と思っておけばいいと思います。ここが少し変わってるので、最初はわかりにくいですね。例えば、ルートにあるdata/questions以下の階層に読み込みたい場合、まず、「questions」部分をクリックして、その階層に入ります。

05

階層に入った後、「・・・」部分のメニューから「JSONをインポート」を選びます。

06

「閲覧」を押して、

07

先ほど作成したJSONファイルを選択。

08

「インポート」を押すと、その階層にあったデータがごっそり消えて、インポートしたJSONが読み込まれます。

09

では、存在していない階層に読み込みたい場合はどうするか。例えば、ルートにdataという階層を作って、そのdata以下に読み込んでみます。

下の例の場合、ルートで読み込んでしまうと、「users」という階層がなくなってしまいます。なので、いったん、dataという階層を作ります。「+」を押すとその階層に新しく階層を作れます。

10

名前に「data」と入れて、値は適当に「0」とか何か入れて作ればいいと思います。ここで「追加」を押してdata階層を作れば、その階層に入ることができます。(値の0というのはダミーのようなもんです)

11

data部分をクリックして、data階層に入ります。

12

ここでインポートを行えば、ダミーで入れた「0」は消えて、この階層にJSONデータが入ってきます。

13

JSON形式が正しく作成されていれば、「データが正常にインポートされました」というメッセージが出て、データが読み込まれていることも確認できます。(「#text」といった記号付きのキー名があったりするとエラーが出ますので注意です)

14

配列を読み込むと数値がキー名となったツリー構造となっていることが確認できます。開いてみると、Googleドキュメントのスプレッドシートの1行目をキー名としたデータが読み込まれていることが確認できると思います。

15

とりあえず、これで読み込めたので、Googleドキュメントの方を更新した場合、まったく同じプロセスでデータ変換、インポートすれば、いつでもこの場所のデータを更新できるでしょう(手動ですが。。)

スポンサーリンク