iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C#使用NPOI对Excel数据进行导入导出
  • 941
分享到

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

2024-04-02 19:04:59 941人浏览 八月长安
摘要

目录一、概述1、操作excel的类库:2、引用DLL程序集构成二、通过NPOI,将Excel文件导到数据表DataTable四、常见用法:1、查找2、插入图片五、填充Excel模板六

一、概述

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

1、操作Excel的类库:

  • NPOI: V2.5.1 快速生成 https://GitHub.com/tonyqus/npoi
  • MyXls: (已停止)
  • Aspose.Cell.dll: 收费
  • EPPlus 5: Https://github.com/EPPlusSoftware/
  • Spire.XLS: 收费

2、引用DLL

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

  • ICSharpcode.SharpZipLib.dll
  • NPOI.dll
  • NPOI.OOXML.dll
  • NPOI.OpenXml4Net.dll
  • NPOI.OpenXmlFORMats.dll

程序集构成

二、通过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 sheet
ISheet sheet = workbook.CreateSheet("Sheet1");

// Create the drawing patriarch.  This is the top level container for all shapes. 
IDrawing patriarch = sheet.CreateDrawingPatriarch();

//add a picture
HSSFClientAnchor 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"));//复制第一个模板Sheet
cloneSheet.ForceFormulaRecalculation = true;
workbook.SetSheetName(workbook.GetSheetIndex(cloneSheet), "SheetClone");//设置新SheetName

cloneSheet.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"));//移除原模板Sheet

FileStream 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的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: C#使用NPOI对Excel数据进行导入导出

本文链接: https://www.lsjlt.com/news/150878.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • C#使用NPOI对Excel数据进行导入导出
    目录一、概述1、操作Excel的类库:2、引用DLL程序集构成二、通过NPOI,将Excel文件导到数据表DataTable四、常见用法:1、查找2、插入图片五、填充Excel模板六...
    99+
    2024-04-02
  • C#如何使用NPOI对Excel数据进行导入导出
    本篇内容介绍了“C#如何使用NPOI对Excel数据进行导入导出”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、概述NPOI 是 POI ...
    99+
    2023-07-02
  • C#通过NPOI导入导出数据EXCEL
    本文实例为大家分享了C#通过NPOI导入导出数据EXCEL的具体代码,供大家参考,具体内容如下 其实从数据库到服务器导入导出有很多方法,但是比较简单的有NPOI这个方法 准备工作,先...
    99+
    2024-04-02
  • C#操作NPOI实现Excel数据导入导出
    目录1.NpoiExcelHelper.cs  Npoi操作Excel类2.WEB项目的调用方法首先在项目中引用NPOI,通过管理NuGet程序包,搜索NPOI,...
    99+
    2023-02-15
    C# NPOI Excel数据导入导出 C# Excel数据导入导出 C# NPOIExcel
  • C#使用NPOI实现Excel导入导出功能
    本文实例为大家分享了C#使用NPOI实现Excel导入导出的具体代码,供大家参考,具体内容如下 Excel导入 使用OpenFileDiolog控件和button结合,选择文件导入,...
    99+
    2024-04-02
  • C#用NPOI导出导入Excel帮助类
    本文实例为大家分享了C#用NPOI导出导入Excel帮助类的具体代码,供大家参考,具体内容如下 1、准备工作 在管理NuGet程序包中搜索 NPOI,安装 NPOI 到要项目中。 2...
    99+
    2024-04-02
  • C#中如何使用NPOI实现Excel导入导出功能
    本文小编为大家详细介绍“C#中如何使用NPOI实现Excel导入导出功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“C#中如何使用NPOI实现Excel导入导出功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧...
    99+
    2023-06-29
  • C#使用Npoi导出Excel并合并行列
    在工作开发中,客户经常要求数据库中数据导出到Excel表格。以前方法是引用office相关组件,如果客户没有安装office,功能就会遇到问题。 现在用Npoi导出Excel,导出表...
    99+
    2024-04-02
  • C#使用NPOI将List数据导出到Excel文档
    NPOI是一个开源的C#读写Excel、WORD等微软OLE2组件文档的项目。使用 NPOI 可以在没有安装 Office 或者相应环境的机器上对 WORD/EXCEL 文档进行读写...
    99+
    2024-04-02
  • C#使用NPOI导出Excel类封装
    NPOI是指构建在POI 3.x版本之上的一个程序,NPOI可以在没有安装Office的情况下对Word或Excel文档进行读写操作。 NPOI是一个开源的C#读写Excel、WOR...
    99+
    2024-04-02
  • C#中怎么使用Npoi导出Excel合并行列
    这篇文章主要讲解了“C#中怎么使用Npoi导出Excel合并行列”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#中怎么使用Npoi导出Excel合并行列”吧!现在用Npoi导出Excel,...
    99+
    2023-06-29
  • ASP.Net MVC怎么利用NPOI导入导出Excel
    今天小编给大家分享一下ASP.Net MVC怎么利用NPOI导入导出Excel的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了...
    99+
    2023-06-30
  • C#如何使用NPOI将excel导入到list
    小编给大家分享一下C#如何使用NPOI将excel导入到list,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!具体内容如下这个是确定是实体类接收/// <summary>/// 将excel...
    99+
    2023-06-29
  • C#中如何使用NPOI将List数据导出到Excel文档
    今天小编给大家分享一下C#中如何使用NPOI将List数据导出到Excel文档的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。...
    99+
    2023-06-29
  • 怎么用C#实现NPOI的Excel导出
    这篇文章主要讲解了“怎么用C#实现NPOI的Excel导出”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用C#实现NPOI的Excel导出”吧!技术点:自定义attribute属性通过反...
    99+
    2023-06-26
  • C#使用NPOI将excel导入到list的方法
    本文实例为大家分享了C#使用NPOI将excel导入到list的具体代码,供大家参考,具体内容如下 这个是确定是实体类接收 /// <summary> /// 将exce...
    99+
    2024-04-02
  • ASP.Net MVC利用NPOI导入导出Excel的示例代码
    什么是NPOI 该项目是位于http://poi.apache.org/的POI Java项目的.NET版本。POI是一个开源项目,可以帮助您读取/写入xls,doc,ppt文件。它...
    99+
    2024-04-02
  • ORACLE怎么进行导入导出数据
    本篇内容介绍了“ORACLE怎么进行导入导出数据”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!简介:Sql...
    99+
    2024-04-02
  • fastadmin实现导出Excel和导入Excel数据
    public function export() { if ($this->request->isPost()) { require_once(VENDOR_...
    99+
    2023-08-31
    php Powered by 金山文档
  • Python数据处理-导入导出excel数据
    目录一.xlwt库将数据导入Excel1.将数据写入一个Excel文件2.定制Excel表格样式3.元格对齐4.单元格的背景色5.单元格边框二、xlrd库读取Excel中的数据1.读...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作