php - 获取csv文件中的列名

标签 php sql-server excel csv sqlsrv

正在创建 CSV 文件并想知道如何在第一行中获取列名。现在我认为它正在尝试回应列名但得到 0'nulls。我也想知道是否可以将每个值放在每个单元格中,我可以在 excel 中手动完成,但这很麻烦。

enter image description here

这是代码:

$result=sqlsrv_query($conn,$sql) or die("Couldn't execute query:<br>" . sqlsrv_error(). "<br>" . sqlsrv_errno()); 

$file_ending = "csv";
$reals=array();
//header info for browser
header("Content-Type: application/csv");    
header("Content-Disposition: attachment; filename=test.csv");  
header("Pragma: no-cache"); 
header("Expires: 0");
/*******Start of Formatting for Excel*******/   
//define separator (defines columns in excel & tabs in word)
$sep = "\t"; //tabbed character

$i=0;
foreach( sqlsrv_field_metadata( $result ) as $fieldMetadata ) {    
       echo $fieldMetadata["Name"]+"\t";
       if($fieldMetadata["Type"]=="real")//$fieldMetadata["Type"]=== SQL_REAL
       {
           $reals[] = $i;
       }
       $i++;
}


print("\n");    
//end of printing column names  
//start while loop to get data
while($row = sqlsrv_fetch_array($result))
{

   $schema_insert = "";
   for($j = 0; $j < sqlsrv_num_fields($result); $j++)
   {
      if ($row[$j] != "") {
         if (in_array($j, $reals)) {
            $schema_insert .= str_replace(".",",", $row[$j]) . $sep;
         } else {
            $schema_insert .= $row[$j] . $sep;
         }
      }
      else
         $schema_insert .= "" . $sep;
   }

   $schema_insert = preg_replace("/\r\n|\n\r|\n|\r/", " ", $schema_insert);
   $schema_insert .= "\t";
   print(trim($schema_insert));
   print "\n";
}

最佳答案

这行得通吗?由于 sqlsrv_fetch_array 返回一个以字段名称作为键的关联数组,我们可以将其作为第一行输入。

$result=sqlsrv_query($conn,$sql) or die("Couldn't execute query:<br>" . sqlsrv_error(). "<br>" . sqlsrv_errno()); 

$file_ending = "csv";
$reals=array();
//header info for browser
header("Content-Type: application/csv");    
header("Content-Disposition: attachment; filename=test.csv");  
header("Pragma: no-cache"); 
header("Expires: 0");
/*******Start of Formatting for Excel*******/   
//define separator (defines columns in excel & tabs in word)
$sep = "\t"; //tabbed character

$firstRow = true;


//start while loop to get data
while($row = sqlsrv_fetch_array($result))
{
  if($firstRow)
  {
    $names = array_keys($row);
    $namesToPrint = '';

    foreach($names as $idx => $name)
    {
        if($idx % 2 != 0)
        {
            $namesToPrint .= $name.',';
        }
    }

    $namesToPrint = substr($namesToPrint, 0, -1);

    print $namesToPrint."\n";

    $firstRow = false;
  }

   $schema_insert = "";
   for($j = 0; $j < sqlsrv_num_fields($result); $j++)
   {
      if ($row[$j] != "") {
         if (in_array($j, $reals)) {
            $schema_insert .= str_replace(".",",", $row[$j]) . $sep;
         } else {
            $schema_insert .= $row[$j] . $sep;
         }
      }
      else
         $schema_insert .= "" . $sep;
   }

   $schema_insert = preg_replace("/\r\n|\n\r|\n|\r/", " ", $schema_insert);
   $schema_insert .= "\t";
   print(trim($schema_insert));
   print "\n";
}

关于php - 获取csv文件中的列名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23358391/

相关文章:

python - 当我使用 pandas 读取 .csv 中的特定列时奇怪的跳过

php - 还包括 MySQL SELECT 查询中的 NULL 行

php - 即使我的连接文件有效,phpmyadmin 上的数据库也不会保存数据

sql - SSRS 2008 - Reporting Services 网页除标题外均为空白

sql-server - SQL Server不同设计查询性能

excel - 尝试将 XLSM 保存为 CSV 时出现 "method saveas of object _workbook failed"错误

PHP 更新用户帐户详细信息未显示错误但帐户详细信息未更新

php - session 登录 - 如果用户不再存在于数据库中,则销毁 session

sql-server - 如何首先在 EF 代码中制作持久计算列?

excel - 使用第 1 行合并单元格中的文本为多个图表提供标题