溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么在.Net Core中使用OpenXML導(dǎo)出導(dǎo)入Excel文件

發(fā)布時(shí)間:2021-03-29 15:26:20 來(lái)源:億速云 閱讀:277 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

今天就跟大家聊聊有關(guān)怎么在.Net Core中使用OpenXML導(dǎo)出導(dǎo)入Excel文件,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

Open-XML-SDK

open-xml-sdk是是微軟開(kāi)源的項(xiàng)目。Open XML SDK是用于Open XML文檔(DOCX, XLSX, and PPTX)的開(kāi)源類庫(kù)。它可以:

  • 生成Word,Excel,PPT時(shí)有非常好的性能

  • 從XML數(shù)據(jù)源中填充內(nèi)容到Word文檔中

  • 可將單個(gè)Word,Excel,PPT分成多個(gè)文件或者將多個(gè)合并到一個(gè)文件中

  • DOCX => HTML/CSS 和 HTML/CSS => DOCX 提供友好便捷的方式

  • 提取Excel中的數(shù)據(jù)

  • 用正則表達(dá)式查找或者替換DOCX / PPTX中的內(nèi)容

  • 更新 DOCX / PPTX 中緩存的數(shù)據(jù)或者嵌入的表格.

  • 文檔內(nèi)容的修改, 例如從文件中刪除跟蹤的修訂或刪除不可接受的內(nèi)容.

依賴 WindowsBase 或 System.IO.Packaging

怎么在.Net Core中使用OpenXML導(dǎo)出導(dǎo)入Excel文件

開(kāi)源地址:Open-XML-SDK

Nuget:DocumentFormat.OpenXml

Open XML SDK for Office 文檔

示例

首先添加Nuget包引用

怎么在.Net Core中使用OpenXML導(dǎo)出導(dǎo)入Excel文件

直接上代碼:

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();
}

導(dǎo)出的Excel如圖:

怎么在.Net Core中使用OpenXML導(dǎo)出導(dǎo)入Excel文件

讀取Excel

讀取Excel的代碼會(huì)相對(duì)簡(jiǎn)單一些:

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);
    }
   }
  }
 }
}

看完上述內(nèi)容,你們對(duì)怎么在.Net Core中使用OpenXML導(dǎo)出導(dǎo)入Excel文件有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI