当前环境.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文件的更多相关文章

  1. .Net core NPOI导入导出Excel

    最近在想.net core NPOI 导入导出Excel,一开始感觉挺简单的,后来真的遇到很多坑.所以还是写一篇博客让其他人少走一些弯路,也方便忘记了再重温一遍.好了,多的不说,直接开始吧. 在.Ne ...

  2. NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中

    以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...

  3. NPOI导入导出Excel

    .net mvc利用NPOI导入导出excel 注意:如何导出的提交方式ajax导出是失效的! 解决方案是:js处理l两个表单的提交  代码:  第一步. 在页面里面加入2个隐藏的iframe, 如下 ...

  4. (C#)利用Aspose.Cells组件导入导出excel文件

    Aspose.Cells组件可以不依赖excel来导入导出excel文件: 导入: public static System.Data.DataTable ReadExcel(String strFi ...

  5. 【转】 (C#)利用Aspose.Cells组件导入导出excel文件

    Aspose.Cells组件可以不依赖excel来导入导出excel文件: 导入: public static System.Data.DataTable ReadExcel(String strFi ...

  6. ASP.NET Core导入导出Excel文件

    ASP.NET Core导入导出Excel文件 希望在ASP.NET Core中导入导出Excel文件,在网上搜了一遍,基本都是使用EPPlus插件,EPPlus挺好用,但商用需要授权,各位码友若有好 ...

  7. 导入导出Excel文件

    搭建环境 先新建web project ,然后Add Struts Capabilties: 下载导入导出Excel所需的jar包: poi-3.8-20120326.jar包  :  http:// ...

  8. C#,使用NPOI,导出excel文件

    /// <summary> /// 导出excel文件 /// </summary> /// <param name="dt">Table表数据 ...

  9. .net利用NPOI导入导出Excel

    NPOI在.net中的操作Excel 1.读取 using (FileStream stream = new FileStream(@"c:\客户资料.xls", FileMode ...

随机推荐

  1. MySQL 体系结构

    标签:MYSQL/数据库/查询原理/体系结构 概述 学习一门数据库系统首先得了解它的架构,明白它的架构原理对于后期的分析问题和性能调优都有很大的帮助,接下来就通过分析架构图来认识它. 目录 概述 架构 ...

  2. C#设计模式之桥接

    IronMan之桥接 前言 前面的几个篇幅都是在讲"部件"的生产已经简简单单的使用,以后可能要对"部件"进行升级,不是不对它本身升级,是其它方式的升级,可以让它 ...

  3. 《Node web开发》笔记

    还是因为学习kibana,才开始了解node. Node是一种基于事件驱动的异步系统,基于Chrome的引擎V8. Node中由于大量的使用模块,因此出现了很多开源模块,有点像java社区的样子. 笔 ...

  4. Uiautomator 2.0之Configrator类学习小记

    1. Configration类介绍 1.1. Configrator用于设置脚本动作的默认延时 1.2  Configrator功能: 1.2.1 可调节两个模拟动作之间的默认间隔 1.2.2 可调 ...

  5. Java基础-输入输出-3.编写BinIoDemo.java的Java应用程序,程序完成的功能是:完成1.doc文件的复制,复制以后的文件的名称为自己的学号姓名.doc。

    3.编写BinIoDemo.java的Java应用程序,程序完成的功能是:完成1.doc文件的复制,复制以后的文件的名称为自己的学号姓名.doc. try { FileInputStream in = ...

  6. Maven配置Nexus私服

    官方文档:http://books.sonatype.com/nexus-book/3.0/reference/maven.html#maven-sect-single-group 1,下载安装 首先 ...

  7. WaitType:SOS_SCHEDULER_YIELD

    今天遇到一个query,处于SOS_SCHEDULER_YIELD 状态,physical IO 不增加,CPU的使用一直在增长.当一个sql query长时间处于SOS_SCHEDULER_YIEL ...

  8. Introduction of OpenCascade Foundation Classes

    Introduction of OpenCascade Foundation Classes Open CASCADE基础类简介 eryar@163.com 一.简介 1. 基础类概述 Foundat ...

  9. 希尔排序及希尔排序java代码

    原文链接:http://www.orlion.ga/193/ 由上图可看到希尔排序先约定一个间隔(图中是4),然后对0.4.8这个三个位置的数据进行插入排序,然后向右移一位对位置1.5.9进行插入排序 ...

  10. 2、Redis入门介绍

    1.什么是Redis Redis:REmote DIctionary Server(远程字典服务器) 是完全开源免费的,用C语言编写的,遵守BSD协议,是一个高性能的(key/value)分布式内存数 ...