0

我有一个从 URL 下载文件的 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
4

1 回答 1

0

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

于 2012-04-25T18:28:59.267 回答