1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > excel npoi 连接_Asp.Net使用Npoi导入导出Excel的方法

excel npoi 连接_Asp.Net使用Npoi导入导出Excel的方法

时间:2020-06-06 06:35:02

相关推荐

excel npoi 连接_Asp.Net使用Npoi导入导出Excel的方法

针对Excel文件的导入与导出是非常常见的功能之一。本文实例讲述了使用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();

}

二、导入Excel

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

具体功能代码如下:

///

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

///

/// Excel服务器路径

/// Excel表名称

///

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;

}

}

相信本文所述对大家的程序设计有一定的借鉴价值。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。