无法在C#中使用Gembox加载.xls文件
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了无法在C#中使用Gembox加载.xls文件,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2794字,纯文字阅读大概需要4分钟。
内容图文
![无法在C#中使用Gembox加载.xls文件](/upload/InfoBanner/zyjiaocheng/686/899aee3bd05b413285116bafca59cd37.jpg)
我想使用C#加载.xls文件(类型:97-2003电子表格).
我正在使用Gembox库.
当我使用以下命令时,遇到“文件包含损坏的数据”.作为错误.
ExcelFile ef = ExcelFile.Load(filepath, XlsxLoadOptions.XlsxDefault);
当我删除XlsxLoadOptions参数时,我得到的是“读取错误:文件不是有效的OLE2复合文件”.
我是C#的新手,无法调试问题的根本原因.
请帮忙!
解决方法:
评论中回答了这个问题.不幸的是,它在那里不太清晰可见,因此这里是答案以及有关此问题的其他一些详细信息.
GemBox.Spreadsheet提供了一些Load overload methods.使用以下代码时:
ExcelFile ef = ExcelFile.Load("C://temp//book.xls");
结果如下:
ExcelFile ef = ExcelFile.Load("C://temp//book.xls", LoadOptions.XlsDefault);
与以下内容相同:
ExcelFile ef = ExcelFile.Load("C://temp//book.xls", new XlsLoadOptions());
加载选项指定如何读取输入文件,以及在使用ExcelFile.Load(String)方法时,这些选项将基于文件的扩展名.
在这种情况下,文件具有“ .xls”扩展名,但是它不是二进制XLS格式(BIFF8),而是HTML格式.这是一个比较常用的技巧,您可以使用HTML,CSV甚至扩展名为“ .xls”的XLSX文件,并且MS Excel可以打开它.它将检测到正确的文件格式,并通过以下消息提示用户:
File format and extension of ‘book.xls’ don’t match. The file could be corrupted or unsafe. Unless you trust its source, don’t open it. Do you want to open it anyway?
请注意,此技巧仅适用于“ .xls”扩展名,不适用于例如“ .xlsx”.但是,我们可以使用类似以下的内容来检测正确的文件格式:
private static LoadOptions GetLoadOptions(string path)
{
string extension = Path.GetExtension(path).ToUpperInvariant();
switch (extension)
{
case ".XLSX":
case ".XLSM":
case ".XLTX":
case ".XLTM":
return LoadOptions.XlsxDefault;
case ".XLS":
case ".XLT":
return GetLoadOptions(path, null);
case ".ODS":
case ".OTS":
return LoadOptions.OdsDefault;
case ".TAB":
case ".TSV":
return new CsvLoadOptions(CsvType.TabDelimited);
case ".CSV":
return LoadOptions.CsvDefault;
default:
return null;
}
}
private static LoadOptions GetLoadOptions(string xlsPath, LoadOptions defaultOptions)
{
byte[] signature = new byte[8];
using (var stream = File.OpenRead(xlsPath))
stream.Read(signature, 0, 8);
byte[] xlsSignature = new byte[] { 0xD0, 0xCF, 0x11, 0xE0, 0xA1, 0xB1, 0x1A, 0xE1 };
if (signature.SequenceEqual(xlsSignature))
return LoadOptions.XlsDefault;
byte[] xlsxSignature = new byte[] { 0x50, 0x4B, 0x03, 0x04 };
if (signature.Take(4).SequenceEqual(xlsxSignature))
return LoadOptions.XlsxDefault;
string firstLine = File.ReadLines(xlsPath)
.First(line => !string.IsNullOrWhiteSpace(line)).TrimStart().ToUpperInvariant();
if (firstLine.StartsWith("<!DOCTYPE") ||
firstLine.StartsWith("<HTML") ||
firstLine.StartsWith("<BODY"))
return LoadOptions.HtmlDefault;
return defaultOptions;
}
这也是一个有关如何使用它的小演示示例:
string filepath = "C://temp//book.xls";
LoadOptions options = GetLoadOptions(filepath);
if (options == null)
throw new FileFormatException();
ExcelFile ef = ExcelFile.Load(filepath, options);
// ...
内容总结
以上是互联网集市为您收集整理的无法在C#中使用Gembox加载.xls文件全部内容,希望文章能够帮你解决无法在C#中使用Gembox加载.xls文件所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。