我使用以下代码读取 xls 文件:
private static DataSet GetDataSetFromExcelFilePath(string filePath)
{
try
{
//Microsoft.Jet.OLEDB.4.0
using (OleDbConnection oleDbConnection = new
OleDbConnection(string.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0}; Extended Properties=\"Excel 8.0;Persist Security Info=False;HDR=No;IMEX=1;\"", filePath)))
//OleDbConnection(string.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0}; Extended Properties=\"Excel 8.0;Persist Security Info=False;HDR=No;IMEX=1\"", filePath)))
// using (OleDbConnection oleDbConnection = new
// OleDbConnection(string.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0}; Extended Properties=\"Excel 8.0;Persist Security Info=False;HDR=No;IMEX=1\"", filePath)))
{
oleDbConnection.Open();
DataTable schema = oleDbConnection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
string sheetName = schema.Rows[0].Field<string>("TABLE_NAME");
var adapter = new OleDbDataAdapter(string.Format("SELECT * FROM [{0}]", sheetName), oleDbConnection);
var dataSet = new DataSet();
adapter.Fill(dataSet, Path.GetFileName(filePath));
return dataSet;
}
}
catch (Exception ex)
{
return null;
}
}
请注意,我在连接字符串中设置了 IMEX 1,因此它将所有数据作为字符串读取,但我在客户的一台计算机上遇到了一个奇怪的问题,其中 AM/PM 或完整的 HH 在时间上被完全忽略。以下是使用上述代码填充数据集的方式:https://gyazo.com/f45c29c42b5d1339ae1fe159be4caf76 AM 和 PM 之间没有区别。
下面是 excel 中的实际数据: https://gyazo.com/caf91c165eb08e3110fd2c3b7d4b8c51
请注意,无法更改 Excel 格式或结构。最好是任何可能的更改都必须在代码中完成。
作为引用,如果有人想下载excel文件进行测试,这里是:https://www.dropbox.com/s/7824xh3ihlym9v9/test.xls?dl=0
还有一件事,当您将窗口语言设置为挪威时,可以复制该问题,如下所示:https://gyazo.com/d03b3056ed81e177076471a74058fdb7
最佳答案
ODBC 的问题是众所周知的错误。当您没有确切的设置/office版本/注册表等时,很难给出正确的建议。
您使用的IMEX=1
设置仅设置“模式”,即导入模式。然后,您有一个注册表设置ImportMixedTypes
,您可以在其中指定两个值:Text
或Majority Type
。默认设置是 Text
,这就是您将所有内容都以文本形式获取的原因。更多详情可以看我的回答here .
您的时间问题比您尝试将其转换为文本更复杂。 Excel 本身有一个时间的内部表示,然后您可以将其转换为文本。这就是您错过 PM/AM 部分的原因。最简单的方法是使用 24 小时格式,您可能知道但不想要这种格式。
还有出路吗?是的。连接Excel文件时需要直接指定列:
...
var timeColumn =
new OleDbDataAdapter("SELECT FORMAT([Time], 'hh:mm tt') as [Time] FROM [sheetName]", oleDbConnection);
...
要查看FORMAT
的更多选项,请参阅 MSDN .
关于c# - 具有 IMEX 1 的 OleDBConnection 忽略时间值中的 AM/PM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58568393/