CSV 파일 만들기 및 첫 번째 행에서 어떻게 열 이름을 가져올 수 있는지 궁금합니다. 지금은 Column 이름을 반향하려고 시도하지만 0'null을 얻으려고한다고 생각합니다. 또한 각 셀에 각 값을 넣을 수 있는지 궁금합니다. 수동으로 Excel에서 수행 할 수 있지만 번거로울 수 있습니다.CSV 파일에 열 이름 가져 오기
$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";
}
sql; CSV 파일에는 데이터가 있지만 필드 이름은 없다고 생각합니다. csv 파일에서 첫 번째 행 (필드 이름)을 가져올 수 있습니까? – fanfan1609
필드 이름을 가져 오는 방법을 잘 모르겠지만 첫 번째 필드에 NULL이 나타납니다. 이유도 모르겠다. – user3580316