我正在使用VBA DoCmd.TransferText
命令将数据从CSV文本文件导入到Access数据库中的新表中。我遇到了一些问题,其中某些文件的前三列中的文本数据导入为货币。我无法弄清楚发生了什么事。TransferText不正确地导入像“FS ###”这样的字符串作为货币
Here是与正确导入(VollintineLines.csv)一个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
测试数据库的ZIP文件缺少Access DB的文件名! –
现在已修复,对不起! –