伪Excel导出新版代码

    /// <summary>
    /// 导出Excel  CreateExcel(ds, "统计表.xls",new int[]{6,8});
    /// </summary>
    /// <param name="ds">DataSet ds</param>
    /// <param name="FileName">文件名称</param>
    /// <param name="iarry">new int[] {6,8};</param>
    public void CreateExcel(DataSet ds, string FileName,int[] iarry)
    {
        FileName = HttpUtility.UrlEncode(FileName, System.Text.Encoding.UTF8);

        HttpResponse resp;
        resp = Page.Response;
        resp.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
        resp.AppendHeader("Content-Disposition", "attachment;filename=" + FileName);

        StringBuilder colHeaders = new StringBuilder();
        StringBuilder ls_item = new StringBuilder();
       
        DataTable dt = ds.Tables[0];
        DataRow[] myRow = dt.Select();//可以类似dt.Select("id>10")之形式达到数据筛选目的
        int i = 0;
        int cl = dt.Columns.Count;

        //取得数据表各列标题,各标题之间以t分割,最后一个列标题后加回车符
        for (i = 0; i < cl; i++)
        {
            if (i == (cl - 1))//最后一列,加n
            {
                colHeaders.Append(dt.Columns[i].Caption.ToString() + "\n");
            }
            else
            {
                colHeaders.Append(dt.Columns[i].Caption.ToString() + "\t");
            }

        }
        resp.Write(colHeaders.ToString());
        //向HTTP输出流中写入取得的数据信息

        //逐行处理数据  
        foreach (DataRow row in myRow)
        {
            //当前行数据写入HTTP输出流,并且置空ls_item以便下行数据    
            for (i = 0; i < cl; i++)
            {
                if (iarry.Contains(i))
                {
                    ls_item.Append("=\"" + Convert.ToString(row[i]) + "\"\t");
                }
                else
                {
                    if (i == (cl - 1))//最后一列,加n
                    {
                        ls_item.Append(row[i].ToString() + "\n");
                    }
                    else
                    {
                        ls_item.Append(Convert.ToString(row[i]) + "\t");
                    }
                }
            }

            resp.Write(ls_item.ToString());
            ls_item.Clear();
        }
        resp.End();
    }

第二种

    /// <summary>
    /// DataSetToExcel(this, ds, "人员信息表.xls", new string[] { "身份证", "账户" });
    /// </summary>
    /// <param name="page">this</param>
    /// <param name="ds">DateSet</param>
    /// <param name="fileName">xxx.xxx</param>
    /// <param name="sarry">数字文本</param>
    public void DataSetToExcel(Page page,DataSet ds,string fileName,string[] sarry )
    {
        page.Response.Clear();
        page.Response.Buffer = true;
        page.Response.Charset = "GB2312";
        //page.Response.Charset = "UTF-8";
        fileName = HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8);
        page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + fileName);
        page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");//设置输出流为简体中文
        page.Response.ContentType = "application/vnd.ms-excel";//设置输出文件类型为excel文件。 
        page.Response.ContentType = "";
        page.EnableViewState = false;
       
        /// 1) 文本:vnd.ms-excel.numberformat:@ 
        /// 2) 日期:vnd.ms-excel.numberformat:yyyy/mm/dd 
        /// 3) 数字:vnd.ms-excel.numberformat:#,##0.00 
        /// 4) 货币:vnd.ms-excel.numberformat:¥#,##0.00 
        /// 5) 百分比:vnd.ms-excel.numberformat: #0.00%
       
        StringBuilder sb = new StringBuilder();
        int count = 0;
        foreach (DataTable tb in ds.Tables)
        {
            sb.AppendLine("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\">");
            sb.AppendLine("<table cellspacing=\"0\" cellpadding=\"5\" rules=\"all\" border=\"1\">");

            sb.AppendLine("<tr style=\"font-weight: bold; white-space: nowrap;\">");
            foreach (DataColumn column in tb.Columns)
            {
                sb.AppendLine("<td>" + column.ColumnName + "</td>");
            }
            sb.AppendLine("</tr>");

            foreach (DataRow row in tb.Rows)
            {
                sb.Append("<tr>");
                foreach (DataColumn column in tb.Columns)
                {
                    if (sarry.Contains(column.ColumnName))
                        sb.Append("<td style=\"vnd.ms-excel.numberformat:@\">" + row[column].ToString() + "</td>");
                    else
                        sb.Append("<td>" + row[column].ToString() + "</td>");
                }
                sb.AppendLine("</tr>");
                count++;
            }
            sb.AppendLine("</table>");
        }

        page.Response.Write(sb.ToString());
        page.Response.End();
    }
posted on 2016-07-19 17:28  雪夜  阅读(207)  评论(0编辑  收藏  举报