SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

Zend FrameworkでGoogleアプリケーションを使い倒す

PHPアプリでGoogle Spreadsheetをデータベースとして利用しよう

Zend FrameworkでGoogleアプリケーションを使い倒す(5)


  • X ポスト
  • このエントリーをはてなブックマークに追加

明細書データの登録

 今回の明細用のひな形は次のようになっています。

 合計金額には「=SUM(E13:E15)」の数式が入力されており、小計の合計値を計算しています。

 また例えば13行目の小計では「=C13*(D13/100)」が入力されており、D13に入力された数量に従って金額が表示されるようになっています。

図6:明細(明細書)
図6:明細(明細書)

 このようにあらかじめ数式を入力しておくことでコードに記載する手間が省けたり、また整形されたフォーマット上に出力できるのはスプレッドシートならではです。

 ご注文数量の欄にデータを登録するコードが以下になります。先ほどは1行新規で追加するためにリストフィードを扱いましたが、今回はある特定のセルにだけデータを入力したいため、セルフィードを扱うことになります。

[リスト14]index.php(抜粋)
// 明細作成
$outputSpecial = array(13, 4);①

$serviceSpread->updateCell($outputSpecial[0],②
                           $outputSpecial[1],
                           $_POST['special'] * 100,
                           $detailKey,
                           $detailSheetId);

1. 出力先のセル位置

 セル単位での扱いとなるため、セルの位置を行、列共に指定します。

2. セルにデータを入力する

 以下関数を使用して、セルにデータを入力します。

[リスト15]updateCellメソッド
$serviceSpread->updateCell(行, 列, 入力データ, スプレッドシートのキー, ワークシートのキー)

今回使用したオブジェクトとメソッド

 以下に今回のサンプルで使用したオブジェクトとそのメソッドをまとめます。

Zend_Gdata_Spreadsheets

 スプレッドシートを扱う大元となるサービスオブジェクトです。

Zend_Gdata_Spreadsheetsクラスのメソッド
メソッド 詳細
Zend_Gdata_Spreadsheets_SpreadsheetFeed getSpreadsheetFeed(string $location) スプレッドシートのフィードを取得する。引数はフィード要求先のURI、もしくは特定のフィードを検索するZend_Gdata_Spreadsheets_DocumentQuery型のクエリ。何も指定しない場合はデフォルトのフィード要求先URIである'http://spreadsheets.google.com/feeds/spreadsheets'が引数となる。
Zend_Gdata_Spreadsheets_WorksheetFeed getWorksheetFeed(mixed $location) ワークシートのフィードを取得する。引数にフィード要求先のURI、もしくは特定のフィードを検索するZend_Gdata_Spreadsheets_DocumentQuery型のクエリ、もしくはZend_Gdata_Spreadsheets_SpreadsheetEntry型のスプレッドシートのエントリ。
Zend_Gdata_Spreadsheets_ListFeed getListFeed(mixed $location) リストのフィードを取得する。引数は要求先となるURI、もしくはZend_Gdata_Spreadsheets_ListQuery型のクエリ、もしくはZend_Gdata_Spreadsheets_WorksheetEntry型のワークシートのエントリ。
Zend_Gdata_Spreadsheets_CellFeed getCellFeed(string $location) セルのフィードを取得する。引数は要求先のURI、もしくはZend_Gdata_Spreadsheets_CellQuery型のクエリ、もしくはZend_Gdata_Spreadsheets_WorksheetEntry型のワークシートのエントリ。
Zend_Gdata_Spreadsheets_CellEntry updateCell(int $row, int $col, int $inputValue, string $key, [string $wkshtId = 'default']) 対象のセルに値を設定。既にデータがある場合は上書きとなる。引数は、列、行、値、スプレッドシートのキー、ワークシートのキー。
Zend_Gdata_Spreadsheets_ListEntry insertRow(array $rowData, string $key, [string $wkshtId = 'default']) 対象のワークシートのデータ最下部に追加行を挿入。引数はデータの列名を配列の添え字とするarray型のデータ、スプレッドシートのキー、ワークシートのキー。
Zend_Gdata_Spreadsheets_CellEntry updateRow(Zend_Gdata_Spreadsheets_ListEntry $entry, array $newRowData) 対象の行を更新する。引数は更新対象のZend_Gdata_Spreadsheets_ListEntry型のリストエントリ、更新する値を表すarray型のデータ
void deleteRow(Zend_Gdata_Spreadsheets_ListEntry $entry) 対象の行を削除する。引数は削除対象のZend_Gdata_Spreadsheets_ListEntry型のリストエントリ。

Zend_Gdata_Spreadsheets_DocumentQuery

 対象のワークシートの条件を保持するクエリオブジェクトです。

Zend_Gdata_Spreadsheets_DocumentQueryクラスのメソッド
メソッド 詳細
Zend_Gdata_Spreadsheets_CellQuery setSpreadsheetKey(string $value) 引数にスプレッドシートのキーを設定することで取得するワークシートをどのスプレッドシートから抽出するかを設定

 また上記に対応するgetメソッドも提供されています。

Zend_Gdata_Spreadsheets_ListQuery

 対象のリストフィードの条件を保持するクエリオブジェクトです。

Zend_Gdata_Spreadsheets_ListQueryクラスのメソッド
メソッド 詳細
Zend_Gdata_Spreadsheets_CellQuery setSpreadsheetKey(string $value) 引数にスプレッドシートのキーを指定することで取得するリストフィードをどのスプレッドシートから抽出するかを設定
Zend_Gdata_Spreadsheets_CellQuery setWorksheetId(string $value) 引数にワークシートのキーを指定することで取得するリストフィードをどのワークシートから抽出するかを設定

 また上記に対応するgetメソッドも提供されています。

まとめ

 いかがでしょうか。Zend_Gdata_Spreadsheetについて解説を行いました。スプレッドシートは簡単なデータベースとしても使用できますし、エクセルのように計算式や体裁を整えた文書の作成も行うことができます。ただし、実行してみると分かりますが、データベースとしてはあまり高速ではありませんので、大量の複雑なデータを扱う場合には注意が必要です。

 さて、今回でZend_Gdataシリーズの解説はひとまず終了となります。PHPとGoogleサービスの連携、理解できたでしょうか。Googleサービスは今後も色々増えることが予想されますし、それに伴いZend_Gdataもアップデートされ、様々なサービスがPHPから扱えるようになると思われます。それでも基本は今回解説したものと同じになりますので、どんどん便利なPHPスクリプトを作成していってください。

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
Zend FrameworkでGoogleアプリケーションを使い倒す連載記事一覧

もっと読む

この記事の著者

山田 祥寛(ヤマダ ヨシヒロ)

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for Visual Studio and Development Technologies。執筆コミュニティ「WINGSプロジェクト」代表。主な著書に「独習シリーズ(Java・C#・Python・PHP・Ruby・JSP&サーブレットなど)」「速習シリーズ(ASP.NET Core・Vue.js・React・TypeScript・ECMAScript、Laravelなど)」「改訂3版JavaScript本格入門」「これからはじめるReact実践入門」「はじめてのAndroidアプリ開発 Kotlin編 」他、著書多数

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

WINGSプロジェクト 森山 絵美(モリヤマ エミ)

WINGSプロジェクトについて>有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2018年11月時点での登録メンバは55名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。 RSS X: @WingsPro_info(公式)、@WingsPro_info/wings(メンバーリスト) Facebook

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/4189 2009/08/31 14:27

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング