Batch file 批处理或vb脚本从excel文件读取URL,并将URL附加文件下载到指定位置或目录

Batch file 批处理或vb脚本从excel文件读取URL,并将URL附加文件下载到指定位置或目录,batch-file,vbscript,download,automatic-storage,Batch File,Vbscript,Download,Automatic Storage,我正在寻找一个VB脚本或批处理文件,从包含列B中URL数据的CSV文件中读取和执行多个URL,所述URL直接包含在可下载文件中,该文件需要存储在代表列a中存储的内容命名的位置或目录中 列A和列B可以是相反的 我试着用批处理文件做同样的事情,但无法自动读取CSV文件,而是能够创建如下所示的简单代码,但在日常使用中不会成功,因为自动总是需要手动干预,请相应地帮助,另外,检入Python解决方案代码可用,但不希望将其作为Python安装所需的代码使用,因为我也不希望这样做 @echo Off TITL

我正在寻找一个VB脚本或批处理文件,从包含列B中URL数据的CSV文件中读取和执行多个URL,所述URL直接包含在可下载文件中,该文件需要存储在代表列a中存储的内容命名的位置或目录中

列A和列B可以是相反的

我试着用批处理文件做同样的事情,但无法自动读取CSV文件,而是能够创建如下所示的简单代码,但在日常使用中不会成功,因为自动总是需要手动干预,请相应地帮助,另外,检入Python解决方案代码可用,但不希望将其作为Python安装所需的代码使用,因为我也不希望这样做

@echo Off
TITLE Test File Download and Storage
Pause
CD\
d:
cd Test
dir Tes_poc1 [i.e. From column A] 
curl http://www.abcd,com/file1.pdf > file1.pdf [URL Just for example, can't share actual one due to security limitations]
cd Test
dir Tes_poc2 "i.e. From column A" 
curl http://www.abcd,com/file2.pdf > file2.pdf [URL Just for example, can't share actual one due to security limitations]

编辑:

还尝试了以下VBscript,可以下载文件并创建文件夹,但无法将下载的文件移动到相应的文件夹:

