导出到 Excel 时更改日期格式

Dav*_*vid 1 vb.net excel date

我在程序中编写了导出到 Excel 的函数,这也与导入程序一致。

导入程序正在运行一些验证检查,但其中一些检查失败,因为 Excel 工作表将它们格式化为 MM/dd/yyyy,但大多数检查都存储为 dd/MM/yyyy。

查看我的导出程序后,我可以看到在导出之前,网格中的日期格式均正确为 dd/MM/yyyy,因此问题不在这里。

然而,当打开导出的 Excel 文件时,我可以看到某些日期存储为 MM/dd/yyyy。

我的电脑上的区域设置是正确的,设置为英国,甚至在检查列上的 Excel 格式后,我可以看到它设置为 dd/MM/yyyy。

那么,可能会出现什么问题呢?为什么有些出口不同?

网格中显示的值(正确格式 - 请参阅顶部 2 行“评价一次开始”,2016 年 1 月 6 日)

在此输入图像描述

导出例程中的代码

Dim formatRange As Excel.Range
formatRange = xlWorksheet.Range("F2", "F99000")
formatRange.NumberFormat = "dd/MM/yyyy"

formatRange = xlWorksheet.Range("I1", "I99000")
formatRange.NumberFormat = "dd/MM/yyyy"

formatRange = xlWorksheet.Range("J1", "J99000")
formatRange.NumberFormat = "dd/MM/yyyy"

formatRange = xlWorksheet.Range("M1", "M99000")
formatRange.NumberFormat = "dd/MM/yyyy"

formatRange = xlWorksheet.Range("N1", "N99000")
formatRange.NumberFormat = "dd/MM/yyyy"

formatRange = xlWorksheet.Range("Q1", "Q99000")
formatRange.NumberFormat = "dd/MM/yyyy"

For k As Integer = 1 To dgvExport.Columns.Count
    xlWorksheet.Cells(1, k) = dgvExport.Columns(k - 1).HeaderText
Next

Dim eStr As String = ""
Dim nStr As String = ""

Me.Cursor = Cursors.WaitCursor

For i = 0 To dgvExport.RowCount - 1
  For j = 0 To dgvExport.ColumnCount - 1
     Try
       eStr = Trim(dgvExport(j, i).Value)
       nStr = eStr.Replace(vbCr, "").Replace(vbLf, "")
       xlWorksheet.Cells(i + 2, j + 1) = nStr
     Catch
       xlWorksheet.Cells(i + 2, j + 1) = dgvExport(j, i).Value
     End Try

   Next
Next
Run Code Online (Sandbox Code Playgroud)

我导出的 Excel 文件(请注意,有些日期是 dd/MM,而有些日期是 MM/dd)

在此输入图像描述

Dav*_*vid 5

正如 @jkpieterse 所建议的,我只需要将日期值作为实际日期数据类型传递。为此,我修改了For Each循环。

原来的:

For i = 0 To dgvExport.RowCount - 1
  For j = 0 To dgvExport.ColumnCount - 1
    Try
       eStr = Trim(dgvExport(j, i).Value)
       nStr = eStr.Replace(vbCr, "").Replace(vbLf, "")
       xlWorksheet.Cells(i + 2, j + 1) = nStr
    Catch
      xlWorksheet.Cells(i + 2, j + 1) = dgvExport(j, i).Value
    End Try
  Next
Next
Run Code Online (Sandbox Code Playgroud)

工作版本:

For i = 0 To dgvExport.RowCount - 1
  For j = 0 To dgvExport.ColumnCount - 1
     Try
       If j <> 5 AndAlso j <> 8 AndAlso j <> 9 AndAlso j <> 12 AndAlso j <> 13 AndAlso j <> 16 Then
         eStr = Trim(dgvExport(j, i).Value)
         nStr = eStr.Replace(vbCr, "").Replace(vbLf, "")
         xlWorksheet.Cells(i + 2, j + 1) = nStr
       Else
         xlWorksheet.Cells(i + 2, j + 1) = Convert.ToDateTime(dgvExport(j, i).Value).GetDateTimeFormats(Threading.Thread.CurrentThread.CurrentCulture.DateTimeFormat)
       End If
     Catch
       xlWorksheet.Cells(i + 2, j + 1) = dgvExport(j, i).Value
     End Try

  Next
Next
Run Code Online (Sandbox Code Playgroud)

这意味着,如果正在评估的当前列的索引不是包含日期的列之一,则将其正常导出,但如果是,则将其转换为日期时间,其格式与线程的当前区域性格式。

这就像做梦一样。