仔细阅读本文相信本文所述对大家的asp.net程序设计有一定的借鉴价值

  asp.net针对Excel文件的导入与导出是非常常见的功能之一。本文实例讲述了Asp.Net使用Npoi导入导出Excel的方法。分享给大家供大家参考之用。具体方法如下:

  在使用Npoi导出Excel的时候,服务器www.e78.com可以不装任何office组件,一般在导出时用到Npoi导出Excel文件,所导Excel也符合规范,打开时也不会有任何文件损坏之类的提示。但是在做导入时还是使用OleDb的方式,这种方式的导入在服务器端似乎还是需要装office组件的。

  一、Npoi导出/下载Excel

  具体功能代码如下:

  view sourceprint?01 public void NpoiExcel(DataTable dt, string title)

  02 {

  03 NPOI.HSSF.UserModel.HSSFWorkbook book = new NPOI.HSSF.UserModel.HSSFWorkbook();

  04 NPOI.SS.UserModel.ISheet sheet = book.CreateSheet("Sheet1");

  05

  06 NPOI.SS.UserModel.IRow headerrow = sheet.CreateRow(0);

  07 ICellStyle style = book.CreateCellStyle();

  08 style.Alignment = HorizontalAlignment.Center;

  09 style.VerticalAlignment = VerticalAlignment.Center;

  10

  11 for (int i = 0; i < dt.Columns.Count; i++)

  12 {

  13 ICell cell = headerrow.CreateCell(i);

  14 cell.CellStyle = style;

  15 cell.SetCellValue(dt.Columns[i].ColumnName);

  16

  17 }

  18

  19 MemoryStream ms = new MemoryStream();

  20 book.Write(ms);

  21 Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", HttpUtility.UrlEncode(title + "_" + DateTime.Now.ToString("yyyy-MM-dd"), System.Text.Encoding.UTF8)));

  22 Response.BinaryWrite(ms.ToArray());

  23 Response.End();

  24 book = null;

  25 ms.Close();

  26 ms.Dispose();

  27 }

  二、Asp.Net导入Excel

  导入仍然是用OleDb这种方式,感兴趣的朋友可以尝试一下其他方法。

  具体功能代码如下:

  view sourceprint?01 ///

  02 /// 连接Excel 读取Excel数据 并返回DataSet数据集合

  03 ///

  04 /// Excel服务器路径

  05 /// Excel表名称

  06 ///

  07 public static System.Data.DataSet ExcelSqlConnection(string filepath, string tableName)

  08 {

  09

  10 string strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filepath + ";Extended Properties='Excel 8.0;HDR=YES;IMEX=1'";

  11 OleDbConnection ExcelConn = new OleDbConnection(strCon);

  12 try

  13 {

  14 string strCom = string.Format("SELECT * FROM [Sheet1$]");

  15 ExcelConn.Open();

  16 OleDbDataAdapter myCommand = new OleDbDataAdapter(strCom, ExcelConn);

  17 DataSet ds = new DataSet();

  18 myCommand.Fill(ds, "[" + tableName + "$]");

  19 ExcelConn.Close();

  20 return ds;

  21 }

  22 catch

  23 {

  24 ExcelConn.Close();

  25 return null;

  26 }

  27 }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值