首页 > 解决方案 > 尝试使用 EPPlus 从 ZipArchive 读取 Excel 文件

问题描述

我正在尝试从 zip 存档中读取 excel 文件:

var excelEntry = archive.Entries.Single(entry => Regex.IsMatch(entry.FullName, @"\.xlsx\z", RegexOptions.IgnoreCase));
using (var excelPackage = new ExcelPackage(excelEntry.Open()))
{
}

但是,我得到了 NotSupportedException。

(Exception thrown: 'System.NotSupportedException' in System.dll
Additional information: This operation is not supported.) 

该文件是一个简单的 .xlsx,没有任何保护。有任何想法吗?

标签: c#epplus

解决方案


这确实是因为 zip 存档流是只读的,而 ExcelPackage 只接受读/写流。

我做了以下调整:

var entryStream = excelEntry.Open();
using (var ms = new MemoryStream())
using (var excelPackage = new ExcelPackage())
{
  entryStream.CopyTo(ms);
  excelPackage.Load(ms);
  ...
}

推荐阅读