Posts Tagged ‘plugin’

    Share on Facebook
    はてなブックマーク - PHPmatsriにてCsvCombinePluginを紹介してきました。
    このエントリーをはてなブックマークに追加

    ブログはお久しぶりです。萩原です。

    今回は、PHPmatsuriに弊社、小山、櫻川、杉本と、私の4人で行ってきました。

    PHPmatsuriの感想

    私は、ハッカソンという形式のイベントは初めてで、LTも初めてでしたので非常に緊張しましたが、何とか無事に発表まで終える事が出来て良かったです。

    発表でおーと声が上がった時は非常にうれしかったです。
    後、下記にも載せているホークスのスタメンを出したときに、「何でそんなマニアックな」と言って下さった方、ありがとうございます。
    あれが一番うれしかったりします(笑)。

    普段、私はCakePHPを扱っていますが、SymfonyやLithiumなどの他のフレームワークについてはまったくといっていいほど知りませんでしたので、その二つのセッションを両フレームワークの開発者から聞けたことも非常に貴重な機会でした。

    また、開発風景やLTの発表を見まして、皆さんすごい、もっと自分も頑張らないとと改めて感じました。

    CsvCombinePlugin

    さて、今回私がPHPmatsuriで紹介しました、CsvCombinePluginについてご紹介したいと思います。

    このプラグインはCSVの入出力の処理を簡単に行うことが出来るプラグインです。
    CakePHP1.3と2.0の両方のブランチをGithubで用意しています。

    せっかくですのでCakePHP2の方式で紹介したいと思います。

    まずはこちらのGithubの”cake2″というブランチよりダウンロードしてきて、Pluginディレクトリ内に”CsvCombine”とrenameして下さい。

    CSVの入力

    まずはCSVを添付して配列で返すメソッドを紹介します。

    モデルにBehaviorを宣言します。

    <?php
    App::uses('AppModel','Model');
    CakePlugin::load('CsvCombine');
    class CsvTest extends AppModel{
        var $actsAs = array('CsvCombine.CsvImport');
    }

    後は、コントローラで列ごとの配列のキー値を指定したらアクションをたたいて完了です。

    <?php
    App::uses('AppController','Controller');
        class CsvTestsController extends AppController{
        var $name = 'CsvTests';
     
        function index(){
            if ($this->request->is('post')) {
               /***基本必要な個所***/
               //配列のキー値を左から指定
                $list = array('打順', '守備','名前','打率','HR','打点');
                //このアクションで配列が返ってくる
                $data = $this->CsvTest->csvData($list);
                 /***!基本必要な個所***/
                if ($data === false) {
                    print_r('MISS');
                    exit;
                }
                print_r($data);
                exit;
            }
     
        }

    これで下記の様なCSVを添付すると・・・(PHPmatsuri1日目夜の日のホークスのスタメンです・・・)

    1,遊,川﨑,.271,1,37
    2,二,本多,303,0,43
    3,左,内川,.341,12,73
    4,三,松田,.283,25,83
    5,中,長谷川,.293,4,34
    6,右,福田,.256,1,20
    7,DH,柴原,.077,0,0
    8,一,明石,.277,1,12
    9,捕,山崎,.191,0,11
    P,投,杉内,.200,0,3
    

    以下のような配列が返ってきます。(preで整形しています。

    Array
    (
        [0] => Array
            (
                [打順] => 1
                [守備] => 遊
                [名前] => 川﨑
                [打率] => .271
                [HR] => 1
                [打点] => 37
            )
    
        [1] => Array
            (
                [打順] => 2
                [守備] => 二
                [名前] => 本多
                [打率] => 303
                [HR] => 0
                [打点] => 43
            )
    
        [2] => Array
            (
                [打順] => 3
                [守備] => 左
                [名前] => 内川
                [打率] => .341
                [HR] => 12
                [打点] => 73
            )
    
        [3] => Array
            (
                [打順] => 4
                [守備] => 三
                [名前] => 松田
                [打率] => .283
                [HR] => 25
                [打点] => 83
            )
    
        [4] => Array
            (
                [打順] => 5
                [守備] => 中
                [名前] => 長谷川
                [打率] => .293
                [HR] => 4
                [打点] => 34
            )
    
        [5] => Array
            (
                [打順] => 6
                [守備] => 右
                [名前] => 福田
                [打率] => .256
                [HR] => 1
                [打点] => 20
            )
    
        [6] => Array
            (
                [打順] => 7
                [守備] => DH
                [名前] => 柴原
                [打率] => .077
                [HR] => 0
                [打点] => 0
            )
    
        [7] => Array
            (
                [打順] => 8
                [守備] => 一
                [名前] => 明石
                [打率] => .277
                [HR] => 1
                [打点] => 12
            )
    
        [8] => Array
            (
                [打順] => 9
                [守備] => 捕
                [名前] => 山崎
                [打率] => .191
                [HR] => 0
                [打点] => 11
            )
    
        [9] => Array
            (
                [打順] => P
                [守備] => 投
                [名前] => 杉内
                [打率] => .200
                [HR] => 0
                [打点] => 3
            )
    
    )
    

    CSVの出力

    CSVの出力はコントローラでComponentを宣言して、出力したい配列を準備してアクションをたたいて完了です。(今度は同日の阪神のスタメンです・・・大阪でしたし。)

    <?php
    App::uses('AppController', 'Controller');
    CakePlugin::load('CsvCombine');
     
    /**
     * ParentEnquetes Controller
     *
     * @property ParentEnquete $ParentEnquete
     */
    class CsvTestsController extends AppController {
     
        var $components = array('CsvCombine.CsvExport');
     
        function export(){
            $list[] = array('1','二','平野','.297','1','28');
            $list[] = array('2','中','柴田','.280','0','8');
            $list[] = array('3','遊','鳥谷','.300','5','49');
            $list[] = array('4','三','新井','.274','17','89');
            $list[] = array('5','一','ブラゼル','.282','15','66');
            $list[] = array('6','右','マートン','.316','13','57');
            $list[] = array('7','左','金本','.218','12','37');
            $list[] = array('8','捕','藤井','.218','2','15');
            $list[] = array('9','投','スタンリッジ','.095','0','0');
     
            $this->CsvExport->export($list);
        }
    }

    以下のCSVが出力されます。

    1,二,平野,.297,1,28
    2,中,柴田,.280,0,8
    3,遊,鳥谷,.300,5,49
    4,三,新井,.274,17,89
    5,一,ブラゼル,.282,15,66
    6,右,マートン,.316,13,57
    7,左,金本,.218,12,37
    8,捕,藤井,.218,2,15
    9,投,スタンリッジ,.095,0,0
    

    以上が、PHPmatsuriで発表してきました、CsvCombinePluginの紹介でした。
    このプラグインは実際にはオプションで区切り文字など指定が出来ますので、TSVなどにも対応が可能です。
    GithubのREADMEに詳しく書いているのでそちらもご覧頂けたらと思います。
    よろしければお使いください!

    最後に

    このような、有意義で楽しいイベントを準備、運営していただいた皆さん。ありがとうございました。
    次も参加したいと思えるイベントでした!

    それでは、弊社二人目が明日、また書きますのでよろしくお願いします!