dongyuli0964 2017-02-21 17:47
浏览 93
已采纳

迭代CSV文件并获取指定标题的每个值?

I have a CSV file and I want to check if the row contains a special title. Only if my row contains a special title it should be converted to XML, other stuff added and so on.

My question now is, how can I iterate through the whole CSV file and get for every title the value in this field?

Because if it matches my special title I just want to convert the specified row where the title is matching my title. Maybe also an idea how I can do that?

Sample: CSV File

I must add that feature to my actual function. Because my actual function is just is converting the whole CSV to XML. But I just want to convert the specified rows.

My actual function:

function csvToXML($inputFilename, $outputFilename, $delimiter = ',')
{
  // Open csv to read
  $inputFile = fopen($inputFilename, 'rt');

  // Get the headers of the file
  $headers = fgetcsv($inputFile, 0, $delimiter);

  // Create a new dom document with pretty formatting
  $doc = new DOMDocument('1.0', 'utf-8');
  $doc->preserveWhiteSpace = false;
  $doc->formatOutput = true;

  // Add a root node to the document
  $root = $doc->createElement('products');
  $root = $doc->appendChild($root);

  // Loop through each row creating a <row> node with the correct data
  while (($row = fgetcsv($inputFile, 0, $delimiter)) !== false) {
    $container = $doc->createElement('product');
    foreach ($headers as $i => $header) {
      $child = $doc->createElement($header);
      $child = $container->appendChild($child);
      $value = $doc->createTextNode($row[$i]);
      $value = $child->appendChild($value);
    }

    $root->appendChild($container);
  }

  $strxml = $doc->saveXML();
  $handle = fopen($outputFilename, 'w');
  fwrite($handle, $strxml);
  fclose($handle);
}
  • 写回答

1条回答 默认 最新

  • dongliyu3278 2017-02-21 18:03
    关注

    Just check the title before adding the rows to XML. You could do it by adding the following lines:

     while (($row = fgetcsv($inputFile, 0, $delimiter)) !== false) {
    
        $specialTitles = Array('Title 1', 'Title 2', 'Title 3'); // titles you want to keep
    
        if(in_array($row[1], $specialTitles)){
            $container = $doc->createElement('product');
            foreach ($headers as $i => $header) {
              $child = $doc->createElement($header);
              $child = $container->appendChild($child);
              $value = $doc->createTextNode($row[$i]);
              $value = $child->appendChild($value);
            }
    
            $root->appendChild($container);
        }
      }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥100 需要跳转番茄畅听app的adb命令
  • ¥50 寻找一位有逆向游戏盾sdk 应用程序经验的技术
  • ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
  • ¥50 opencv4nodejs 如何安装
  • ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证