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