質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.35%

cakephp CSV出力について

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 2,317

nerd

score 35

現在、独学でcakephp3を習得中の環境にあります。
cakephp3でテーブルからCSVにエクスポートする機能を作成しようと考えております。

現在、controller内でexportアクションを作成して一番簡単と思われる方法でテストをしておりますが
エラーで止まっております。

エラー内容

fputcsv() expects parameter 2 to be array, object given

現在のコード
$list = $this->Samples->find()->toArray();
$fp = fopen('test.csv', 'w');
foreach ($list as $fields) {
    fputcsv($fp, $fields);
}

fclose($fp);

$this->Samples->find()で最初取得していたので、データ型を調べたらobjyectとなっていたので
->toArray()でarrayとして取得したのですがうまく動きません。
エラーの内容を調べていると、fputcsvの第2引数にarrayで入れていないからエラーとしてはじかれているのだと思うのですが、CAKEPHPのCSV出力の出力サンプルを拝見しても違いとしては、$listのみ違うことくらいしか読み取れませんでした。

以下参考URL
http://qiita.com/kazu56/items/d2df449eb58e4ef9410e

試しに、

$list = array (
    array('aaa', 'bbb', 'ccc', 'dddd'),
    array('123', '456', '789'),
    array('"aaa"', '"bbb"')
);

` とした場合には動きました。

よって、$list = $this->Samples->find()->toArray();
で取得しているものがarrayではないのでしょうか。

エンティティとarrayの違いをうまく理解できていないことが原因になっているのかと推測しておりますが
解決方法がわかりませんでしたので、ご質問をさせていただきました。

わかりにくくて大変恐縮ではありますが、ご教授いただけましたら幸いです。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

hydrate(false)をクエリオブジェクトで実行してみては...

$list = $this->Samples->find()->hydrate(false)->toArray();

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/05/26 22:05

    keiji-yoneda様

    ご教授ありがとうございます。
    ご指摘の通りやってみたのですがうまく動きました。
    ちなみに下記内容でも同様の結果を取得できました。
    ``$list = $this->Samples->find()->hydrate(false);``

    ``$list = $this->Samples->find()->hydrate(false);``
    ``$list = $this->Samples->find()->toArray();``

    リファレンスを読んでみたのですが、上記2文の違いがよく分かりませんでした。

    お手すきの時にまたご教授いただけましたら幸いです。

    また、迅速なご回答誠にありがとうございました。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.35%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る