【问题标题】:Append dynamically generated string to end of CSV line将动态生成的字符串附加到 CSV 行的末尾
【发布时间】:2014-04-17 03:54:14
【问题描述】:

所以我有两个 CSV:InputCSV 和 OutputCSV

输入CSV.csv

name     col1     col2     col3     col4     col5
john     qOJY     OHXl     vIOH     Tdnm     Z7OH
greg     YRc1     hyFB     pW8m     5LSE     Yo4r
saly     Dy4o     51Ui     tuKI     02VQ     RVgB

输出CSV.csv

name     url
john     site.com/JcRIeyFCEl.mp4
greg     site.com/TTwF4Cue2B.mp4
saly     site.com/ouroANTtAC.mp4

所以在processor.php中,我有

    if (($csvFile = fopen("InputCSV.csv", "r")) !== false && ($resultCsv = fopen("OutputCSV.csv", 'w')) !== false) {
        while (($data = fgetcsv($csvFile)) !== false) {
            // do stuff to generate $thumbfile
            // this bit needs to use parts of $data like $data[3], $data[5] to generate $thumbfile
            // which in the end should look like $thumbfile = 'site.com/rAndOmsTRing.jpg';
        }
    $outputData = fgetcsv($resultCsv);
    $outputData[] .= $thumbfile_url; //Append to end of line. is this what I'm doing wrong? 
    fputcsv($resultCsv, $outputData);

我需要做的是向 OutputCSV.csv 添加一个新列,并在每行/行的末尾附加 $thumbfile。目前,它的作用是删除现有的两个列,并仅将 $thumbfile 作为一列写入。

OutputCSV.csv 在此脚本运行后需要如下所示: 输出CSV.csv

name     url                         thumbfile
john     site.com/JcRIeyFCEl.mp4     site.com/snTflxaqNI.jpg
greg     site.com/TTwF4Cue2B.mp4     site.com/ELrg6vwKEr.jpg
saly     site.com/ouroANTtAC.mp4     site.com/xTjfqCEoIZ.jpg

注意:我使用的实际 csv 没有标题。我把它们放在那里只是为了让阅读更容易。

【问题讨论】:

    标签: php csv append fputcsv


    【解决方案1】:

    要满足您的需要,您需要将 OutputCSV.csv 的数据保存在数组中,然后在同一个数组中添加您的 $thumbfile。

    这里是一个例子,我使用你的 csv 文件,用“,”分隔。

        if (($csvFile = fopen("InputCSV.csv", "r")) !== false && ($resultCsv = fopen("OutputCSV.csv", 'r')) !== false) {
            while (($data = fgetcsv($csvFile,4096,",")) !== false) {
            // do stuff to generate $thumbfile
            $thumbfile[]=$data[3].$data[5].".jpg";
                }
            $x=0;
            while (($dataoutput = fgetcsv($resultCsv,4096,",")) !== false) {
                $dataotputcsv[$x]=$dataoutput;   //here is [0]=> "john" [1]=> "site.com/JcRIeyFCEl.mp4"
                array_push($dataotputcsv[$x], $thumbfile[$x]);  //here i add the $thumbfile
          //and now is [0]=> "john" [1]=> "site.com/JcRIeyFCEl.mp4" [2]=> "vIOHZ7OH.jpg"
            $x++;
            }
            $file = fopen("OutputCSV.csv", 'w'); 
            foreach($dataotputcsv as $string) {
                fputcsv($file, $string);  //save all lines to file
            }
    
        }
    

    【讨论】:

      猜你喜欢
      • 2022-12-11
      • 2020-08-19
      • 2014-03-06
      • 2017-09-29
      • 2013-02-16
      • 1970-01-01
      • 1970-01-01
      • 2015-09-21
      • 2013-10-17
      相关资源
      最近更新 更多