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