当前位置:  开发笔记 > 编程语言 > 正文

使用C#解析XLS文件时出现问题

如何解决《使用C#解析XLS文件时出现问题》经验,为你挑选了1个好方法。

好吧,让我们看看我是否能让它变得有意义.

我有一个程序编写解析Excel文件,它工作得很好.我使用以下内容进入文件:

string FileToConvert = Server.MapPath(".") + "\\App_Data\\CP-ARFJN-FLAG.XLS";
string connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + FileToConvert + ";Extended Properties=Excel 8.0;";
OleDbConnection connection = new OleDbConnection(connectionString);
connection.Open();
//this next line assumes that the file is in default Excel format with Sheet1 as the first sheet name, adjust accordingly
OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM [CP-ARFJN-FLAG$]", connection);

这很好用.但是当我在实际文件上尝试它(它由另一个程序提供给我)时,我收到此错误:

System.Data.OleDb.OleDbException: External table is not in the expected format. at System.Data.OleDb.OleDbConnectionInternal..ctor(OleDbConnectionString constr, OleDbConnection connection) at System.Data.OleDb.OleDbConnectionFactory.CreateConnection(DbConnectionOptions options, Object poolGroupProviderInfo, DbConnectionPool pool, DbConnection owningObject) at System.Data.ProviderBase.DbConnectionFactory.CreateNonPooledConnection(DbConnection owningConnection, DbConnectionPoolGroup poolGroup) at System.Data.ProviderBase.DbConnectionFactory.GetConnection(DbConnection owningConnection) at System.Data.ProviderBase.DbConnectionClosed.OpenConnection(DbConnection outerConnection, DbConnectionFactory connectionFactory) at System.Data.OleDb.OleDbConnection.Open() at wetglobe.Page_Load(Object sender, EventArgs e)

但是,这是我认为问题所在.如果我拿这个文件,并用我的本地Excel保存,首先我得到这个弹出窗口:

CP-ARFJN-FLAG.XLS可能包含与Text(制表符分隔)不兼容的功能.您想以这种格式保留工作簿吗?

要保留此格式(不包含任何不兼容的功能),请单击"是".

要保留这些功能,请单击"否".十以最新的Excel格式保存副本.

要查看可能丢失的内容,请单击"帮助".

如果我单击否,然后将其保存为当前的Excel格式,程序将正常工作.

所以我假设这是以一些疯狂的旧Excel格式保存的?

我想我的问题是:

我怎么知道Excel版本保存了什么?

如何解析当前状态?

- 或者 - 我可以编程方式将其保存为更新版本吗?

我希望很清楚......谢谢.



1> Ed Harper..:

听起来您的第三方应用程序生成的XLS文件可能不是真正的Excel格式 - 它实际上可能是带有.xls扩展名的制表符分隔文本文件.

尝试用文本编辑器打开它,看看.

如果是制表符分隔符,则可以放弃OleDB适配器并将其作为标准文本文件打开/解析.

推荐阅读
pan2502851807
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有