6

複数の行を返すクエリを実行して、CSVにエクスポートする必要があります。ただし、セルを特定の順序で配置する必要があります。

それで、私のテーブルがID、名前、住所、妻に配置されているとしましょう。id、address、wife、nameの順にcsvを作成する必要があります。正しい順序で配列を作成し、それを使用してcsvを作成できると思いましたが、1時間グーグルした後、配列を使用してcsvを作成する方法がわかりません。

fputcsvがありますが、事前に作成されたcsvが必要です。また、私はそれを行うためのcodeigniterの方法があることを望んでいました。

 public function export() {
    $this->load->helper('download');

    $data[1] = 'i like pie';
    $data[2] = 'i like cake';
    force_download('result.csv', $data);  
}

私はそれを試しましたが、ダウンロードヘルパーファイルが配列ではなく文字列を期待しているというエラーが表示されました。

4

3 に答える 3

16

これが私が使用するコードです...エクスポートで必要な列を調整できます...

注: この CSV は直接送信さphp://outputれ、出力バッファに直接書き込まれます。これは、サーバーに .csv ファイルを保存していないことを意味し、巨大な配列を構築してからループを試行する、はるかに大きなファイル サイズを処理できます。

    header("Content-type: application/csv");
    header("Content-Disposition: attachment; filename=\"Jobs_".date('M.j.y', $from)."-".date('M.j.y', $to).".csv\"");
    header("Pragma: no-cache");
    header("Expires: 0");

    $handle = fopen('php://output', 'w');
    fputcsv($handle, array(
        'JobId',
        'Template',
        'Customer',
        'Status',
        'Error',
        'PDF',
        'Run Time',
        'Wait Time',
        'Server'
    ));

    foreach ($jobs as $jobData) {
        fputcsv($handle, array(
            $job->getId(),
            $job->getTemplate(),
            $jobData['customers_firstname'].' '.$jobData['customers_lastname'],
            $status,
            $error,
            $jobData['products_pdfupload'],
            $job->getRunTime(),
            $job->getWaitTime(),
            $jobData['server']
        ));
    }

    fclose($handle);
    exit;

これにより、CSV エクスポートがどのように機能するかをよく理解できるはずです。私は CodeIgniter のファイル ダウンロード ヘルパーを使用していないため、その点についてはお手伝いできません。

于 2012-06-04T20:10:24.413 に答える
4

この短いスクリプトは CSV を構築し、ダウンロードすることもできます。

function convert_to_csv($input_array, $output_file_name, $delimiter)
{
    /** open raw memory as file, no need for temp files */
    $temp_memory = fopen('php://memory', 'w');
    /** loop through array */
    foreach ($input_array as $line) {
        /** default php csv handler **/
        fputcsv($temp_memory, $line, $delimiter);
    }
    /** rewrind the "file" with the csv lines **/
    fseek($temp_memory, 0);
    /** modify header to be downloadable csv file **/
    header('Content-Type: application/csv');
    header('Content-Disposition: attachement; filename="' . $output_file_name . '";');
    /** Send file to browser for download */
    fpassthru($temp_memory);
}

/** Array to convert to csv */
$array_to_csv = Array(Array(12566, 'Enmanuel', 'Corvo'), Array(56544, 'John', 'Doe'), Array(78550, 'Mark', 'Smith'));
convert_to_csv($array_to_csv, 'report.csv', ',');

ここで完全な投稿を読むことができます:

PHP配列からCSVへ - ダウンロード

于 2014-09-02T20:38:36.833 に答える
2
<?php

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

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

foreach ($list as $fields) {
    fputcsv($fp, $fields);
}

fclose($fp);
?>
于 2012-06-04T20:15:33.173 に答える