gpt4 book ai didi

c# - 有没有办法强制 Microsoft.Jet.OLEDB 从 Excel 中获取 MM/DD/YYYY 格式的日期列?

转载 作者:太空狗 更新时间:2023-10-29 23:18:55 24 4
gpt4 key购买 nike

我在从 Excel 工作表读取 DateColumns 时遇到问题。

有时人们使用不同的日期格式,这会带来问题。比方说,当我期望从 Excel 列中得到 07/26/2010 时,我得到了 26-Jul-2010,因为用户更改了它的日期格式。

我使用 Microsoft.Jet.OLEDB 将 xls 工作表读入 DataTable

无论 XLS 上设置的 DateFormat 是什么,我能否以某种方式强制 OleDb 阅读器将所有日期转换为 MM/DD/YYYY 格式?

我用这段代码读取Excel文件:

string strConn;
strConn = @"Provider=Microsoft.Jet.OLEDB.4.0;" +
"Data Source=" + uploadedFileInfo.FullName + ";" +
@"Extended Properties=""Excel 8.0;HDR=NO;""";


using (OleDbConnection connToExcel = new OleDbConnection(strConn))
{
//You must use the $ after the object you reference in the spreadsheet
connToExcel.Open();

string firstSheetName = ExcelUploadedFileReaderBuilder
.GetFirstExcelSheetName(connToExcel);

OleDbDataAdapter myCommand
= new OleDbDataAdapter(String.Format("SELECT * FROM [{0}]", firstSheetName), connToExcel);

DataSet myDataSet = new DataSet();

myCommand.Fill(myDataSet, "uploadedExcelTable");

DataTable dtUploadedExcel = myDataSet.Tables["uploadedExcelTable"];

lineCount = GetLineNumberWhereNULLRowOccured(dtUploadedExcel) + 1;

connToExcel.Close();
}

最佳答案

您不必按照建议遍历数据集。通过在查询中指定所需的格式,您可以让查询为您完成所有格式设置。
示例如下:

OleDbDataAdapter myCommand = 
new OleDbDataAdapter("SELECT FORMAT([DateCol], 'MM/dd/yyyy') as [DateCol] FROM [SheetName]", connToExcel);

只要您使用的是 JET OLEDB 或 Ace OLEDB 数据提供程序,它就可以保证正常工作。我不能保证它会与其他数据提供商一起使用,但您可以随时检查。

关于c# - 有没有办法强制 Microsoft.Jet.OLEDB 从 Excel 中获取 MM/DD/YYYY 格式的日期列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3532197/

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