[转]c# 导出到excel

 原文地址:

http://hi.baidu.com/spider__/blog/item/f3ee210f61c55fe8ab6457e1.html/cmtid/ea57e822a00206aa4623e8fd

导出到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 += "

";
//写出列名
data += "";
foreach (DataColumn column in tb.Columns)
{
data += "";
}
data += "";

            //写出数据
foreach (DataRow row in tb.Rows)
{
data += "

";
foreach (DataColumn column in tb.Columns)
{
if (column.ColumnName.Equals("证件编号") || column.ColumnName.Equals("报名编号"))
data += "";
else
data += "";
}
data += "";
}
data += "
" + column.ColumnName + "
" + row[column].ToString() + "" + row[column].ToString() + "
";
}

        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();
}

///////////////////////////////////////////////////////////////////

StringBuilder的性能和“+”的性能的区别。

public static string ExportTable(DataSet ds)
{
StringBuilder sb = new StringBuilder();
//data = ds.DataSetName + "\n";
int count = 0;

foreach (DataTable tb in ds.Tables)
{
//data += tb.TableName + "\n";
sb.AppendLine("");
sb.AppendLine("

");
//写出列名
sb.AppendLine("");
foreach (DataColumn column in tb.Columns)
{
sb.AppendLine("");
}
sb.AppendLine("");

//写出数据
foreach (DataRow row in tb.Rows)
{
sb.Append("");
foreach (DataColumn column in tb.Columns)
{
if (column.ColumnName.Equals("证件编号") || column.ColumnName.Equals("报名编号"))
sb.Append("");
else
sb.Append("");
}
sb.AppendLine("");
count++;
}
sb.AppendLine("
" + column.ColumnName + "
" + row[column].ToString() + "" + row[column].ToString() + "
");
}

return sb.ToString();
}

你可能感兴趣的:(c#,dataset,string,excel,sql,table)