gpt4 book ai didi

c# - 具有 IMEX 1 的 OleDBConnection 忽略时间值中的 AM/PM

转载 作者:行者123 更新时间:2023-12-01 17:19:09 28 4
gpt4 key购买 nike

我使用以下代码读取 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,您可以在其中指定两个值:TextMajority 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/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com