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

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

ただいまの
回答率

90.47%

  • PHP

    20844questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

fgetcsv()

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 377

MISHIRO

score 18

下記のサイトを見ていたのですがこのコードで記述されているfgetcsvの使われ方はどのような意味なのでしょうか?

# 一時ファイルのデータを再度CSVとして読み込む
while(($data=fgetcsv($temp,0,",")) !== false){
 $csv[] = $data;
}


fgetcsvで検索をかけても

fgetcsv ( resource $handle [, int $length = 0 [, string $delimiter = "," [, string $enclosure = '"' [, string $escape = "\" ]]]] )


という書き方のものの解説は出てくるのですが今回問題となったコードの解説は見当たりませんでした。
このコードについて解説をお願いします。

またこのサイトを見る限りですとCSVを一時ファイルとして作り直していると読み取れるのですが
その場合、元のCSVと形が変わっていることはないのでしょうか?

参考サイトURL:http://php.ex-mode.net/mb/s/contents.php?n=chap4_7

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+3

ごめんなさい、どこがわからないかわからないので、ざっと何をしているかだけ

  • fgetcsv($temp,0,",")

まず$tempは事前にfopenで開いた状態を保持しているインスタンスです
$tempから抜き出して1行を0文字分=まるまる1行分読み取ってcsvとして解釈します
その際のデリミタ(=文字間をきりわける記号)に「,」を使います

  • $data=fgetcsv($temp,0,",")

fgetcsvで得た1行分配列データを$dataに代入します

  • while(($data=fgetcsv($temp,0,",")) !== false){・・・}

$dataがfalseになる場合はファイルの最後まで読んだことになります
falseでない場合は、データがあるということなのでwhile内を実行します

  • $csv[] = $data;

$csvの最後に1つデータを拡張して、$dataを代入します。
具体的には

if(!isset($csv)) $csv=[];
$csv[count($csv)==0?0:(max(array_keys($csv))+1)]=$data;


もう少し分解すると

if(!isset($csv)) $csv=[];
if(count($csv)==0){
  $key=0;
}else{
  $key=max(array_keys($csv))+1)
}
$csv[$key]=$data;

と同等の処理です(もうすこし解釈がわかれますが)

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/09/22 16:56

    詳しい説明ありがとうございます。
    とても分かりやすく助かりました。

    $csv[count($csv)==0?0:(max(array_keys($csv))+1)]=$data;
    とのことなのですが解説していただけませんでしょうか。
    まだPHPのことをほぼ知らない状態でうまく解釈できませんでした。

    キャンセル

  • 2017/09/22 17:00

    > $csv[count($csv)==0?0:(max(array_keys($csv))+1)]=$data;

    も$csvの要素数が0だった場合0
    そうでない場合は$csvのキーにある最大値に1をたした数字
    をキーにした$csvに$dataを代入するという意味です。
    本文にちょっと追記しておきます

    キャンセル

  • 2017/09/22 17:12

    追記していただきありがとうございます。
    わかりやすくなりました。

    すみません。
    もう一点質問させていただきたいのですが
    csvの内容が

    名前(姓),名前(名),名前(セイ),名前(メイ)
    田中,一郎,タナカ,イチロウ

    で、$csvの中身が何もなかった場合は

    $csv[0][0]=名前(姓);
    $csv[0][1]=名前(名);
    $csv[0][2]=名前(セイ);
    $csv[0][3]=名前(メイ);
    $csv[1][0]=田中;
    $csv[1][1]=一郎;
    $csv[1][2]=タナカ;
    $csv[1][3]=イチロウ;

    という状態になるのでしょうか?

    キャンセル

  • 2017/09/22 17:19

    print_r($csv)するとこう戻ります。

    Array
    (
    [0] => Array
    (
    [0] => 名前(姓)
    [1] => 名前(名)
    [2] => 名前(セイ)
    [3] => 名前(メイ)
    )

    [1] => Array
    (
    [0] => 田中
    [1] => 一郎
    [2] => タナカ
    [3] => イチロウ
    )

    )

    キャンセル

  • 2017/09/22 17:25

    なるほど。
    何度もコメントしていただきありがとうございました。
    とてもわかりやすく記述してくださったおかげて理解できました。

    キャンセル

+2

PHPマニュアルにきちんと説明が書いてあるように思いますが・・

ファイルポインタから行を取得し、CSVフィールドを処理する
fgetcsv() は行を CSV フォーマットのフィールドとして読込み処理を行い、 読み込んだフィールドを含む配列を返すという違いがあります。

書き込み可のモード (w+) でユニークな名前を有するテンポラリファイルを作成し、 ファイルハンドルを返します。
ファイルをクローズした場合や、スクリプトが終了したりしたときに、このファイルは自動的に削除されます。

これをご提示のサイトのコードに当てはめて要約すると
list.csvの内容を一時ファイルにうつした上で1行ずつ行がなくなるまで読み込み、「,」を列の区切りとして配列でデータを取得する(最大行長は制限しない)。スクリプトと終了同時に一時ファイルは削除される
ですね。

つまり、csvを作り直しているわけではなく、csvをメール配信リストとして「データとして(テンポラリファイルにうつして)」取り込み、
取り込んだデータを行毎に取得した配列として後ほどループし、1件ずつメール送信を行っている、ということです。
情報を読み込んでいるだけなので元のcsvにはなんら影響しません。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/09/22 16:49

    回答ありがとうございます。

    確かに書かれてはいたのですが、どういう意味なのか理解できず質問させていただきました。

    csvでの記述が

    名前(姓),名前(名),名前(セイ),名前(メイ)
    田中,太郎,タナカ,タロウ

    となっていた場合
    配列には
    csv[0]="田中"
    csv[1]="太郎"
    csv[2]="タナカ"
    csv[3]="タロウ"
    という形で入るのでしょうか?

    キャンセル

  • 2017/09/22 16:52

    ちょっと違いますね。
    $data[0] = "田中" ・・・
    となるはずです。
    実際にcsvを用意して動作させてみてはいかがでしょうか。

    キャンセル

  • 2017/09/22 17:13

    環境が作れ次第試してみようと思います。
    ありがとうございました。

    キャンセル

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

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

関連した質問

  • 受付中

    PHPにおけるCSV読み込みについて

    PHP初心者です。 現在アンケートフォームを作っているのですが ①アンケート入力 ②入力確認フォーム ③回答完了ページ(この時点でアンケート内容をCSVファイルに出

  • 受付中

    csvアップロード後

    ヘディングのテキスト###前提・実現したいこと csvfileをアップロードは完了したのですが 次のステップの段階で 「水野さん、田中さん、鈴木さん」の名前だけを表示できます

  • 解決済

    PHPでCSVの先頭行に新たなデータを挿入したい

    PHPでCSVの先頭行に新たなデータを挿入したいのですが、困っています。 fopenをaでは最終行に追記されてしまい、wではCSVの既存のデータが消えてしまいます。 試行錯

  • 解決済

    PHP:preg_matchが値を返さない

    preg_matchで「万円」が含まれる場合の条件分岐をさせたいと思います。 以下のようなコードを書きましたが、 if(preg_match('~の前にecho $data_v

  • 解決済

    WordPressでCSVファイルを正しく出力させたい

    WordPressにて下記のPHPコードでCSVファイルをブラウザで出力すると、 244行にもなるタグなどを含むCSVファイルが出力されてしまいます。 求めている内容だけ出力されな

  • 解決済

    【PHP】セルの中にダブルクオートを含むCSVをfgetcsvで取得したい

    複数あるうちの1つのセルにhtml(ダブルクオートを含む)が入っているCSVの読み込みを行いたかったので以下を実行しました。 $arrCSV = fgetcsv($fp, 10

  • 解決済

    phpでTSVファイルから指定したカラムを抽出したい

    日次で更新される1000行程度のTSVファイルがあります。 001 鈴木 宮城 31 002 佐藤 東京 47 003 松田 静

  • 解決済

    csvからデータが取れない

    csvを読み込んで、 csvの1行目のデータを表示したいです(2行目以降は表示できています。) 読み込む側 function getTest() { $file =

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

  • PHP

    20844questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。