.net导出excel文件操作类续

转载 2012年03月22日 12:01:04

在此之前已经写过一篇关于“.net导出wordexcel等文件操作类“的文章详见:http://www.cnblogs.com/dreamof/archive/2008/06/24/1229069.html
  
本文的目的主要是讲讲.net导出excel的技巧及解决以下问题:

  (1)出现导出长串数据(如身份证)EXCEL中后显示为科学计数法的格式,或者报表中显示为001的数据导出到Excel后成了1的格式;

  (2)列宽自适应;

  涉及到的技巧如下:

  (1)       新建一个最原始的DataGrid,对其设置如下:Visible=false,AllowPaging=false;

  (2)       导出数据之前将要导出的数据绑定到DataGrid中;

  (3)       对长数据如身份证、或类似001的数据库进行格式化,转换为文本格式;

  (4)       调用操作类获取DataGrid控件的数据并导出,此时你会发现导出的数据解决了问题(1)并且数据列宽自适应了;

  .net导出excel文件操作类如下:

.net导出excel文件操作类
using System;
using System.Data;
using System.Web;
using System.Text;
using System.IO;

namespace GZPI.Service.AgenciesChannel
{
    
/// <summary>
    
/// ExportData 的摘要说明。
    
/// </summary>
    public class ExportData
    {
        
public ExportData()
        {
            
//
            
// TODO: 在此处添加构造函数逻辑
            
//
        }
        
/// <summary>
        
/// 
        
/// </summary>
        
/// <param name="dt"></param>
        
/// <param name="strFileName">含.xls</param>
        public static void ExportDataToExcel(DataTable dt, string FileName)
        {
            
try
            {
                StringWriter sw 
= new StringWriter();
                
string colstr = "";
                
foreach (DataColumn col in dt.Columns)
                {
                    colstr 
+=col.ColumnName + "\t";
                }
                sw.WriteLine(colstr);

                
foreach (DataRow row in dt.Rows)
                {
                    colstr 
= "";
                    
foreach (DataColumn col in dt.Columns)
                    {
                        colstr 
+=row[col.ColumnName].ToString() + "\t";
                    }
                    sw.WriteLine(colstr);
                }
                sw.Close();
                HttpContext.Current.Response.AppendHeader(
"Content-Disposition""attachment;filename=" + HttpUtility.UrlEncode(FileName+ ".xls", System.Text.Encoding.UTF8));
                HttpContext.Current.Response.ContentType 
= "application/ms-excel";    
                System.Web.HttpContext.Current.Response.ContentEncoding 
= System.Text.Encoding.Default;
                System.Web.HttpContext.Current.Response.Write(sw);
                System.Web.HttpContext.Current.Response.End();
            }
            
catch (Exception ex)
            {
                
throw ex;
            }
        }

        
public static void ExportDataToExcelByWeb(DataTable dt,System.Web.UI.WebControls.DataGrid DGOutPut,string FileName)
        {
            
try
            {
                DGOutPut.Visible
=true;
                DGOutPut.DataSource
=dt;
                DGOutPut.DataBind();
                System.Web.HttpContext.Current.Response.Clear();
                System.Web.HttpContext.Current.Response.Buffer 
= true;
                System.Web.HttpContext.Current.Response.Charset 
= "GB2312";
                System.Web.HttpContext.Current.Response.AppendHeader(
"Content-Disposition""attachment;filename="+FileName+".xls");
                System.Web.HttpContext.Current.Response.ContentEncoding 
= System.Text.Encoding.GetEncoding("GB2312");//设置输出流为简体中文
                System.Web.HttpContext.Current.Response.ContentType = "application/ms-excel";//设置输出文件类型为excel文件。 
                DGOutPut.EnableViewState = false;
                System.Globalization.CultureInfo myCItrad 
= new System.Globalization.CultureInfo("ZH-CN"true);
                System.IO.StringWriter oStringWriter 
= new System.IO.StringWriter(myCItrad);
                System.Web.UI.HtmlTextWriter oHtmlTextWriter 
= new System.Web.UI.HtmlTextWriter(oStringWriter);
                DGOutPut.RenderControl(oHtmlTextWriter);
                System.Web.HttpContext.Current.Response.Write(oStringWriter.ToString());
                System.Web.HttpContext.Current.Response.End();
                DGOutPut.Visible
=false;
            }
            
catch (Exception ex)
            {
                
throw ex;
            }
        }

    }
}

 

  实例如下
  1、前台代码:
  <asp:DataGrid id="DGOutPut" runat="server" Visible="False"></asp:DataGrid>
  2、后台代码:  

后台代码
        private void DGOutPut_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
        {
            
if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
            {
                e.Item.Cells[
1].Attributes.Add("style""vnd.ms-excel.numberformat:@");         
            }
        }

        
private void BtnOutPut_Click(object sender, System.EventArgs e)
        {            
            DataTable dt
=_da.ExecuteDataTable(sql);               
       GZPI.Service.AgenciesChannel.ExportData.ExportDataToExcelByWeb(dt,DGOutPut,
"续办人事代理业务信息");    
        }

C#读取和导出EXCEL类库(可操作多个SHEET)

改进的一个EXCEL类,可以读取EXCEL,也可以将内容导出到EXCEL.操作多个SHEET比较方便. 而且无须安装任何EXCEL. 1.读取. public void Read(str...
  • hwm831002
  • hwm831002
  • 2013年09月30日 10:59
  • 6676

.Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法)

MVC控制器导出导入Excel方法,可用于java SSH架构
  • GX_LiangWenLong
  • GX_LiangWenLong
  • 2015年05月30日 19:16
  • 20618

.NET操作Excel免费开源类库简介及比较

自从上次找到NPOI之后,根据园友提供的线索以及Google,又找到了一些开源免费的类库,所以都简单体验了一遍。 主要找到以下类库: MyXls(http://sourceforge.net/pr...
  • sven_xu
  • sven_xu
  • 2015年06月02日 09:18
  • 1214

asp.net 对 excel文件操作的类

  • 2008年11月14日 12:11
  • 9KB
  • 下载

Excel格式类型文件操作的.NET 控件Spire.XLS

Spire.XLS for .NET控件是e-iceblue公司开发的一款支持对所有Excel格式类型文件进行操作的.NET 控件。它适用于任何类型的应用程序比如ASP.NET Web应用程序或者Wi...
  • baobiaokongjian
  • baobiaokongjian
  • 2014年06月24日 11:29
  • 515

asp.net文件操作基类

using System; using System.Data; using System.Configuration; using System.Web; using System.Web....
  • wangsky2
  • wangsky2
  • 2011年12月01日 09:05
  • 955

.net 文件操作类(转载)

using System; using System.Collections.Generic; using System.Text; using System.IO; #endregi...
  • anfeng_8379
  • anfeng_8379
  • 2012年01月13日 11:11
  • 4312

.NET文件操作类 (转载)

using System; using System.Collections.Generic; using System.Text; using System.IO; #endregion ...
  • lhx527099095
  • lhx527099095
  • 2012年09月26日 17:27
  • 1048

VB.NET中文件操作类

 程序是在文件中保存的,因此我们常常需要使用到目录(文件夹)来组织文件,在VB.NET中有几个重要的类用于目录的操作。 1.Directory 这个类是一个静态类,它可以不使用new方法产生而直接...
  • neusoft06
  • neusoft06
  • 2014年03月04日 19:05
  • 833

基于NPOI的打开/导出Excel文件操作类

  • 2010年12月15日 16:43
  • 2.14MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:.net导出excel文件操作类续
举报原因:
原因补充:

(最多只允许输入30个字)