我知道这是一个相当常见的问题,但我还没有找到可靠的解决方案。
我有一个csv文件中的数据,第一列格式为dd/mm/yyyy。当我使用Workbooks.OpenText打开它时,默认为mm/dd/yyyy,直到它发现它认为的月份超过12,然后恢复为dd/mm/yyyy。
这是我的测试代码,它试图将其强制为xlDMYFormat,我也尝试了文本格式。我知道这个问题只适用于*.csv文件,而不是*.txt,但这不是一个可接受的解决方案。
Option Base 1
Sub TestImport()
Filename = "test.csv"
Dim ColumnArray(1 To 1, 1 To 2)
ColumnsDesired = Array(1)
DataTypeArray = Array(xlDMYFormat)
' populate the array for fieldinfo
For x = LBound(ColumnsDesired) To UBound(ColumnsDesired)
ColumnArray(x, 1) = ColumnsDesired(x)
ColumnArray(x, 2) = DataTypeArray(x)
Next x
Workbooks.OpenText Filename:=Filename, DataType:=xlDelimited, Comma:=True, FieldInfo:=ColumnArray
End Sub
test.csv 包含以下内容:
Date
11/03/2010
12/03/2010
13/03/2010
14/03/2010
15/03/2010
16/03/2010
17/03/2010