匯出到Excel檔案並不難,所以就有好多方法:控制項直接Render、把DataSet輸出成String再Write出來等,(當然如果調用Excel程式的庫檔案的話還可以使用更強的直接操作Excel的方法,但這種方法用於Web服務顯得有點要求太高:必須讓Web伺服器安裝指定版本的Excel或其支援庫檔案)。就其前兩種方法,實際上也是一樣的,Render也是把由DataSet轉變的View產生為一個Table輸出到用戶端而已,只不過隱藏了細節,如果不信,你用EditPlus什麼的看看產生的.xls檔案就知道了。
Excel的識別力太強了,以至於它本身的格式、Csv格式、Tab分隔字元格式、網頁的Table格式等都能夠很好的開啟。但是它“太聰明”了,以至於自動識別數字和字串,而且要把超過11位的數字自動變為科學計數法的格式,你試試輸入“123456789012”,離開那個儲存格,就成“123457E+11”了,夠聰明的吧,不過有時會讓我們感覺不便,因為我輸入的就是我自己的社會安全號碼碼,尾巴上沒有“X”,本來好好的15位元字,得現在成這麼個計數法了。那我就改改顯示格式吧,改為把數字顯示為文本,好了。可是國家的身份證升級了,號碼變成18位,我把它輸入到資料庫,匯出來時,用剛才的方法處理過,18位沒錯,可是最後三位怎麼都是零了!Excel為我們做了太多的事,不管是應該的還是不應該的。
怎麼解決?請看代碼:
private void Export(GridView GV, string FileType, string FileName)
{
Response.Charset = "UTF8";
Response.ContentEncoding = System.Text.Encoding.UTF8;
Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(FileName, Encoding.UTF8).ToString());
Response.ContentType = FileType;
this.EnableViewState = false;
Response.Write(PubFuncs.GridViewToExportTable(GV));
Response.End();
}
public static string ExportTable(DataTable dt)
{
string data = "";
data += "<table cellspacing=/"0/" cellpadding=/"5/" rules=/"all/" border=/"1/">";
//寫出列名
data += "<tr style=/"font-weight: bold; white-space: nowrap;/">";
foreach (DataColumn column in dt.Columns)
{
data += "<td>" + column.ColumnName + "</td>";
}
data += "</tr>";
//寫出資料
foreach (DataRow row in dt.Rows)
{
data += "<tr>";
foreach (DataColumn column in dt.Columns)
{
if (GetIsNumber(row[column].ToString()))
{
data += "<td style=/"vnd.ms-excel.numberformat:@/">" + row[column].ToString() + "</td>";
}
else
{
data += "<td>" + row[column].ToString() + "</td>";
}
}
data += "</tr>";
}
data += "</table>";
return data;
}
public static string GridViewToExportTable(GridView gv)
{
string data = "";
data += "<table cellspacing=/"0/" cellpadding=/"5/" rules=/"all/" border=/"1/">";
//寫出列名
data += "<tr style=/"font-weight: bold; white-space: nowrap;/">";
for (int i = 0; i < gv.HeaderRow.Cells.Count; i++)
{
data += "<td>" + gv.HeaderRow.Cells[i].Text.ToString() + "</td>";
}
data += "</tr>";
//寫出資料
for (int i = 0; i < gv.Rows.Count; i++)
{
data += "<tr>";
for (int j = 0; j < gv.Rows[i].Cells.Count; j++)
{
string strvlue = gv.Rows[i].Cells[j].Text.Trim().Replace(" ", "");
if (GetIsNumber(strvlue))
{
data += "<td style=/"vnd.ms-excel.numberformat:@/">" + strvlue + "</td>";
}
else
{
data += "<td>" + strvlue + "</td>";
}
}
data += "</tr>";
}
data += "</table>";
return data;
}