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

标签 c# excel c#-4.0 .net-4.5 windows-server-2012

我使用以下代码读取 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/

相关文章:

c# - 当文本长于标签大小时调整标签的文本大小?

excel - 将值从一个工作表复制到另一个

php - 使用 PHPExcel 处理 .xls 获取 OOM

c#-4.0 - Nlog 未将所有行写入并行循环中的文件

javascript - 如何将所有 JS 文件写入一个 html 页面?

c# - NHibernate 异常枚举器已修改

c# - 如何在不将整个图像加载到内存的情况下加载 TIFF 图像的一部分?

c# - 如何将光标锁定到游戏窗口?

使用两个日期的 SQL 查询

c# - C# 中的泛型类型