|
ASP.NET針對Excel文件的導入與導出是非常常見的功能之一。本文實例講述了ASP.NET使用Npoi導入導出Excel的方法。分享給大家供大家參考之用。具體方法如下:
在使用Npoi導出Excel的時候,服務器可以不裝任何office組件,一般在導出時用到Npoi導出Excel文件,所導Excel也符合規范,打開時也不會有任何文件損壞之類的提示。但是在做導入時還是使用OleDb的方式,這種方式的導入在服務器端似乎還是需要裝office組件的。
一、Npoi導出/下載Excel
具體功能代碼如下:
public void NpoiExcel(DataTable dt, string title){ NPOI.HSSF.UserModel.HSSFWorkbook book = new NPOI.HSSF.UserModel.HSSFWorkbook(); NPOI.SS.UserModel.ISheet sheet = book.CreateSheet("Sheet1"); NPOI.SS.UserModel.IRow headerrow = sheet.CreateRow(0); ICellStyle style = book.CreateCellStyle(); style.Alignment = HorizontalAlignment.Center; style.VerticalAlignment = VerticalAlignment.Center; for (int i = 0; i < dt.Columns.Count; i++) { ICell cell = headerrow.CreateCell(i); cell.CellStyle = style; cell.SetCellValue(dt.Columns[i].ColumnName); } MemoryStream ms = new MemoryStream(); book.Write(ms); Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", HttpUtility.UrlEncode(title + "_" + DateTime.Now.ToString("yyyy-MM-dd"), System.Text.Encoding.UTF8))); Response.BinaryWrite(ms.ToArray()); Response.End(); book = null; ms.Close(); ms.Dispose();}
導入仍然是用OleDb這種方式,感興趣的朋友可以嘗試一下其他方法。
具體功能代碼如下:
/// <summary>/// 連接Excel 讀取Excel數據 并返回DataSet數據集合/// </summary>/// <param name="filepath">Excel服務器路徑</param>/// <param name="tableName">Excel表名稱</param>/// <returns></returns>public static System.Data.DataSet ExcelSqlConnection(string filepath, string tableName){ string strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filepath + ";Extended Properties='Excel 8.0;HDR=YES;IMEX=1'"; OleDbConnection ExcelConn = new OleDbConnection(strCon); try { string strCom = string.Format("SELECT * FROM [Sheet1$]"); ExcelConn.Open(); OleDbDataAdapter myCommand = new OleDbDataAdapter(strCom, ExcelConn); DataSet ds = new DataSet(); myCommand.Fill(ds, "[" + tableName + "$]"); ExcelConn.Close(); return ds; } catch { ExcelConn.Close(); return null; }}
相信本文所述對大家的ASP.NET程序設計有一定的借鑒價值。
AspNet技術:Asp.Net使用Npoi導入導出Excel的方法,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。