Php 迭代CSV文件并获取指定头的每个值?

Php 迭代CSV文件并获取指定头的每个值?,php,xml,csv,dom,Php,Xml,Csv,Dom,我有一个CSV文件,我想检查该行是否包含特殊标题。只有当我的行包含一个特殊的标题时,它才应该转换为XML,添加其他内容等等 我现在的问题是,我如何遍历整个CSV文件,并获取每个标题在该字段中的值 因为如果它与我的特殊标题匹配,我只想转换标题与我的标题匹配的指定行。也许我也有办法做到这一点 样本: 我必须在我的实际功能中添加该功能。因为我的实际功能只是将整个CSV转换为XML。但我只想转换指定的行 我的实际职能: function csvToXML($inputFilename, $outputF

我有一个CSV文件,我想检查该行是否包含特殊标题。只有当我的行包含一个特殊的标题时,它才应该转换为XML,添加其他内容等等

我现在的问题是,我如何遍历整个CSV文件,并获取每个标题在该字段中的值

因为如果它与我的特殊标题匹配,我只想转换标题与我的标题匹配的指定行。也许我也有办法做到这一点

样本:

我必须在我的实际功能中添加该功能。因为我的实际功能只是将整个CSV转换为XML。但我只想转换指定的行

我的实际职能:

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);
}
函数csvToXML($inputFilename,$outputFilename,$delimiter=','))
{
//打开csv进行读取
$inputFile=fopen($inputFilename,'rt');
//获取文件的标题
$headers=fgetcsv($inputFile,0,$delimiter);
//创建具有良好格式的新dom文档
$doc=新的DOMDocument('1.0','utf-8');
$doc->preserveWhiteSpace=false;
$doc->formatOutput=true;
//将根节点添加到文档中
$root=$doc->createElement('products');
$root=$doc->appendChild($root);
//循环遍历每一行,创建一个具有正确数据的节点
while(($row=fgetcsv($inputFile,0,$delimiter))!==false){
$container=$doc->createElement('product');
foreach($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);
}

在将行添加到XML之前,只需检查标题即可。可以通过添加以下行来完成此操作:

 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);
    }
  }

但为什么
$row[1]
fgetcsv
从CSV行返回一个字段数组。因为你的
标题在第二列,它应该是@index 1。我知道了:D-但我不知道为什么我的IDE不接受我的代码。。。如果它被接受,是否没有???图片。。您的
if
语句中缺少结束语
。。!哈哈,我错过了一个结束语
。更新我的答案。。!