最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

.Net Core使用OpenXML导出、导入Excel

来源:动视网 责编:小采 时间:2020-11-27 22:35:05
文档

.Net Core使用OpenXML导出、导入Excel

.Net Core使用OpenXML导出、导入Excel:导出Excel是程序很常用到的功能,.Net Core可以借助Open-XML-SDK来导出Excel。 Open-XML-SDK open-xml-sdk是是微软开源的项目。Open XML SDK是用于Open XML文档(DOCX, XLSX, and PPTX)的开源类库。它可以: 生成Word,Excel,PP
推荐度:
导读.Net Core使用OpenXML导出、导入Excel:导出Excel是程序很常用到的功能,.Net Core可以借助Open-XML-SDK来导出Excel。 Open-XML-SDK open-xml-sdk是是微软开源的项目。Open XML SDK是用于Open XML文档(DOCX, XLSX, and PPTX)的开源类库。它可以: 生成Word,Excel,PP


导出Excel是程序很常用到的功能,.Net Core可以借助Open-XML-SDK来导出Excel。

Open-XML-SDK

open-xml-sdk是是微软开源的项目。Open XML SDK是用于Open XML文档(DOCX, XLSX, and PPTX)的开源类库。它可以:

  • 生成Word,Excel,PPT时有非常好的性能
  • 从XML数据源中填充内容到Word文档中
  • 可将单个Word,Excel,PPT分成多个文件或者将多个合并到一个文件中
  • DOCX => HTML/CSS 和 HTML/CSS => DOCX 提供友好便捷的方式
  • 提取Excel中的数据
  • 用正则表达式查找或者替换DOCX / PPTX中的内容
  • 更新 DOCX / PPTX 中缓存的数据或者嵌入的表格.
  • 文档内容的修改, 例如从文件中删除跟踪的修订或删除不可接受的内容.
  • 依赖 WindowsBase 或 System.IO.Packaging

    开源地址:Open-XML-SDK

    Nuget:DocumentFormat.OpenXml

    Open XML SDK for Office 文档

    示例

    首先添加Nuget包引用

    直接上代码:

    static void Main(string[] args)
    {
     var spreadsheetDocument = SpreadsheetDocument.Create("F:\\OpenXml.xlsx", SpreadsheetDocumentType.Workbook);
     var workbookpart = spreadsheetDocument.AddWorkbookPart();
     workbookpart.Workbook = new Workbook();
     WorksheetPart worksheetPart = workbookpart.AddNewPart();
     worksheetPart.Worksheet = new Worksheet(new SheetData());
     Sheets sheets = spreadsheetDocument.WorkbookPart.Workbook.AppendChild(new Sheets());
     Sheet sheet = new Sheet() { Id = spreadsheetDocument.WorkbookPart.GetIdOfPart(worksheetPart), SheetId = 1, Name = "Sheet1" };
     sheets.Append(sheet);
     var sheetData = worksheetPart.Worksheet.GetFirstChild();
     for (int i = 0; i < 10; i++)
     {
     Row row = new Row();
     for (int j = 0; j < 10; j++)
     {
     Cell dataCell = new Cell();
     dataCell.CellValue = new CellValue($"{i + 1}行{j + 1}列");
     dataCell.DataType = new EnumValue(CellValues.String);
     row.AppendChild(dataCell);
     }
     sheetData.Append(row);
     }
    
    
     workbookpart.Workbook.Save();
     spreadsheetDocument.Close();
    }
    
    

    导出的Excel如图:

    读取Excel

    读取Excel的代码会相对简单一些:

    static void Main(string[] args)
    {
     using (SpreadsheetDocument doc = SpreadsheetDocument.Open(@"F:\OpenXml.xlsx", false))
     {
     WorkbookPart wbPart = doc.WorkbookPart;
     Sheet mysheet = (Sheet)doc.WorkbookPart.Workbook.Sheets.ChildElements.FirstOrDefault();
     Worksheet worksheet = ((WorksheetPart)wbPart.GetPartById(mysheet.Id)).Worksheet;
     SheetData sheetData = (SheetData)worksheet.ChildElements.FirstOrDefault();
    
     foreach (var row in sheetData.ChildElements)
     {
     foreach (var cell in (row as Row).ChildElements)
     {
     var cellValue = (cell as Cell).CellValue;
     if (cellValue != null)
     {
     Console.WriteLine(cellValue.Text);
     }
     }
     }
     }
    }
    
    

    文档

    .Net Core使用OpenXML导出、导入Excel

    .Net Core使用OpenXML导出、导入Excel:导出Excel是程序很常用到的功能,.Net Core可以借助Open-XML-SDK来导出Excel。 Open-XML-SDK open-xml-sdk是是微软开源的项目。Open XML SDK是用于Open XML文档(DOCX, XLSX, and PPTX)的开源类库。它可以: 生成Word,Excel,PP
    推荐度:
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top