2016-07-07 80 views
1

我試圖從PHP中的MSSQL查詢導出到xlsx文件。我無法訪問我的網站託管的服務器,因此我無法使用任何尚未構建到PHP中的內容。我使用PHP 5.4。到目前爲止,我已經創建了一個<a></a>,它引用了一個應該從我的MSSQL DB中提取數據的php頁面。相反,它以xls格式給我一個空白文件。當我打開它時,它會拋出一個關於沒有在下載文件夾中有stylesheet.css文件的錯誤,然後打開一個空白的xls工作簿。這是我的ExportToExcel.php文件:如何從PHP導出到Excel(xlsx)

$tsql = "select ID, TableName, UpdateDate from pmdb.TableUpdates order by UpdateDate"; 
//echo $tsql . "<br>"; 
$getqueries = $conn->query($tsql); 
//echo "<BR>"; 
//var_dump($getqueries); 
$result = $getqueries->fetchALL(PDO::FETCH_ASSOC); 
$filename = "TableUpdates"; 
//var_dump($tsql); 

header("Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); 
header("Content-Disposition: attachment; filename=$filename.xls"); 

/*******Start of Formatting for Excel*******/ 

//define separators (defines columns in excel & tabs in word) 
$sep = "\t"; //tabbed character 
$br = "\r\n"; //line break 

//start of printing column names as names of SQL fields 
//$max = sqlsrv_num_fields($result); 
/* for ($i = 0; $i < $max; $i++) { 
echo sqlsrv_field_metadata($result,$i) . "\t"; 
} 
print("\n"); */ 

foreach(sqlsrv_field_metadata($result) as $fieldMetadata) { 
foreach($fieldMetadata as $name => $value) { 
    echo "$value" . $sep; 
} 
} 
echo $br; 

//end of printing column names 

//start while loop to get data 
while($row = sqlsrv_fetch($result)) 
{ 
    $schema_insert = ""; 
    for($j=0; $j<sqlsrv_num_fields($result);$j++) 
    { 
     if(!isset($row[$j])) 
      $schema_insert .= "NULL".$sep; 
     elseif ($row[$j] != "") 
      $schema_insert .= "$row[$j]".$sep; 
     else 
      $schema_insert .= "".$sep; 
    } 
    $schema_insert = str_replace($sep."$", "", $schema_insert); 
    $schema_insert = preg_replace("/\r\n|\n\r|\n|\r/", " ", $schema_insert); 
    $schema_insert .= "\t"; 
    print(trim($schema_insert)); 
    print "\n"; 
} 

我得到這個最自其他問題,但沒有人有任何一個答案。

編輯

我已經進一步得到了一點。我現在可以將數據打印到excel中,儘管它仍然會拋出錯誤

的文件格式和擴展名。 。 。不匹配。 。 。

問題在負載:缺少文件:C:\ Users \用戶名\下載\ stylesheet.css中

,但在一列一切印刷品。它用逗號分隔,但所有值都在同一列中。下面是代碼的新部分:

//define separators (defines columns in excel & tabs in word) 
$sep = ","; //tabbed character 
$br = "<br>"; //line break 

$hsql = "select Headings from TableHeadings where TableName = 'TableUpdates' order by ID"; 
$getHeadings = $conn->query($hsql); 
$rHeadings = $getHeadings->fetchALL(PDO::FETCH_ASSOC); 

$headings = array($rHeadings[0]["Headings"],$rHeadings[1]["Headings"],$rHeadings[2]["Headings"]); 

//start of printing column names as names of SQL fields 
foreach($headings as $Heading => $value) 
{ 
    echo "$value" . $sep; 
} 
echo $br; 
for ($i = 0;$i < 3;$i++) 
{ 
    for($l = 0;$l < 3;$l++) 
    { 
     if ($l == 0) 
     { 
      echo $result[$i]["ID"] . $sep; 
     } 
     elseif ($l == 1) 
     { 
      echo $result[$i]["TableName"] . $sep; 
     } 
     else 
     { 
      echo $result[$i]["UpdateDate"]; 
     } 
    } 
    echo $br; 
} 

我該如何得到這個值來回顯每個值,然後移動到下一個單元?它有逗號,但看起來是這樣的:

ID,TableName,UpdateDate, 
1,pmdb.MaterialTracking,2016-07-08 13:45:05.963 
2,pmdb.OSP_OPR_Report,2016-07-08 13:45:45.883 
3,pmdb.COEI_OPR_Report,2016-07-08 13:45:47.920 
+0

您並未創建xls文件。 '.xls'是一個複合-ole格式。您正在生成一個.csv文件,而LYING擅長其類型。這就是爲什麼Excel告訴你格式不匹配的原因。沒有辦法繞過這個,因爲Excel知道你在說謊。要麼使用正確的Excel庫,要麼告訴Excel它是一個csv文件,正確的方法。 –

+0

@MarcB我認爲這是正確的庫頭(「Content-Type:application/vnd.openxmlformats-officedocument.spreadsheetml.sheet」)'。如果沒有,那麼什麼是或如何將其更改爲csv?如果我新的話,我已經做到了。 – Mike

+0

那不是圖書館。這只是告訴客戶「我向你發送這種類型的文件」。然後你發送的數據是完全不同的類型 –

回答

0

我有固定的header,以便Excel知道,那就是它的開放csv文件。我不再有任何錯誤。

header("Content-Type: application/x-csv"); 
header("Content-Disposition: attachment; filename=$filename.csv"); 

我還沒有任何其他的庫,所以不會有任何格式,只是一個csv文件。