简单回顾NPOI导入导出excel文件
当前环境.net4.0
去官方下下载: NOPI官网
关于NOPI的详细,这里就不再介绍。
在项目中,我们只需引入 NPOI.dll 就可以了.
接下来................................................................
上代码......... ..........................................................
/// <summary>
/// 导出
/// </summary>
/// <param name="dt">数据源</param>
/// <param name="filePath">导出地址</param>
public static void ExportExcel(DataTable dt, string filePath)
{
try
{ //创建文档
IWorkbook workbook = new HSSFWorkbook();
//创建表格
ISheet sheet = workbook.CreateSheet(dt.TableName) as NPOI.HSSF.UserModel.HSSFSheet;
//第0行合并单元格,并且插入标题
//sheet.AddMergedRegion(new CellRangeAddress(0, 0, 0, dt.Columns.Count));
//IRow row1 = sheet.CreateRow(0);
////row1.CreateCell(0).SetCellValue(dt.TableName);
//ICell col = row1.CreateCell(0);
//col.SetCellValue(dt.TableName);
//col.CellStyle.Alignment = HorizontalAlignment.Center;
//col.CellStyle.VerticalAlignment = VerticalAlignment.Center;
//col.CellStyle.FillBackgroundColor = NPOI.HSSF.Util.HSSFColor.Blue.Index; //从第一行获取和插入列名
IRow row = sheet.CreateRow();
for (int i = ; i < dt.Columns.Count; i++)
{
ICell cell = row.CreateCell(i);
cell.SetCellValue(dt.Columns[i].ColumnName);
} //从第二行中开始插入数据
int index = ;
foreach (DataRow rows in dt.Rows)
{
row = sheet.CreateRow(index);
foreach (DataColumn item in dt.Columns)
{
ICell cel= row.CreateCell(item.Ordinal);
cel.SetCellValue(rows[item].ToString()); } index++;
} MemoryStream ms = new MemoryStream();
workbook.Write(ms); using (FileStream fileStream = new FileStream(filePath, FileMode.OpenOrCreate))
{
// workbook.Write(fileStream);
// fileStream.Flush(); byte[] bArr = ms.ToArray();
fileStream.Write(bArr, , bArr.Length);
fileStream.Flush(); }
workbook.Close();
}
catch (Exception ex)
{ throw ex;
}
}
具体使用方法如下:
数据是模拟数据..........
class Program
{
static void Main(string[] args)
{
DataTable dt = new DataTable("学生表");
dt.Columns.Add("ID", typeof(int));
dt.Columns.Add("Name", typeof(string));
dt.Columns.Add("Age", typeof(int)); for (int i = ; i <= ; i++)
{ DataRow row = dt.NewRow();
row["ID"] = i;
row["Name"] = "名字" + i;
row["Age"] = i;
dt.Rows.Add(row);
}
//导出
ExportExcel(dt, @"d:\xxx2.xls");
Console.WriteLine("OK");
Console.ReadKey();
}
接下来是导入方法。
/// <summary>
/// 导入
/// </summary>
/// <param name="filePath">excel路径</param>
/// <param name="sheetIndex">sheet索引,默认为第一个</param>
/// <returns></returns>
public static DataTable ImportExcel(string filePath, int sheetIndex=)
{
try
{
using (FileStream fs = new FileStream(filePath, FileMode.OpenOrCreate))
{
DataTable dt = new DataTable();
IWorkbook workbook = new HSSFWorkbook(fs); // sheet索引,默认为第一个
ISheet sheet = workbook.GetSheetAt(sheetIndex); //读取第一行列名
foreach (ICell cels in sheet.GetRow(sheet.FirstRowNum).Cells)
{
dt.Columns.Add(cels.ToString());
} //第二行开始
for (int i = (sheet.FirstRowNum + ); i <= sheet.LastRowNum; i++)
{
IRow rows = sheet.GetRow(i);
DataRow dataRow = dt.NewRow(); //遍历每行每列的值
for (int j = rows.FirstCellNum; j < rows.LastCellNum; j++)
{
dataRow[j] = rows.GetCell(j).ToString();
} dt.Rows.Add(dataRow);
} workbook.Close(); return dt; }
}
catch (Exception ex)
{ throw ex;
} }
使用方法如下:
class Program
{
static void Main(string[] args)
{
DataTable dt = new DataTable("学生表");
dt.Columns.Add("ID", typeof(int));
dt.Columns.Add("Name", typeof(string));
dt.Columns.Add("Age", typeof(int)); for (int i = ; i <= ; i++)
{ DataRow row = dt.NewRow();
row["ID"] = i;
row["Name"] = "名字" + i;
row["Age"] = i;
dt.Rows.Add(row);
}
//导入并且返回DataTable,您可以选择用sqlbulkCopy批量插入数据库
var data= ImportExcel(@"d:\xxx2.xls");
Console.WriteLine("OK");
Console.ReadKey();
关于sqlbulkCopy批量插入数据库,效率还是挺高的,详情可以看我上一篇文章。
本文到此结束。
简单回顾NPOI导入导出excel文件的更多相关文章
- .Net core NPOI导入导出Excel
最近在想.net core NPOI 导入导出Excel,一开始感觉挺简单的,后来真的遇到很多坑.所以还是写一篇博客让其他人少走一些弯路,也方便忘记了再重温一遍.好了,多的不说,直接开始吧. 在.Ne ...
- NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中
以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...
- NPOI导入导出Excel
.net mvc利用NPOI导入导出excel 注意:如何导出的提交方式ajax导出是失效的! 解决方案是:js处理l两个表单的提交 代码: 第一步. 在页面里面加入2个隐藏的iframe, 如下 ...
- (C#)利用Aspose.Cells组件导入导出excel文件
Aspose.Cells组件可以不依赖excel来导入导出excel文件: 导入: public static System.Data.DataTable ReadExcel(String strFi ...
- 【转】 (C#)利用Aspose.Cells组件导入导出excel文件
Aspose.Cells组件可以不依赖excel来导入导出excel文件: 导入: public static System.Data.DataTable ReadExcel(String strFi ...
- ASP.NET Core导入导出Excel文件
ASP.NET Core导入导出Excel文件 希望在ASP.NET Core中导入导出Excel文件,在网上搜了一遍,基本都是使用EPPlus插件,EPPlus挺好用,但商用需要授权,各位码友若有好 ...
- 导入导出Excel文件
搭建环境 先新建web project ,然后Add Struts Capabilties: 下载导入导出Excel所需的jar包: poi-3.8-20120326.jar包 : http:// ...
- C#,使用NPOI,导出excel文件
/// <summary> /// 导出excel文件 /// </summary> /// <param name="dt">Table表数据 ...
- .net利用NPOI导入导出Excel
NPOI在.net中的操作Excel 1.读取 using (FileStream stream = new FileStream(@"c:\客户资料.xls", FileMode ...
随机推荐
- clojure基础入门(一)
最近在看storm的源码,就学习分享下clojure语法. 阅读目录: 概述 变量 运算符 流程控制 总结 概述 clojure是一种运行在JVM上的Lisp方言,属于函数式编程范式,它和java可以 ...
- [.net 面向对象程序设计进阶] (26) 团队开发利器(五)分布式版本控制系统Git——图形化Git客户端工具TortoiseGit
[.net 面向对象程序设计进阶] (26) 团队开发利器(五)分布式版本控制系统Git——图形化Git客户端工具TortoiseGit 读前必备: 接上篇: 分布式版本控制系统Git——使用GitS ...
- C语言 · 冒泡排序
for(int k=0;k<N;k++) { for(int j=k+1;j<N;j++){ if(a[k]>a[j]){ int t = a[k]; a ...
- FASTJSON
package com.hanqi.test; import java.util.ArrayList;import java.util.Date;import java.util.List; impo ...
- 2013 duilib入门简明教程 -- XML基础类(7)
现在大家应该对XML描述界面不那么陌生了,那么我们做进一步介绍. 前面的教程我们写了很多代码,为的是让大家了解下基本流程,其实duilib已经对常用的操作做了很好的包装,正式使用时无需像前面的教程那样 ...
- ajax的使用:例题、ajax的数据处理
需要注意的是,调用的封装的数据库,和jQuery的保存地址 一.注册 (1)写文本框来进行用户名的验证 <input type="text" id="uid&quo ...
- SQL Server游标
什么是游标 结果集,结果集就是select查询之后返回的所有行数据的集合. 游标则是处理结果集的一种机制吧,它可以定位到结果集中的某一行,多数据进行读写,也可以移动游标定位到你所需要的行中进行操作数据 ...
- 【开源】OSharp框架解说系列(5.1):EntityFramework数据层设计
OSharp是什么? OSharp是个快速开发框架,但不是一个大而全的包罗万象的框架,严格的说,OSharp中什么都没有实现.与其他大而全的框架最大的不同点,就是OSharp只做抽象封装,不做实现.依 ...
- 用 namspace 隔离 DHCP 服务 - 每天5分钟玩转 OpenStack(90)
Neutron 通过 dnsmasq 提供 DHCP 服务,而 dnsmasq 如何独立的为每个 network 服务呢? 答案是通过 Linux Network Namespace 隔离,本节将详细 ...
- gsoap设置超时
1.修改gsoap自动生成的代码才能进行超时设置(我这边访问web service的代码都是gsoap工具自动生成.根据wsdl接口) 2.找到生成的soapwwwsdlBindingProxy.cp ...