dim objFileSys, objReadFile
Const ForReading = 1, ForWriting = 2, ForAppending = 8
Const csFSpec = "1.txt"
Dim goFS : Set goFS = CreateObject("Scripting.FileSystemObject")
Dim goWS : Set goWS = CreateObject("WScript.Shell")
Dim tsIn : Set tsIn = goFS.OpenTextFile(csFSpec)
Do Until tsIn.AtEndOfStream
Dim sLine : sLine = tsIn.ReadLine
goWS.Run """chrome.exe"" """ & sLine & """", 1, True
Loop
tsIn.Close
Set objFileSys = CreateObject("Scripting.FileSystemObject")
Set objReadFile = objFileSys.OpenTextFile("D:\Test\2.txt", ForReading)
Do until objReadFile.AtEndOfStream = True
objFileSys.CreateFolder(objReadFile.ReadLine)
Loop
objReadFile.Close
Set objReadFile = Nothing
Set objFileSys = Nothing
其中1.txt包含URL列表,2.txt包含要创建的各个URL文件夹名称的列表

这里有几个示例URL可以用作示例。


假设在批处理文件的同一文件夹中有类似于此的.csv文件的内容:Test.csv

您可以使用Certutil命令行执行以下操作以下载文件:

@echo关闭
模式60、3和颜色A
Hackoo 2018使用Certutil命令下载标题文件
设置“文件=%~dp0Test.csv”
设置“DownloadFolder=%~dp0Test”
如果不存在“%DownloadFolder%”MD“%DownloadFolder%”
CD/D“%DownloadFolder%”
@对于/F“tokens=1-2 delims=,”%%i in('类型“%File%”)do(
如果不存在“%DownloadFolder%\%%i\”MD“%DownloadFolder%\%%i\”
cls&echo(&echo下载“%%~nxj”
呼叫:下载%%j%DownloadFolder%%\%%i\%%~nxj
)
启动“资源管理器”%DownloadFolder%“&退出
::--------------------------------------------
:下载
certutil.exe-urlcache-split-f%1%2>nul
退出/b
::-------------------------------------------

您可以尝试使用progressbar作为奖励

用法:在要下载的脚本上拖放包含每行url的文本文件

在命令行中的用法:Cscript//nologo“ThisVbsFile”“Path\TextFile.txt”

选项显式
Const Copyright=“(C)由Hackoo 2018提供”
Dim标题、输入文件、objFSO、objStream、dic、URL、文件名、路径脚本
Dim BaseName、Save2File、文件夹、k、WaitingMsg、ws、Temp、oExec、HH
Title=“从文件下载”
如果WSH.Arguments.Count=0,则
MsgBox“用法:将包含每行url的文本文件拖放到”&_
“此脚本”&DblQuote(WSH.Scriptname)和“待下载”&vbCrlf&_
“或”&vbCrlf&_
“在命令行中的用法:”&vbCrlf&_
“Cscript//nologo”&DblQuote(WSH.Scriptname)和“&DblQuote(“Path\TextFile.txt”)_
感叹号、标题和版权
Wscript.Quit(1)
如果结束
InputFile=Wscript.Arguments(0)
设置objFSO=CreateObject(“Scripting.FileSystemObject”)
设置objStream=objFSO.OpenTextFile(InputFile,1)
设置dic=CreateObject(“Scripting.Dictionary”)
设置ws=CreateObject(“WScript.Shell”)
Temp=ws.ExpandEnvironmentStrings(“%Temp%”)
不执行objStream.AtEndOfStream时执行
URL=objStream.ReadLine
如果URL为“”,则
FileName=GetFileNamefromDirectLink(URL)
PathScript=objFSO.GetParentFolderName(wscript.ScriptFullName)'此Vbscript的路径
BaseName=GetFilenameWithoutExtension(文件名)
Folder=PathScript&“\”&BaseName
如果不存在objFSO.FolderExists(文件夹),则
objFSO.CreateFolder(文件夹)
如果结束
添加URL、文件夹和“\”文件名
如果结束
环
对于dic中的每个URL
Save2File=dic(URL)
WaitingMsg=“请稍候…”下载:&DblQuote(Save2File)&“正在进行…”
调用CreateProgressBar(标题,WaitingMsg)创建等待栏
调用LaunchProgressBar()'启动等待栏
呼叫下载(URL,Save2File)
暂停(1)
调用CloseProgressBar()
下一个
设置HH=CreateObject(“Internet.HHCtrl”)
HH.textpoop“下载完成!”,“Tahoma,32”,10,10,10500
暂停(3)
Wscript.Quit(0)
'------------------------------------------------
子下载(URL,Save2File)
Dim文件、行、BS、ws
出错时继续下一步
Set File=CreateObject(“WinHttp.WinHttpRequest.5.1”)
文件。打开“获取”,URL,False
File.Send()文件
如果错误号为0,则
Line=Line&vbcrlf&“获取文件时出错”
Line=Line&vbcrlf&“Error”&errr.number&“(0x”&hex(err.number)&“”&vbcrlf&_
错误描述
Line=Line&vbcrlf&“Source”&err.Source
MsgBox行,vbCritical,“获取文件时出错”
清楚
wscript.quit
如果结束
如果File.Status=200,则“文件”存在,可以下载
设置BS=CreateObject(“ADODB.Stream”)
设置ws=CreateObject(“wscript.Shell”)
BS.type=1
英国公开赛
BS.Write File.ResponseBody
BS.SaveToFile Save2File,2
ElseIf File.Status=404然后
MsgBox“未找到文件:”&文件状态,vbCritical,“未找到错误文件”
其他的
MsgBox“未知错误:”&File.Status,vbCritical,“获取文件时出错”
如果结束
端接头
'------------------------------------------------
函数GetFileNamefromDirectLink(URL)
文件名
ArrFile=Split(URL“/”)
FileName=ArrFile(UBound(ArrFile))
GetFileNamefromDirectLink=文件名
端函数
'------------------------------------------------
函数DblQuote(Str)
DblQuote=Chr(34)和Str&Chr(34)
端函数
'------------------------------------------------
函数GetFilenameWithoutExtension(文件名)
暗淡的结果,我
结果=文件名
i=InStrRev(文件名“.”)
如果(i>0),则
结果=Mid(文件名,1,i-1)
如果结束
获取文件
Tes_poc1,http://www.pdf995.com/samples/pdf.pdf
Tes_poc2,https://www.google.com/images/branding/googlelogo/1x/googlelogo_color_272x92dp.png
Option Explicit
Const Copyright =" (C) by Hackoo 2018"
Dim Title,InputFile,objFSO,objStream,dic,URL,FileName,PathScript
Dim BaseName,Save2File,Folder,k,WaitingMsg,ws,Temp,oExec,HH
Title = "Download From File"
If WSH.Arguments.Count = 0 Then
    MsgBox "Usage : Drag and Drop a text file that contains url per row over " &_
    "this script "& DblQuote(WSH.Scriptname) & " to be downloaded "& vbCrlf &_
    "OR " & vbCrlf &_
    "Usage in command line : "& vbCrlf &_
    "Cscript //nologo "& DblQuote(WSH.Scriptname) & " " & DblQuote("Path\TextFile.txt"),_
    vbExclamation,Title & Copyright
    Wscript.Quit(1) 
End If
InputFile = Wscript.Arguments(0)
Set objFSO = CreateObject("Scripting.FileSystemObject")
set objStream = objFSO.OpenTextFile (InputFile, 1)
set dic = CreateObject("Scripting.Dictionary")
Set ws = CreateObject("WScript.Shell")
Temp = ws.ExpandEnvironmentStrings("%Temp%")
Do while not objStream.AtEndOfStream
   URL = objStream.ReadLine
   If URL <> "" Then
   FileName = GetFileNamefromDirectLink(URL)
   PathScript = objFSO.GetParentFolderName(wscript.ScriptFullName) 'Path of this Vbscript
   BaseName = GetFilenameWithoutExtension(FileName)
   Folder = PathScript & "\" & BaseName
    If Not objFSO.FolderExists(Folder) Then 
        objFSO.CreateFolder(Folder)
    End If
   dic.Add URL,Folder & "\" & FileName
   End If
Loop

For Each URL in dic
    Save2File = dic(URL)
    WaitingMsg = "Please wait ... The download of : <font color=Yellow>"& DblQuote(Save2File) & "</font> is in progress ..."
    Call CreateProgressBar(Title,WaitingMsg)'Creation of Waiting Bar
    Call LaunchProgressBar() 'Launch of the Waiting Bar
    Call Download(URL,Save2File)
    pause(1)
    Call CloseProgressBar()
Next

Set HH = CreateObject("Internet.HHCtrl")
HH.TextPopup " Download is finished ! ", "Tahoma,32", 10,10,10,500
Pause(3)
Wscript.Quit(0)
'------------------------------------------------
Sub Download(URL,Save2File)
    Dim File,Line,BS,ws
    On Error Resume Next
    Set File = CreateObject("WinHttp.WinHttpRequest.5.1")
    File.Open "GET",URL, False
    File.Send()
    If err.number <> 0 then
        Line  = Line &  vbcrlf & "Error Getting File"
        Line  = Line &  vbcrlf & "Error " & err.number & "(0x" & hex(err.number) & ") " & vbcrlf &_
        err.description
        Line  = Line &  vbcrlf & "Source " & err.source 
        MsgBox Line,vbCritical,"Error getting file"
        Err.clear
        wscript.quit
    End If
    If File.Status = 200 Then ' File exists and it is ready to be downloaded
        Set BS = CreateObject("ADODB.Stream")
        Set ws = CreateObject("wscript.Shell")
        BS.type = 1
        BS.open
        BS.Write File.ResponseBody
        BS.SaveToFile Save2File, 2
    ElseIf File.Status = 404 Then
        MsgBox "File Not found : " & File.Status,vbCritical,"Error File Not Found"
    Else
        MsgBox "Unknown Error : " & File.Status,vbCritical,"Error getting file"
    End If
End Sub
'------------------------------------------------
Function GetFileNamefromDirectLink(URL)
    Dim ArrFile,FileName
    ArrFile = Split(URL,"/")
    FileName = ArrFile(UBound(ArrFile))
    GetFileNamefromDirectLink = FileName
End Function
'------------------------------------------------
Function DblQuote(Str)
    DblQuote = Chr(34) & Str & Chr(34)
End Function
'------------------------------------------------
Function GetFilenameWithoutExtension(FileName)
    Dim Result, i
    Result = FileName
    i = InStrRev(FileName, ".")
    If ( i > 0 ) Then
        Result = Mid(FileName, 1, i - 1)
    End If
    GetFilenameWithoutExtension = Result
End Function
'------------------------------------------------
Sub CreateProgressBar(Title,WaitingMsg)
    Dim ws,fso,f,f2,ts,ts2,Ligne,i,fread,LireTout,NbLigneTotal,Temp,PathOutPutHTML,fhta,oExec
    Set ws = CreateObject("wscript.Shell")
    Set fso = CreateObject("Scripting.FileSystemObject")
    Temp = WS.ExpandEnvironmentStrings("%Temp%")
    PathOutPutHTML = Temp & "\Barre.hta"
    Set fhta = fso.OpenTextFile(PathOutPutHTML,2,True)
    fhta.WriteLine "<HTML>"
    fhta.WriteLine "<HEAD>"
    fhta.WriteLine "<Title>  " & Title & Copyright & "</Title>"
    fhta.WriteLine "<HTA:APPLICATION"
    fhta.WriteLine "ICON = ""magnify.exe"" "
    fhta.WriteLine "BORDER=""THIN"" "
    fhta.WriteLine "INNERBORDER=""NO"" "
    fhta.WriteLine "MAXIMIZEBUTTON=""NO"" "
    fhta.WriteLine "MINIMIZEBUTTON=""NO"" "
    fhta.WriteLine "SCROLL=""NO"" "
    fhta.WriteLine "SYSMENU=""NO"" "
    fhta.WriteLine "SELECTION=""NO"" "
    fhta.WriteLine "SINGLEINSTANCE=""YES"">"
    fhta.WriteLine "</HEAD>"
    fhta.WriteLine "<BODY text=""white""><CENTER>"
    fhta.WriteLine "<marquee DIRECTION=""LEFT"" SCROLLAMOUNT=""3"" BEHAVIOR=ALTERNATE><font face=""Comic sans MS"">" & WaitingMsg &"</font></marquee>"
    fhta.WriteLine "<img src="""" />"
    fhta.WriteLine "</CENTER></BODY></HTML>"
    fhta.WriteLine "<SCRIPT LANGUAGE=""VBScript""> "
    fhta.WriteLine "Set ws = CreateObject(""wscript.Shell"")"
    fhta.WriteLine "Temp = WS.ExpandEnvironmentStrings(""%Temp%"")"
    fhta.WriteLine "Sub window_onload()"
    fhta.WriteLine "    CenterWindow 575,100"
    fhta.WriteLine "    Self.document.bgColor = ""DarkOrange"" "
    fhta.WriteLine " End Sub"
    fhta.WriteLine " Sub CenterWindow(x,y)"
    fhta.WriteLine "    Dim iLeft,itop"
    fhta.WriteLine "    window.resizeTo x,y"
    fhta.WriteLine "    iLeft = window.screen.availWidth/2 - x/2"
    fhta.WriteLine "    itop = window.screen.availHeight/2 - y/2"
    fhta.WriteLine "    window.moveTo ileft,itop"
    fhta.WriteLine "End Sub"
    fhta.WriteLine "</script>"
    fhta.close
End Sub
'------------------------------------------------
Sub LaunchProgressBar()
    Set oExec = Ws.Exec("mshta.exe " & Temp & "\Barre.hta")
End Sub
'------------------------------------------------
Sub CloseProgressBar()
    oExec.Terminate
End Sub
'------------------------------------------------
Function DblQuote(Str)
    DblQuote = Chr(34) & Str & Chr(34)
End Function
'------------------------------------------------
Sub Pause(Secs)    
    Wscript.Sleep(Secs * 1000)    
End Sub  
'------------------------------------------------