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 }