我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C#如何使用NPOI对Excel数据进行导入导出

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C#如何使用NPOI对Excel数据进行导入导出

本篇内容介绍了“C#如何使用NPOI对Excel数据进行导入导出”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

一、概述

NPOI 是 POI 项目的 .NET 版本。POI是一个开源的Java读写Excel、WORD等微软OLE2组件文档的项目, 使用 NPOI 你就可以在没有安装 Office 或者相应环境的机器上对 WORD/EXCEL 文档进行读写。

1、操作Excel的类库:

  • NPOI: V2.5.1

  • MyXls: (已停止)

  • Aspose.Cell.dll: 收费

  • EPPlus 5

  • Spire.XLS: 收费

2、引用DLL

使用时需引用需要引用所有5个dll

  • ICSharpCode.SharpZipLib.dll

  • NPOI.dll

  • NPOI.OOXML.dll

  • NPOI.OpenXml4Net.dll

  • NPOI.OpenXmlFormats.dll

C#如何使用NPOI对Excel数据进行导入导出

程序集构成

C#如何使用NPOI对Excel数据进行导入导出

C#如何使用NPOI对Excel数据进行导入导出

二、通过NPOI,将Excel文件导到数据表DataTable

DataTable dt = ImportToTable("00.xls");if (dt != null){    Console.Write(dt.Rows.Count);    Console.ReadKey();}public static DataTable ImportToTable(string fileName){    DataTable dt = new DataTable();    IWorkbook workbook;    string fileExt = Path.GetExtension(fileName).ToLower();    using (FileStream fs = new FileStream(fileName, FileMode.Open, FileAccess.Read))    {        //XSSFWorkbook 适用XLSX格式,HSSFWorkbook 适用XLS格式        if (fileExt == ".xlsx")        {            workbook = new XSSFWorkbook(fs);        }        else if (fileExt == ".xls")        {            workbook = new HSSFWorkbook(fs);        }        else        {            workbook = null;            return null;        }        ISheet sheet = workbook.GetSheetAt(0);//Sheet总数量:workbook.NumberOfSheets        //表头          IRow header = sheet.GetRow(sheet.FirstRowNum);        for (int i = 0; i < header.LastCellNum; i++)        {            object obj = GetValueType(header.GetCell(i));            if (obj == null || obj.ToString() == string.Empty)            {                dt.Columns.Add(new DataColumn("Columns" + i.ToString()));            }            else                dt.Columns.Add(new DataColumn(obj.ToString()));        }        //数据          for (int i = sheet.FirstRowNum + 1; i <= sheet.LastRowNum; i++)        {            DataRow dr = dt.NewRow();            bool hasValue = false;            IRow row = sheet.GetRow(i);            for (int j = row.FirstCellNum; j < row.LastCellNum; j++)            {                dr[j] = GetValueType(sheet.GetRow(i).GetCell(j));                if (dr[j] != null && dr[j].ToString() != string.Empty)                {                    hasValue = true;                }            }            if (hasValue)            {                dt.Rows.Add(dr);            }        }        return dt;    }}/// /// 获取单元格类型/// /// /// /// static object GetValueType(ICell cell){    if (cell == null)        return null;    switch (cell.CellType)    {        case CellType.Blank: //BLANK:              return null;        case CellType.Boolean: //BOOLEAN:              return cell.BooleanCellValue;        case CellType.Numeric: //NUMERIC:              return cell.NumericCellValue;        case CellType.String: //STRING:              return cell.StringCellValue;        case CellType.Error: //ERROR:              return cell.ErrorCellValue;        case CellType.Formula: //FORMULA:          default:            return "=" + cell.CellFormula;    }}

四、常见用法:

1、查找

IEnumerator rows = sheet.GetEnumerator();while (rows.MoveNext()){    IRow row = (HSSFRow)rows.Current;    ICell cell = row.GetCell(0);    if (cell != null && cell.StringCellValue == "XX")    {        return row.GetCell(1).StringCellValue;    }}

2、插入图片

IWorkbook workbook = new HSSFWorkbook();//add picture data to this workbook.byte[] bytes = System.IO.File.ReadAllBytes(@"00.jpg");int pictureIdx = workbook.AddPicture(bytes, PictureType.JPEG);//create sheetISheet sheet = workbook.CreateSheet("Sheet1");// Create the drawing patriarch.  This is the top level container for all shapes. IDrawing patriarch = sheet.CreateDrawingPatriarch();//add a pictureHSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 1023, 0, 0, 0, 1, 3);IPicture pict = patriarch.CreatePicture(anchor, pictureIdx);//保存为Excel文件  using (FileStream fs = new FileStream("00_new.xls", FileMode.Create, FileAccess.Write)){    workbook.Write(fs);}

五、填充Excel模板

IWorkbook workbook;using (FileStream fs = new FileStream("模板文件.xls", FileMode.Open, FileAccess.Read)){    workbook = new HSSFWorkbook(fs);}ISheet cloneSheet = workbook.CloneSheet(workbook.GetSheetIndex("Sheet1"));//复制第一个模板SheetcloneSheet.ForceFormulaRecalculation = true;workbook.SetSheetName(workbook.GetSheetIndex(cloneSheet), "SheetClone");//设置新SheetNamecloneSheet.GetRow(4).GetCell(1).SetCellValue("a");//为已经存在的单元格赋值IRow row = cloneSheet.GetRow(15);if (row == null)    row = cloneSheet.CreateRow(15);ICell cell = row.GetCell(7);if (cell == null)    cell = row.CreateCell(7);cell.SetCellValue("XX");// 为不存在的单元格,先新建再赋值cloneSheet.ShiftRows(51, 60, 34);//51-60行(尾部)整体移动34行,腾出更多控件插入多行数据workbook.RemoveSheetAt(workbook.GetSheetIndex("Sheet1"));//移除原模板SheetFileStream fs_new = new FileStream(DateTime.Now.Ticks + ".xls", FileMode.Create);workbook.Write(fs_new);fs_new.Close();

六、DataTable导出到Excel文件

1、直接导出到Excel:

调用方式:

ExportToExcel(dt, "00_new.xls");

代码

public static void ExportToExcel(DataTable dt, string fileName){    IWorkbook workbook;    string fileExt = Path.GetExtension(fileName).ToLower();    //XSSFWorkbook 适用XLSX格式,HSSFWorkbook 适用XLS格式    if (fileExt == ".xlsx")    {        workbook = new XSSFWorkbook();    }    else if (fileExt == ".xls")    {        workbook = new HSSFWorkbook();    }    else    {        workbook = null;        return;    }    ISheet sheet = string.IsNullOrEmpty(dt.TableName) ? workbook.CreateSheet("Sheet1") : workbook.CreateSheet(dt.TableName);    //表头      IRow row = sheet.CreateRow(0);    for (int i = 0; i < dt.Columns.Count; i++)    {        ICell cell = row.CreateCell(i);        cell.SetCellValue(dt.Columns[i].ColumnName);    }    //数据      for (int i = 0; i < dt.Rows.Count; i++)    {        IRow row1 = sheet.CreateRow(i + 1);        for (int j = 0; j < dt.Columns.Count; j++)        {            ICell cell = row1.CreateCell(j);            cell.SetCellValue(dt.Rows[i][j].ToString());        }    }    //保存为Excel文件      using (FileStream fs = new FileStream(fileName, FileMode.Create, FileAccess.Write))    {        workbook.Write(fs);    }}

2、将DataTable导出到Excel:先导出到MemoryStream

public static MemoryStream ExportToExcel(DataTable dt, string HeaderText){    var workbook = new HSSFWorkbook();    ISheet sheet = workbook.CreateSheet(string.IsNullOrWhiteSpace(dt.TableName) ? "Sheet1" : dt.TableName);    //右击文件“属性”信息    #region 文件属性信息    {        var dsi = PropertySetFactory.CreateDocumentSummaryInformation();        dsi.Company = "NPOI";        workbook.DocumentSummaryInformation = dsi;        SummaryInformation si = PropertySetFactory.CreateSummaryInformation();        si.Author = "文件作者信息";        si.ApplicationName = "创建程序信息";        si.LastAuthor = "最后保存者信息";        si.Comments = "作者信息";        si.Title = "标题信息";        si.Subject = "主题信息";        si.CreateDateTime = DateTime.Now;        workbook.SummaryInformation = si;    }    #endregion    //格式    var dateStyle = workbook.CreateCellStyle();    var format = workbook.CreateDataFormat();    dateStyle.DataFormat = format.GetFormat("yyyy-mm-dd");//日期格式    //取得列宽    var arrColWidth = new int[dt.Columns.Count];    foreach (DataColumn item in dt.Columns)    {        arrColWidth[item.Ordinal] = Encoding.GetEncoding(936).GetBytes(item.ColumnName.ToString()).Length;    }    for (var i = 0; i < dt.Rows.Count; i++)    {        for (var j = 0; j < dt.Columns.Count; j++)        {            int intTemp = Encoding.GetEncoding(936).GetBytes(dt.Rows[i][j].ToString()).Length;            if (intTemp > arrColWidth[j])            {                arrColWidth[j] = intTemp;            }        }    }    int rowIndex = 0;    foreach (DataRow row in dt.Rows)    {        #region 表头 列头        if (rowIndex == 65535 || rowIndex == 0)        {            if (rowIndex != 0)            {                sheet = workbook.CreateSheet();//超过65535行,则新建一个Sheet            }            #region 表头及样式            {                var headerRow = sheet.CreateRow(0);                headerRow.HeightInPoints = 25;                headerRow.CreateCell(0).SetCellValue(HeaderText);                //CellStyle                ICellStyle headStyle = workbook.CreateCellStyle();                headStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center;// 左右居中                    headStyle.VerticalAlignment = VerticalAlignment.Center;// 上下居中                                                                         // 设置单元格的背景颜色(单元格的样式会覆盖列或行的样式)                    headStyle.FillForegroundColor = (short)11;                //定义font                IFont font = workbook.CreateFont();                font.FontHeightInPoints = 20;                font.Boldweight = 700;                headStyle.SetFont(font);                headerRow.GetCell(0).CellStyle = headStyle;                sheet.AddMergedRegion(new NPOI.SS.Util.CellRangeAddress(0, 0, 0, dt.Columns.Count - 1));//合并区域            }            #endregion            #region 列头及样式            {                var headerRow = sheet.CreateRow(1);                //CellStyle                ICellStyle headStyle = workbook.CreateCellStyle();                headStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center;// 左右居中                    headStyle.VerticalAlignment = VerticalAlignment.Center;// 上下居中                                                                         //定义font                IFont font = workbook.CreateFont();                font.FontHeightInPoints = 10;                font.Boldweight = 700;                headStyle.SetFont(font);                foreach (DataColumn column in dt.Columns)                {                    headerRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);                    headerRow.GetCell(column.Ordinal).CellStyle = headStyle;                    sheet.SetColumnWidth(column.Ordinal, (arrColWidth[column.Ordinal] + 1) * 256);//设置列宽                }            }            #endregion            rowIndex = 2;//数据行RowIndex为2(表头和列头个占一行)        }        #endregion        #region 内容        var dataRow = sheet.CreateRow(rowIndex);        foreach (DataColumn column in dt.Columns)        {            var newCell = dataRow.CreateCell(column.Ordinal);            string drValue = row[column].ToString();            switch (column.DataType.ToString())            {                case "System.String"://字符串类型                    newCell.SetCellValue(drValue);                    break;                case "System.DateTime"://日期类型                    DateTime dateV;                    DateTime.TryParse(drValue, out dateV);                    newCell.SetCellValue(dateV);                    newCell.CellStyle = dateStyle;//格式化显示                    break;                case "System.Boolean"://布尔型                    bool boolV = false;                    bool.TryParse(drValue, out boolV);                    newCell.SetCellValue(boolV);                    break;                case "System.Int16"://整型                case "System.Int32":                case "System.Int64":                case "System.Byte":                    int intV = 0;                    int.TryParse(drValue, out intV);                    newCell.SetCellValue(intV);                    break;                case "System.Decimal"://浮点型                case "System.Double":                    double doubV = 0;                    double.TryParse(drValue, out doubV);                    newCell.SetCellValue(doubV);                    break;                case "System.DBNull"://空值处理                    newCell.SetCellValue("");                    break;                default:                    newCell.SetCellValue("");//设置单元格公式:newCell.SetCellFormula("SUM($B0:$D0)")                    break;            }        }        #endregion        rowIndex++;    }    //自动列宽    for (int i = 0; i <= dt.Columns.Count; i++)        sheet.AutoSizeColumn(i, true);    using (MemoryStream ms = new MemoryStream())    {        workbook.Write(ms);        ms.Flush();        ms.Position = 0;        return ms;    }}

3、应用

1、Web导出
public static void ExportToExcelByWeb(DataTable dt, string HeaderText, string FileName){    HttpContext context = HttpContext.Current;    context.Response.ContentType = "application/vnd.ms-excel";    context.Response.ContentEncoding = Encoding.UTF8;    context.Response.Charset = "UTF-8";    context.Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", HttpUtility.UrlEncode(FileName, Encoding.UTF8)));    byte[] data = ExportToExcel(dt, HeaderText).GetBuffer();//Read()方法也可以    context.Response.BinaryWrite(data);//     或者: context.Response.OutputStream.Write(data,0,data.Length)    context.Response.End();}
2、Winform导出
public static void ExportToExcel(DataTable dt, string HeaderText, string FileName){    using (MemoryStream ms = ExportToExcel(dt, HeaderText))    {        using (FileStream fs = new FileStream(FileName, FileMode.Create, FileAccess.Write))        {            byte[] data = ms.ToArray();//跟GetBuffer()对比,速度稍慢,但无空数据            fs.Write(data, 0, data.Length);            fs.Flush();        }    }}

GridView导出到Excel

Web中的GridView可直接导出到Excel:renderControl()

“C#如何使用NPOI对Excel数据进行导入导出”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

C#如何使用NPOI对Excel数据进行导入导出

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C#如何使用NPOI对Excel数据进行导入导出

本篇内容介绍了“C#如何使用NPOI对Excel数据进行导入导出”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、概述NPOI 是 POI
2023-07-02

C#操作NPOI实现Excel数据导入导出

这篇文章主要为大家详细介绍了C#如何操作NPOI实现Excel数据导入导出功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
2023-02-15

C#中如何使用NPOI实现Excel导入导出功能

本文小编为大家详细介绍“C#中如何使用NPOI实现Excel导入导出功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“C#中如何使用NPOI实现Excel导入导出功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧
2023-06-29

C#如何使用NPOI将excel导入到list

小编给大家分享一下C#如何使用NPOI将excel导入到list,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!具体内容如下这个是确定是实体类接收/// /// 将excel导入到list///
2023-06-29

C#中如何使用NPOI将List数据导出到Excel文档

今天小编给大家分享一下C#中如何使用NPOI将List数据导出到Excel文档的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
2023-06-29

C#中怎么使用Npoi导出Excel合并行列

这篇文章主要讲解了“C#中怎么使用Npoi导出Excel合并行列”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#中怎么使用Npoi导出Excel合并行列”吧!现在用Npoi导出Excel,
2023-06-29

java如何使用EasyExcel导入导出excel

这篇文章主要介绍了java如何使用EasyExcel导入导出excel,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、准备工作1、导包
2023-06-15

如何在Oracle中进行数据导入和导出

在Oracle中进行数据导入和导出有多种方法,以下是其中一种常见的方法:数据导出:使用exp工具:可以使用Oracle提供的exp工具来导出数据,命令如下:exp username/password@database_name file
如何在Oracle中进行数据导入和导出
2024-04-09

PHP如何使用xlswriter进行大数据的导入导出?(详解)

PHP如何使用xlswriter进行大数据的导入导出?下面本篇文章给大家介绍一下PHP大数据xlswriter导入导出(最优数据化)的方法,希望对大家有所帮助!本文介绍基于PHP扩展xlswriter的Vtiful\Kernel\Excel类可以支持无限层级的复杂表头导出!后续也可能会持续更新优化一、准备xlswriter扩展1、windows系统:到PECL网站下载符合自己本地PHP环境的ddl文
2022-07-07

SpringBoot中如何使用POI导入导出Excel

SpringBoot中如何使用POI导入导出Excel,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1.创建Excel文档HSSFWorkbook workbook = n
2023-06-19

如何使用koa2完成Excel导入导出

这篇文章主要介绍了如何使用koa2完成Excel导入导出的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何使用koa2完成Excel导入导出文章都会有所收获,下面我们一起来看看吧。一、安装 node-xlsxn
2023-07-05

如何在Oracle数据库中进行数据导入和导出

在Oracle数据库中,可以使用几种方法来进行数据导入和导出,包括使用SQL*Loader实用程序、使用exp和imp工具、使用Oracle Data Pump实用程序等。以下是一些常见的方法:使用SQLLoader实用程序:SQLLoa
如何在Oracle数据库中进行数据导入和导出
2024-03-02

如何使用SQL语句在MySQL中进行数据导入和导出?

如何使用SQL语句在MySQL中进行数据导入和导出?MySQL是一种广泛使用的关系型数据库管理系统,它提供了一种简洁且强大的 SQL 语言来操作和管理数据。在实际应用中,我们经常需要将数据导入到MySQL数据库中或者将数据库中的数据导出到外
如何使用SQL语句在MySQL中进行数据导入和导出?
2023-12-17

PHP怎么使用xlswriter进行大数据的导入导出

这篇文章主要介绍了PHP怎么使用xlswriter进行大数据的导入导出的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇PHP怎么使用xlswriter进行大数据的导入导出文章都会有所收获,下面我们一起来看看吧。一
2023-07-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录