我正在使用VBA DoCmd.TransferText
命令将CSV文本文件中的数据导入Access数据库中的新表。我遇到了一些问题,其中某些文件的前三列中的文本数据作为货币导入。我无法弄清楚发生了什么。
Here是一个测试数据库,还有一个正确导入的CSV(VollintineLines.csv)......
PipeID,UpstreamMH,DownstreamMH,Diameter,GISLength,Status
WS010353S,WS010353,WS010163,36,227.1984614,Fully Surveyed as Phase Work
WS011155S,WS011155,WS011154,8,418.5435318,Not Surveyed
WS011154S,WS011154,WS011153,8,303.9618911,Fully Surveyed as Phase Work
......还有一个没有(CourtLines.csv)。
PipeID,UpstreamMH,DownstreamMH,Diameter,GISLength,Status
FS020628S,FS020628,FS020462,10,278.72,Not Surveyed
FS020463S-1,FS020463,FS020462,12,248.39,Not Surveyed
FS020216S,FS020216,FS020215,12,227.53,Fully Surveyed as Phase Work
(请忽略数据库中未命名的对象,只是想弄清楚这里发生了什么,我没有打扰命名。)
以下是导入代码,您必须启用Microsoft Office 16.0对象库参考。
Private Sub Command0_Click()
Dim Path As FileDialog
Dim FileName As Variant
DoCmd.SetWarnings False
DoCmd.Hourglass True
Set Path = Application.FileDialog(msoFileDialogFilePicker)
With Path
.AllowMultiSelect = False
.Title = "Select your File"
.Filters.Add "All Files", "*.*"
If .Show = -1 Then
For Each FileName In .SelectedItems
DoCmd.TransferText acImportDelim, , "TempPipeData", FileName, True
Next FileName
Else
MsgBox "No File Selected to Import."
End If
End With
DoCmd.SetWarnings True
DoCmd.Hourglass False
End Sub
答案 0 :(得分:0)
您显然遇到了一个相当模糊的错误,它影响了不使用导入规范的TransferText
调用。 (它也在另一个网站here上讨论。)
解决方法包括:
Text
),然后从CSV文件导入现有(空)表。TransferSpreadsheet
导入Excel数据,然后