注意要先添加程序集的引用

导出到excel:

    public override IWorkbook writeExecl(string filePath, DataTable dt)
{
if (File.Exists(filePath))
{
File.Delete(filePath);
}
IWorkbook wk = new XSSFWorkbook(); ;
//创建一个名称为data的表
ISheet tb = wk.CreateSheet("data");
//表头
IRow row1 = tb.CreateRow();
int k = ;
foreach (DataColumn dc in dt.Columns)
{
ICell cell1 = row1.CreateCell(k); cell1.SetCellValue(getChinaName(dc.ColumnName));
k = k + ;
} //表体
for (int i = ; i < dt.Rows.Count; i++)
{
IRow row = tb.CreateRow(i + );
for (int j = ; j < dt.Columns.Count; j++)
{
if (j == )
{
ICell cell = row.CreateCell(j);
string value = dt.Rows[i][j].ToString();
cell.SetCellValue(tranSchoolType(value));
}
else
{
ICell cell = row.CreateCell(j);
string value = dt.Rows[i][j].ToString();
cell.SetCellValue(value);
}
} } string uploadPath = HttpContext.Current.Server.MapPath(filePath); //打开一个xls文件,如果没有则自行创建 //如果存在myxls.xls文件则在创建是不要打开该文件!
using (FileStream fs = File.OpenWrite(uploadPath))
{ //向打开的这个xls文件中写入mySheet表并保存。
wk.Write(fs); }
}

是用excel2003还是excel2007可以用下面这个方法:

 static IWorkbook isExcelType(string filePath)
{
IWorkbook wk = null;
FileStream fs = new FileStream(filePath, FileMode.OpenOrCreate, FileAccess.ReadWrite);
if (filePath.IndexOf(".xlsx") > ) // 2007版本
wk = new XSSFWorkbook(fs);
else if (filePath.IndexOf(".xls") > ) // 2003版本
wk = new HSSFWorkbook(fs); fs.Close();
return wk; }

