用于下载CSV文件的Visual Basic脚本(CSV为空 - 0字节)

时间:2012-04-25 18:14:33

标签: vbscript ftp

我有一个vb脚本从URL下载文件 - 该网址是一个ftp网站:ftp://ftp.zois.co.uk/pub/jcp/

我需要下载下面指定的文件。脚本获取文件但内容为空 - 尝试使用ftp站点上的其他CSV文件并遇到同样的问题。

有人可以帮忙吗?

HTTPDownload "ftp://ftp.zois.co.uk/pub/jcp/JCP-scrape-2012-04-24.csv", "C:\"

Sub HTTPDownload( myURL, myPath )
' This Sub downloads the FILE specified in myURL to the path specified in myPath.
'
' myURL must always end with a file name
' myPath may be a directory or a file name; in either case the directory must exist
'
 ' Written by Rob van der Woude
' http://www.robvanderwoude.com
'
    ' Based on a script found on the Thai Visa forum
' http://www.thaivisa.com/forum/index.php?showtopic=21832

' Standard housekeeping
Dim i, objFile, objFSO, objHTTP, strFile, strMsg
Const ForReading = 1, ForWriting = 2, ForAppending = 8

' Create a File System Object
Set objFSO = CreateObject( "Scripting.FileSystemObject" )

' Check if the specified target file or folder exists,
' and build the fully qualified path of the target file
If objFSO.FolderExists( myPath ) Then
    strFile = objFSO.BuildPath( myPath, Mid( myURL, InStrRev( myURL, "/" ) + 1 ) )
ElseIf objFSO.FolderExists( Left( myPath, InStrRev( myPath, "\" ) - 1 ) ) Then
    strFile = myPath
Else
    WScript.Echo "ERROR: Target folder not found."
    Exit Sub
End If

' Create or open the target file
Set objFile = objFSO.OpenTextFile( strFile, ForWriting, True )

' Create an HTTP object
Set objHTTP = CreateObject( "WinHttp.WinHttpRequest.5.1" )

' Download the specified URL
objHTTP.Open "GET", myURL, False
objHTTP.Send

' Write the downloaded byte stream to the target file
For i = 1 To LenB( objHTTP.ResponseBody )
    objFile.Write Chr( AscB( MidB( objHTTP.ResponseBody, i, 1 ) ) )
Next

' Close the target file
objFile.Close( )
End Sub

1 个答案:

答案 0 :(得分:0)

该代码用于从HTTP下载。 FTP不是HTTP。 FTP确实有一个get命令,但如果没有其他东西,端口几乎肯定是不同的,因为没有指定端口,它几乎肯定使用80用于HTTP,而FTP使用21作为其默认值。 Here是使用ftp的类似示例。可能有其他/更好的FTP组件,而不是它使用的,但这是你的问题的根源。另请注意,它并没有真正获取您的文件,它只是创建一个永远不会被写入的文件。