好久沒有寫點什麼了,也許是太忙。一年了,積累了不少好的東東,有機會時就寫出來與大家分享。
好,言歸正傳。
匯出到Excel/Csc檔案並不難,所以就有好多方法:控制項直接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為我們做了太多的事,不管是應該的還是不應該的。
怎麼解決?請看代碼:
public static string ExportTable(DataSet ds)
{
string data = "";
//data = ds.DataSetName + "\n";
foreach (DataTable tb in ds.Tables)
{
//data += tb.TableName + "\n";
data += "<table cellspacing=\"0\" cellpadding=\"5\" rules=\"all\" border=\"1\">";
//寫出列名
data += "<tr style=\"font-weight: bold; white-space: nowrap;\">";
foreach (DataColumn column in tb.Columns)
{
data += "<td>" + column.ColumnName + "</td>";
}
data += "</tr>";
//寫出資料
foreach (DataRow row in tb.Rows)
{
data += "<tr>";
foreach (DataColumn column in tb.Columns)
{
if (column.ColumnName.Equals("證件編號") || column.ColumnName.Equals("報名編號"))
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 void ExportDsToXls(Page page, string sql)
{
ExportDsToXls(page, "FileName", sql);
}
public static void ExportDsToXls(Page page, string fileName, string sql)
{
DataSet ds = DBUtil.GetDataSet(sql);
if (ds != null) ExportDsToXls(page, fileName, ds);
}
public static void ExportDsToXls(Page page, DataSet ds)
{
ExportDsToXls(page, "FileName", ds);
}
public static void ExportDsToXls(Page page, string fileName, DataSet ds)
{
page.Response.Clear();
page.Response.Buffer = true;
page.Response.Charset = "GB2312";
//page.Response.Charset = "UTF-8";
page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + fileName + System.DateTime.Now.ToString("_yyMMdd_hhmm") + ".xls");
page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");//設定輸出資料流為簡體中文
page.Response.ContentType = "application/ms-excel";//設定輸出檔案類型為excel檔案。
page.EnableViewState = false;
page.Response.Write(ExportTable(ds));
page.Response.End();
}
//style="vnd.ms-excel.numberformat:@" 可以去除自動科學計數法的困擾
//輸出為Table,能夠最大限度的減少欄位中資料對產生的檔案格式的影響,在這裡我沒有處理資料中含有HTML標籤的情況 在頁面後台中,這樣使用就可以了:
protected void lbtnToExcel_Click(object sender, EventArgs e)
{
string strWhere = BuildSearchWhereString();
string strOrder = this.hidOrderString.Value;
string sql = "SELECT 報名編號, 證件編號, 姓名, 考區考點, 報考類別, "
+ "行政區劃名稱 AS 行政區劃, 單位名稱 AS 工作單位, 畢業學校名稱, 畢業專業名稱 AS 畢業專業, 畢業年月, "
+ "郵寄地址, 性別"
+ " from [VW報名]";
if (!string.IsNullOrEmpty(strWhere)) sql += " where " + strWhere;
if (!string.IsNullOrEmpty(strOrder)) sql += " order by " + strOrder;
else sql += " order by [報考類別]";
PageExport.ExportDsToXls(this.Page, "BaoMing", sql);
dataBind();
}
暫寫到這裡,休息。
更新日期:2008-5-5