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

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

ただいまの
回答率

89.08%

fputcsvでサーバーに出力したい。

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,880

tajix_japan

score 86

前提・実現したいこと

下記のPHPは、このPHPファイルにアクセスするとMySQLのデータを自動的にブラウザ上でダウンロードできます。
このPHPにfputcsvを付け加えて、ブラウザ上ではなくサーバー上にCSVファイルとして保存したいです

該当のソースコード

<?php
$down_file = date('Ymd') . '.csv';
header("Content-Type: application/octet-stream");
header("Content-Disposition: attachment; filename=" . $down_file);
$db_host = "localhost";
$db_user = "root";
$db_passwd = "passwd";
$db_name = "db_name";
$sql = "SELECT * FROM table";

$db = mysql_connect($db_host,$db_user,$db_passwd);
mysql_query("set names utf8");
mysql_select_db($db_name,$db);
$result = mysql_query($sql,$db);
for($i=0; $i<mysql_num_fields($result); $i++){
//print (mb_convert_encoding(mysql_field_name($result,$i),'SJIS', 'UTF-8').",");
}
//print("\n");
for($j=0 ; $j<mysql_num_rows($result); $j++) {
for($k=0; $k<mysql_num_fields($result); $k++) {
$str = mysql_result($result,$j,$k);
print (mb_convert_encoding($str,'SJIS', 'UTF-8').",");
}
print("\n");
}
mysql_close($db);
?>

試したこと

一番下に

$fp = fopen('file.csv', 'w');
fputcsv($fp, $str);

を加えましたが、真っ白になるだけでSQLデータが記入されることはありませんでした。
を加えてみたのですが何事も起こりませんでした。
どのように改造すればいいか教えてください。
宜しくお願い致します。

補足情報(言語/FW/ツール等のバージョンなど)

より詳細な情報

