NPOI读写Excel表格、Word文档

NPOI是从POI移植过来的.NET版本,专门对Word、Excel进行读写操作的一个开源项目

下面就试着怎么用我们的C#来进行读写操作,我现在用的Office版本是2016

我们首先通过Nuget把NPOI引入到我们的项目中

1、读取Excel表格

using(FileStream fs=new FileStream(@"C:\Users\BIDIANQING\Desktop\1.xlsx", FileMode.Open,FileAccess.Read))
            {
                XSSFWorkbook book = new XSSFWorkbook(fs);
                ISheet sheet= book.GetSheetAt(0);  //book.NumberOfSheets;
                string sheetName= sheet.SheetName;
                int lastRowNum = sheet.LastRowNum;
                
                for (int i = 0; i <= lastRowNum; i++)
                {
                    string str = string.Empty;
                    IRow row= sheet.GetRow(i);
                    int lastCellNum = row.LastCellNum;
                    for (int j = 0; j < lastCellNum; j++)
                    {
                        ICell cell= row.GetCell(j);
                        CellType cellType= cell.CellType;
                        if (cellType == CellType.Numeric)
                        {
                            str += cell.NumericCellValue.ToString()+"|";
                        }
                        else if (cellType == CellType.String)
                        {
                            str += cell.StringCellValue+"|";
                        }
                    }
                    Console.WriteLine(str);
                }
                
            }

 

2、把数据写入Excel表格

List<Person> list = new List<Person>();
            list.Add(new Person() { Id = 1, Name = "张三" });
            list.Add(new Person() { Id = 2, Name = "李四" });
            list.Add(new Person() { Id = 3, Name = "小王" });
            list.Add(new Person() { Id = 4, Name = "小鸣" });

        string desk = Environment.GetFolderPath(Environment.SpecialFolder.DesktopDirectory);
        string guid = Guid.NewGuid().ToString();

using (FileStream fs = new FileStream(string.Format("{0}\\{1}.xlsx",desk,guid), FileMode.Create, FileAccess.Write))
            {
                XSSFWorkbook book = new XSSFWorkbook();
                ISheet sheet= book.CreateSheet("person");
                int n=0;
                foreach (var item in list)
                {
                    IRow row= sheet.CreateRow(n);
                    row.CreateCell(0, CellType.Numeric).SetCellValue(item.Id);
                    row.CreateCell(1, CellType.String).SetCellValue(item.Name);
                    n++;
                }
                book.Write(fs);
            }
            Console.WriteLine("OK");
            Console.ReadKey();

 

3、读取Word文档

 using(FileStream fs=new FileStream(@"C:\Users\BIDIANQING\Desktop\1.docx", FileMode.Open,FileAccess.Read))
            {
                XWPFDocument doc = new XWPFDocument(fs);
                //var package= doc.Package;
                var paragraphs= doc.Paragraphs;
                foreach (var item in paragraphs)
                {
                    Console.WriteLine(item.ParagraphText);
                }
            }
            Console.ReadKey();

 

4、把数据写入Word文档

你可能感兴趣的:(NPOI读写Excel表格、Word文档)