.Net Core使用OpenXML导出Excel_.NET_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > .NET > .Net Core使用OpenXML导出Excel

.Net Core使用OpenXML导出Excel

 2017/10/12 16:25:43  ZKEASOFT  程序员俱乐部  我要评论(0)
  • 摘要:导出Excel是程序很常用到的功能,.NetCore可以借助Open-XML-SDK来导出Excel。Open-XML-SDKopen-xml-sdk是是微软开源的项目。OpenXMLSDK是用于OpenXML文档(DOCX,XLSX,andPPTX)的开源类库。它可以:生成Wrold,Excel,PPT时有非常好的性能从XML数据源中填充内容到World文档中可将单个Wrold,Excel,PPT分成多个文件或者将多个合并到一个文件中DOCX=>
  • 标签:.net excel 使用 net 导出excel XML

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

Open-XML-SDK

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

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

依赖 WindowsBase 或 System.IO.Packaging

PlatformSystem.IO.Packing SourceTested by .NET 3.5 WindowsBase N/A .NET 4.0 WindowsBase .NET 4.5.2 .NET 4.6 NuGet .NET 4.6 .NET Standard NuGet .NET Core 1.0

开源地址:https://github.com/OfficeDev/Open-XML-SDK

Nuget:https://www.nuget.org/packages/DocumentFormat.OpenXml

Open XML SDK for Office 文档

http://msdn.microsoft.com/en-us/library/office/bb448854.aspx

示例

首先添加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如图:

原文地址:http://www.zkea.net/codesnippet/detail/post-69

发表评论
用户名: 匿名