PHP Version 5.3.3
MySQL 5.1.65 

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • kei344

    2016/06/08 14:29

    コードはコードブロックで囲んでいただけませんか? ```(バッククオート3つ)で囲み、前後に改行をいれるか、コードを選択して「</>」ボタンを押すとコードブロックになります。

    キャンセル

回答 2

checkベストアンサー

+2

$strは1レコード・1カラムごとの値を格納しているだけなので、ループを抜けた最後には、一番最後に取得した値しか残っていないです。
次のような感じで実装すると良いと思います。

$fp = fopen('file.csv', 'w'); 
for($j=0 ; $j<mysql_num_rows($result); $j++) { 
  $str = Array();
  for($k=0; $k<mysql_num_fields($result); $k++) { 
    $str[] = mysql_result($result,$j,$k); 
  } 
  fcsvput($fp,$str);
} 
fclose($fp);

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/06/08 21:59

    ありがとうございます。

    ```

    $fp = fopen('file.csv', 'w');
    for($j=0 ; $j<mysql_num_rows($result); $j++) {
    $str = Array();
    for($k=0; $k<mysql_num_fields($result); $k++) {
    $str[] = mysql_result($result,$j,$k);
    }
    fcsvput($fp,$str);
    }
    fclose($fp);

    ```

    という記述を下記の【1】【2】【3】と入れてみました。
    fileは更新されるのですが、白紙のままです。
    そもそも、入れる場所が間違っているのでしょうか?
    ご迷惑をお掛け致します。
    よろしくお願いいたします。

    ```

    <?php
    $down_file = date('Ymd') . '.csv';
    header("Content-Type: application/octet-stream");
    header("Content-Disposition: attachment; filename=" . $down_file);
    $db_host = "localhost";
    $db_user = "root";
    $db_passwd = "kt8410II";
    $db_name = "value_cars";
    $sql = "SELECT * FROM buy_car_request";

    $db = mysql_connect($db_host,$db_user,$db_passwd);
    mysql_query("set names utf8");
    mysql_select_db($db_name,$db);
    $result = mysql_query($sql,$db);
    for($i=0; $i<mysql_num_fields($result); $i++){
    //print (mb_convert_encoding(mysql_field_name($result,$i),'SJIS', 'UTF-8').",");
    }
    //print("\n");
    for($j=0 ; $j<mysql_num_rows($result); $j++) {
    for($k=0; $k<mysql_num_fields($result); $k++) {
    $str = mysql_result($result,$j,$k);
    print (mb_convert_encoding($str,'SJIS', 'UTF-8').",");
    }


    //【1】結果 file.csvは白紙のまま


    print("\n");
    }

    //【2】結果 file.csvは白紙のまま


    mysql_close($db);


    //【3】結果 file.csvは白紙のまま


    ?>

    ```

    キャンセル

  • 2016/06/09 08:34

    【1】でも【2】でも【3】でもなく、既存コードで出力のループのしているところがありますよね。
    そこに組み込みましょうということです。

    キャンセル

  • 2016/06/09 20:22

    ありがとうございます。
    下記で解決いたしました。
    深く御礼申し上げます。


    <?php
    $down_file = date('Ymd') . '.csv';
    header("Content-Type: application/octet-stream");
    header("Content-Disposition: attachment; filename=" . $down_file);
    $db_host = "localhost";
    $db_user = "root";
    $db_passwd = "passwd";
    $db_name = "db_name";
    $sql = "SELECT * FROM table";

    $db = mysql_connect($db_host,$db_user,$db_passwd);
    mysql_query("set names utf8");
    mysql_select_db($db_name,$db);
    $result = mysql_query($sql,$db);

    for($i=0; $i<mysql_num_fields($result); $i++){

    $fp = fopen('file.csv', 'w');
    for($j=0 ; $j<mysql_num_rows($result); $j++) {
    $str = Array();
    for($k=0; $k<mysql_num_fields($result); $k++) {
    $str[] = mysql_result($result,$j,$k);
    }
    fputcsv($fp,$str);
    }
    fclose($fp);

    }
    mysql_close($db);

    ?>

    キャンセル

+2

fputcsvは配列をcsv形式にして書き出すのですが、今回の場合$strは配列ではなくすでにcsv形式になっている文字列なのでfwritefile_put_contentsを使って書き出してみて下さい。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/06/08 21:58

    ありがとうございます。

    $fp = fopen('file.csv', 'w');
    file_put_contents($fp,$str);
    fclose($fp);
    という記述を下記の【1】【2】【3】と入れてみました。
    fileは更新されるのですが、白紙のままです。
    そもそも、入れる場所が間違っているのでしょうか?
    ご迷惑をお掛け致します。
    よろしくお願いいたします。


    <?php
    $down_file = date('Ymd') . '.csv';
    header("Content-Type: application/octet-stream");
    header("Content-Disposition: attachment; filename=" . $down_file);
    $db_host = "localhost";
    $db_user = "root";
    $db_passwd = "kt8410II";
    $db_name = "value_cars";
    $sql = "SELECT * FROM buy_car_request";

    $db = mysql_connect($db_host,$db_user,$db_passwd);
    mysql_query("set names utf8");
    mysql_select_db($db_name,$db);
    $result = mysql_query($sql,$db);
    for($i=0; $i<mysql_num_fields($result); $i++){
    //print (mb_convert_encoding(mysql_field_name($result,$i),'SJIS', 'UTF-8').",");
    }
    //print("\n");
    for($j=0 ; $j<mysql_num_rows($result); $j++) {
    for($k=0; $k<mysql_num_fields($result); $k++) {
    $str = mysql_result($result,$j,$k);
    print (mb_convert_encoding($str,'SJIS', 'UTF-8').",");
    }


    //【1】結果 file.csvは白紙のまま


    print("\n");
    }

    //【2】結果 file.csvは白紙のまま


    mysql_close($db);


    //【3】結果 file.csvは白紙のまま


    ?>

    キャンセル

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

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

関連した質問

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