陈程的技术博客

  • 关于作者
全栈软件工程师
一个专注于技术研究创新的程序员
  1. 首页
  2. .NET
  3. 正文

NPOI读写execl

2021年2月7日 874点热度 0人点赞 0条评论
using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using Microsoft.Office.Interop.Excel;

namespace UpdateData.Common
{
    public class WriterChangeCell
    {
        /// <summary>
        /// 将字符串数组写入EXCEL
        /// </summary>
        /// <param name="xlFile">EXCEL文件</param>
        /// <param name="sheetName">EXCEL表sheet名称</param>
        /// <param name="changeDateEntities">输入修改位置和修改内容</param>
        /// <returns>EXCEL文件是否成功</returns>
        public void WriteExcel(string xlFile, string sheetName, List<ChangeDateEntity> changeDateEntities)
        {
            try
            {
                var extension = Path.GetExtension(xlFile).ToLower();
                IWorkbook wk = null;

                using (FileStream fs = File.Open(xlFile, FileMode.OpenOrCreate, FileAccess.Read, FileShare.ReadWrite))
                {
                    if (extension == ".xls")
                    {
                        wk = new HSSFWorkbook(fs);
                    }
                    else if (extension == ".xlsx")
                    {
                        wk = new XSSFWorkbook(fs);
                    }
                }

                ISheet sheet = wk.GetSheet(sheetName);

                foreach (var item in changeDateEntities)
                {
                    if (string.IsNullOrEmpty(item.DataValue))
                        continue;
                    //获取行
                    IRow row = sheet.GetRow(item.RowIndex);
                    //在列单元格  
                    ICell cell = row.GetCell(item.ColumnIndex);

                    cell.SetCellValue(item.DataValue);
                }

                MemoryStream stream = new MemoryStream();
                wk.Write(stream);
                var buf = stream.ToArray();

                //保存为Excel文件  
                using (FileStream fs = new FileStream(xlFile, FileMode.Create, FileAccess.Write))
                {
                    fs.Write(buf, 0, buf.Length);
                    fs.Flush();
                }

                wk.Close();

            }
            catch (Exception ex)
            {
                throw ex;
            }
        }


        public List<string> ReaderExcel(string xlFile, List<TableLocation> changeDateEntities)
        {
            List<string> infoList = new List<string>();
            try
            {
                var extension = Path.GetExtension(xlFile).ToLower();
                IWorkbook wk = null;

                using (FileStream fs = File.Open(xlFile, FileMode.OpenOrCreate, FileAccess.Read, FileShare.ReadWrite))
                {
                    if (extension == ".xls")
                    {
                        wk = new HSSFWorkbook(fs);
                    }
                    else if (extension == ".xlsx")
                    {
                        wk = new XSSFWorkbook(fs);
                    }
                }

                ISheet sheet = wk.GetSheetAt(0);

                foreach (var item in changeDateEntities)
                {
                    //获取行
                    IRow row = sheet.GetRow(item.RowIndex);
                    //在列单元格  
                    ICell cell = row.GetCell(item.ColumnIndex);

                    string unit = "";
                    if (cell.CellType == CellType.Numeric)
                    {
                        if (DateUtil.IsCellDateFormatted(cell))
                        {
                            unit = cell.DateCellValue.ToString("D");
                        }
                        else
                        {
                            unit = cell.ToString();
                        }
                    }
                    else if (cell.CellType == CellType.Blank)//空数据类型
                    {
                        unit = "";
                    }
                    else if (cell.CellType == CellType.Formula)//公式类型
                    {
                        IFormulaEvaluator eva = null;
                        if (extension == ".xls")
                        {
                            eva = new HSSFFormulaEvaluator(wk);
                        }
                        else if (extension == ".xlsx")
                        {
                            eva = new XSSFFormulaEvaluator(wk);
                        }
                        unit = eva.Evaluate(cell).StringValue;
                    }
                    else //其他类型都按字符串类型来处理
                    {
                        unit = cell.StringCellValue;
                    }

                    infoList.Add(unit);

                }
                wk.Close();
                return infoList;
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }


    }

    }

gitee:https://gitee.com/zuiyuewentian/update-data

标签: C# execl NPOI
最后更新:2021年4月2日

博主

全栈工程师,侧重项目技术解决方案规划和开发

打赏 点赞
< 上一篇
下一篇 >

文章评论

取消回复

分类
  • .NET (65)
  • docker (3)
  • linux (12)
  • python (20)
  • web (14)
  • 小程序 (4)
  • 数据库 (2)
  • 未分类 (4)
  • 杂七杂八 (10)
标签聚合
nginx C# centos python DevExpress linux winform js
最新 热点 随机
最新 热点 随机
.NET开发手册标准参考 招募兼职前端开发 Centos安装dotnet6环境 VS上切换分支,vs编译运行出现bug,A fatal error was encountered彻底解决方案 用C#封装一个线程安全的缓存器,达到目标定时定量更新入库 C#通过特性的方式去校验指定数据是否为空
dynamic的操作 DevExpress控件-GridControl控件中添加一列复选框并进行相关操作 centOS常用操作命令 用C#写基于用户的协同过滤算法,推荐网站上你可能感兴趣的人 快速排序算法 winform 绘制无边框四周阴影

COPYRIGHT © 2021 陈程的技术博客. ALL RIGHTS RESERVED.

THEME KRATOS MADE BY VTROIS