中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vbs 中怎么實現多線程下載功能

發布時間:2021-08-09 16:21:13 來源:億速云 閱讀:188 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關vbs 中怎么實現多線程下載功能,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

代碼如下:


'by wankoilz

url=InputBox("輸入完整下載地址:")
threadCount=InputBox("輸入線程數(不超過10吧,太多就累贅了):")
fileName=GetFileName(url)
filePath=GetFilePath(WScript.ScriptFullName)
Set ohttp=CreateObject("msxml2.xmlhttp")
Set ado=CreateObject("adodb.stream")
Set fso=CreateObject("scripting.filesystemobject")
ado.Type=1
ado.Mode=3
ado.Open
ohttp.open "Head",url,True
ohttp.send
Do While ohttp.readyState<>4
WScript.Sleep 200
Loop
'獲得文件大小
fileSize=ohttp.getResponseHeader("Content-Length")
ohttp.abort
'創建一個和下載文件同樣大小的臨時文件,供下面ado分段重寫
fso.CreateTextFile(filePath&"TmpFile",True,False).Write(Space(fileSize))
ado.LoadFromFile(filePath&"TmpFile")

blockSize=Fix(fileSize/threadCount):remainderSize=fileSize-threadCount*blockSize
upbound=threadCount-1
'定義包含msxml2.xmlhttp對象的數組,·成員數量便是線程數
'直接 Dim 數組名(變量名) 是不行的,這里用Execute變通了一下
Execute("Dim arrHttp("&upbound&")")
For i=0 To UBound(arrHttp)
startpos=i*blockSize
endpos=(i+1)*blockSize-1
If i=UBound(arrHttp) Then endpos=endpos+remainderSize
Set arrHttp(i)=CreateObject("msxml2.xmlhttp")
arrHttp(i).open "Get",url,True
'分段下載
arrHttp(i).setRequestHeader "Range","bytes="&startpos&"-"&endpos
arrHttp(i).send
Next
Do
WScript.Sleep 200
For i=0 To UBound(arrHttp)
If arrHttp(i).readystate=4 Then
'每當一個線程下載完畢就將其寫入臨時文件的相應位置
ado.Position=i*blockSize
MsgBox "線程"&i&"下載完畢!"
ado.Write arrHttp(i).responseBody
arrHttp(i).abort
complete=complete+1
End If
Next
If complete=UBound(arrHttp)+1 Then Exit Do
timeout=timeout+1
If timeout=5*30 Then
'根據文件大小設定
MsgBox "30秒超時!"
WScript.Quit
End If
Loop
If fso.FileExists(filePath&fileName) Then fso.DeleteFile(filePath&fileName)
fso.DeleteFile(filePath&"TmpFile")
ado.SaveToFile(filePath&fileName)
MsgBox "文件下載完畢!"

Function GetFileName(url)
arrTmp=Split(url,"/")
GetFileName=arrTmp(UBound(arrTmp))
End Function

Function GetFilePath(fullname)
arrTmp=Split(fullname,"\")
For i=0 To UBound(arrTmp)-1
GetFilePath=GetFilePath&arrTmp(i)&"\"
Next
End Function



測試下載地址:

復制代碼 代碼如下:


https://cache.yisu.com/upload/information/20210311/308/13829.gif



VBS實現 多線程 補充

今天有人發郵件問我一個問題:

想請教一下VBS中INPUTBOX函數能否超時關閉?
如果可以的話,應該如何超時關閉輸入框? 萬分感謝

乍一看這是不可能實現的,因為InputBox函數本身沒有超時關閉的參數,而且程序會一直等待InputBox返回才繼續運行,后面的語句不可能在InputBox返回之前執行。

如果VBS能實現高級語言的多線程的話……只可惜VBS不可能實現多線程,但是可以用setTimeout方法模擬“多線程”。

復制代碼 代碼如下:


Dim IE
Set IE = CreateObject("InternetExplorer.Application")
IE.Navigate "about:blank"
Set window = IE.Document.parentWindow
id = window.setTimeout(GetRef("on_timeout"),3000,"VBScript")
name = InputBox("Please enter your name","InputBox Timeout")
window.clearTimeout id
If name <> "" Then MsgBox "Hello," & name
IE.Quit

&apos;By Demon
&apos;http://demon.tw

Sub on_timeout()
Dim WshShell
set WshShell = CreateObject("wscript.Shell")
WshShell.SendKeys "{ESC}"
End Sub

上述就是小編為大家分享的vbs 中怎么實現多線程下載功能了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vbs
AI

墨江| 祁连县| 道真| 湘乡市| 年辖:市辖区| 疏勒县| 壤塘县| 庆云县| 固镇县| 宣武区| 武汉市| 灌云县| 象州县| 当涂县| 仁寿县| 香港| 广西| 集贤县| 郯城县| 商城县| 天峨县| 海南省| 大新县| 湘潭市| 安徽省| 磐安县| 安图县| 宁城县| 杂多县| 嵩明县| 武汉市| 家居| 共和县| 龙山县| 肇州县| 福州市| 滦平县| 凭祥市| 农安县| 察雅县| 顺义区|