使用 ExcelDataReader 和 Epplus 访问受保护的 Excel 文件



title几乎说明了一切。寻找一种使用ExcelDataReader和Epplus访问受密码保护的Excel文件的方法,找不到正确的答案。

如果使用ExcelDataReader,我的代码看起来像

excelStream = File.Open(excelFilePath, FileMode.Open, FileAccess.Read);
excelReader = ExcelReaderFactory.CreateOpenXmlReader(excelStream);
excelDataSet = excelReader.AsDataSet();

如果使用 EPPlus,我的连接代码如下所示

excelPackage = new ExcelPackage(new FileInfo(excelFilePath));
excelWorkbook = excelPackage.Workbook;
excelSheet = excelWorkbook.Worksheets[1];

EPPlus有一些与保护相关的方法,但我不知道如何使用它们。ExcelDataReader似乎没有任何与保护相关的方法。

任何提示表示赞赏,谢谢。

编辑:我已经知道密码

使用 EPPlus 您可以使用

excelPackage = new ExcelPackage(new FileInfo(excelFilePath), "mypassword");

ExcelDataReader 现在支持打开受密码保护的工作表。我在他们的 GitHub 上打开了一个问题,询问他们是否有这样的支持,并收到回复说他们没有,但一段时间后他们添加了对某些密码方法的支持。有关他们仍然不支持的密码方法的详细信息,请参见链接。

有了ExcelDataReadr,您可以像这样访问受保护的文件:

var conf = new ExcelReaderConfiguration { Password = "yourPassword" };
excelReader = ExcelReaderFactory.CreateOpenXmlReader(excelStream, conf);

相关内容

  • 没有找到相关文章

最新更新