从excel读取数据:

   List<Dictionary<string, string>> readExcel(string filePath)
{
IWorkbook wk = null;
wk = isExcelType(filePath);
ISheet sheet = wk.GetSheetAt();
List<string> names = new List<string>();//LastRowNum 是当前表的总行数

for (int j = 1; j <= sheet.LastRowNum; j++) 
            {  for (int j = 1; j <= sheet.LastRowNum; j++) 
            {

//读取当前行数据
                IRow row = sheet.GetRow(j); 
                if (row != null)
                {
                      //LastCellNum 是当前行的总列数
                    for (int k = 0; k <= row.LastCellNum; k++) 
                    {

//当前表格
                        ICell cell = row.GetCell(k); 
                        if (cell != null)
                        {
                            string name = cell.ToString();  
                            names.Add(name);
                        }
                    }
                }
            }
            List<Dictionary<string, string>> lists = new List<Dictionary<string, string>>();
            return lists;
        }

 

好了,以上就简单的完成导入导出了!

用NPOI完成公司任务(主要就是导入导出操作)的更多相关文章

  1. c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出

    c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出 using NPOI.HSSF.UserModel;using NPOI.SS.UserModel;using S ...

  2. Winform开发框架之通用数据导入导出操作的事务性操作完善

    1.通用数据导入导出操作模块回顾 在我的Winfrom开发框架里面,有一个通用的导入模块,它在默默处理这把规范的Excel数据导入到不同的对象表里面,一直用它来快速完成数据导入的工作.很早在随笔< ...

  3. 循序渐进开发WinForm项目(5)--Excel数据的导入导出操作

    随笔背景:在很多时候,很多入门不久的朋友都会问我:我是从其他语言转到C#开发的,有没有一些基础性的资料给我们学习学习呢,你的框架感觉一下太大了,希望有个循序渐进的教程或者视频来学习就好了. 其实也许我 ...

  4. VB中Excel 2010的导入导出操作

    VB中Excel 2010的导入导出操作 编写人:左丘文 2015-4-11 近来这已是第二篇在讨论VB的相关问题,今天在这里,我想与大家一起分享一下在VB中如何从Excel中导入数据和导出数据到Ex ...

  5. NPOI、MyXls、Aspose.Cells 导入导出Excel(转)

    Excel导入及导出问题产生: 从接触.net到现在一直在维护一个DataTable导s出到Excel的类,时不时还会维护一个导入类.以下是时不时就会出现的问题: 导出问题: 如果是asp.net,你 ...

  6. NPOI 2.1.1 系列(1) 使用NPOI读取 Excel文档 ;NpoiExcelHelper 导入导出 2003格式 2007格式的 Excel; Npoi 导出 xlsx 格式

    下载地址 http://npoi.codeplex.com/releases 下面放一个 NPOIHelper 助手类吧,也不是我写的- NpoiExcelHelper 可以生成xlsx格式publi ...

  7. net core WebApi——使用NPOI导入导出操作

    目录 前言 NPOI 测试 小结 @ 前言 时间过得好快,在之前升级到3.0之后,就感觉好久没再动过啥东西了,之前有问到Swagger的中文汉化,虽说我觉得这种操作的意义不是太大,也是多少鼓捣了下,其 ...

  8. NPOI读写Excel组件封装Excel导入导出组件

    后台管理系统多数情况会与Excel打交道,常见的就是Excel的导入导出,对于Excel的操作往往是繁琐且容易出错的,对于后台系统的导入导出交互过程往往是固定的,对于这部分操作,我们可以抽离出公共组件 ...

  9. Sqoop_mysql,hive,hdfs导入导出操作

    前言: 搭建环境,这里使用cdh版hadoop+hive+sqoop+mysql 下载 hadoop-2.5.0-cdh5.3.6.tar.gz hive-0.13.1-cdh5.3.6.tar.gz ...

随机推荐

  1. 数据库查询SQL语句的时候如何写会效率更高?

    引言 以前刚开始做项目的时候,开发经验尚浅,遇到问题需求只要把结果查询出来就行,至于查询的效率可能就没有太多考虑,数据少的时候还好,数据一多,效率问题就显现出来了.每次遇到查询比较慢时,项目经理就会问 ...

  2. hibernate课程 初探单表映射3-1 hibernate单表操作简介

    本章简介: 1 单一主键 2 基本类型 3 对象类型 4 组件属性 5 单表操作CRUD实例

  3. jsp连接sqlite、Sqlite相对路径绝对路径问题(转)

    转自  http://blog.csdn.net/sxy12138/article/details/52304884 假如在java中, # 数据库连接jdbc.jdbc-url=jdbc:sqlit ...

  4. Day6 盒模型

    Day6  盒模型  1.一.标准盒模型(w3c盒模型)        1)组成部分:        content + padding + border + margin           内容  ...

  5. rem 适配屏幕大小

    window.onresize=function(){ var html=document.getElementsByTagName("html")[0]; var width=w ...

  6. 使用create react app教程

    This project was bootstrapped with Create React App. Below you will find some information on how to ...

  7. zabbix中监控项报错

    报错信息: zabbix报错(Not all processes could be identified, non-owned process info will not be shown, you ...

  8. SQL优化 · 经典案例 · 索引篇

    Introduction 在这些年的工作之中,由于SQL问题导致的数据库故障层出不穷,下面将过去六年工作中遇到的SQL问题总结归类,还原问题原貌,给出分析问题思路和解决问题的方法,帮助用户在使用数据库 ...

  9. 基于PowerShell的Lync Server管理 使用C#

    这里所说的Lync Server管理,指通过C#管理Lync账号的启用,禁用,开启账户的语音功能. Lync服务器安装后,会自动创建一个用于远程管理的应用程序,通过IIS查看,其应用程序名为: Lyn ...

  10. 【洛谷2051】[AHOI2009] 中国象棋(烦人的动态规划)

    点此看题面 大致题意: 让你在一张\(N*M\)的棋盘上摆放炮,使其无法互相攻击,问有多少种摆法. 辟谣 听某大佬说这是一道状压\(DP\)题,于是兴冲冲地去做,看完数据范围彻底懵了:\(N≤100\ ...