Как я могу записать массив в CSV-файл? - PullRequest
1 голос
/ 24 января 2020

Я генерирую массив из нескольких переменных и хочу полностью записать это в csv-файл. Заголовок работает правильно, но только из массива / \ n / "(, записывается в CSV.

Если я использую implode до echo , то я получаю пустую строку. Что не так? Вот код, который я использую до сих пор:

<?php

    function scrape_between($data, $start, $end){
        $data = stristr($data, $start); 
        $data = substr($data, strlen($start)); 
        $stop = stripos($data, $end); 
        $data = substr($data, 0, $stop); 
        return $data; 
    }

    function curl($url) {

        $options = Array(
            CURLOPT_RETURNTRANSFER => TRUE, 
            CURLOPT_FOLLOWLOCATION => TRUE,
            CURLOPT_AUTOREFERER => TRUE,
            CURLOPT_CONNECTTIMEOUT => 120,
            CURLOPT_TIMEOUT => 120,
            CURLOPT_MAXREDIRS => 10,
            CURLOPT_USERAGENT => "Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.1a2pre) Gecko/2008073000 Shredder/3.0a2pre ThunderBrowse/3.2.1.8",  // Setting the useragent
            CURLOPT_URL => $url, 
        );

        $ch = curl_init(); 
        curl_setopt_array($ch, $options); 
        $data = curl_exec($ch);
        curl_close($ch);   
        return $data; 
    };

    $header = 'date1,date2,contractcode,exchange,region,commoditycode,openint,noncomlong,noncomshort,noncomspread,comlong,comshort,';
    echo($header);

    $scraped_page = curl("https://www.cftc.gov/dea/newcot/deafut.txt");   
    $scraped_wheat = scrape_between($scraped_page, "WHEAT-SRW - CHICAGO BOARD OF TRADE", "CONTRACTS");
    $scraped_wheat = preg_replace('/",/', '', $scraped_wheat); 
    $pieces = explode('WHEAT', $scraped_wheat);  
    $items = explode(",",$pieces[0]); 
    $tmp = 0;
    foreach ($items as $value)if ($tmp++ < 12) {
    $value = preg_replace('/\s/', '', $value);
    echo ($value.",");

    };
    $file = 'cot-zw.csv';
    file_put_contents($file, $header.'/\n/'.$value.",");

?>  

Большое спасибо за вашу помощь!

РЕДАКТИРОВАТЬ

Предложения через fputcsv создают пустой CSV-файл. Вот что я попробовал (и не смог):

    $scraped_wheat = scrape_between($scraped_page, "WHEAT-SRW - CHICAGO BOARD OF TRADE", "CONTRACTS");
    $scraped_wheat = preg_replace('/",/', '', $scraped_wheat);  // ", am Anfang entfernen
    $pieces = explode('WHEAT', $scraped_wheat);  // explode() Teilt die Zeichenkette
    $items = explode(",",$pieces[0]); // Definition des , als Teiler
    $tmp = 0;
    foreach ($items as $value)if ($tmp++ < 12) {
    $value = preg_replace('/\s/', '', $value);
    echo ($value.",");    
    $fp = fopen('cot-zw.csv', 'w');
    foreach($value as $line){
             $val = explode(",",$line);
             fputcsv($fp, $val);
    }
    fclose($fp);   
    };```

1 Ответ

1 голос
/ 24 января 2020

file_put_contents() - это очень грубый способ записи в CSV.

Я бы порекомендовал использовать fputcsv(). Вот очень простой пример:

<?php
$csv_items = [
    ['row1-col1','row1-col2','row1-col3'],
    ['row2-col1','row2-col2','row2-col3'],
    ['row3-col1','row3-col2','row3-col3']
];

if( $fh = fopen('file.csv','w') ){

    foreach( $csv_items as $csv_item ){
        fputcsv($fh, $csv_item);
    }

    fclose( $fh );
}

https://www.php.net/manual/en/function.fputcsv.php

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...