国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > VBScript > 正文

vbs 多線程下載實現(xiàn)代碼

2019-10-26 18:06:28
字體:
供稿:網(wǎng)友
話說還是閑來練手,初步實現(xiàn)了自己認為的“多線程”下載。(至于是不是多線程,可以參考12樓鏈接)
為避免冗余,省了一些錯誤檢查。我覺得沒多大實際用途,有興趣的兄弟一起學(xué)習(xí)討論唄。歡迎大家指正:

復(fù)制代碼 代碼如下:

'by wankoilz

url=InputBox("輸入完整下載地址:")
threadCount=InputBox("輸入線程數(shù)(不超過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
'創(chuàng)建一個和下載文件同樣大小的臨時文件,供下面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對象的數(shù)組,·成員數(shù)量便是線程數(shù)
'直接 Dim 數(shù)組名(變量名) 是不行的,這里用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
'每當一個線程下載完畢就將其寫入臨時文件的相應(yīng)位置
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
'根據(jù)文件大小設(shè)定
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


測試下載地址:
復(fù)制代碼 代碼如下:

//www.jb51.net/images/logo.gif


VBS實現(xiàn) 多線程 補充

今天有人發(fā)郵件問我一個問題:
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 界首市| 房山区| 新密市| 湖口县| 扬州市| 正安县| 高清| 酒泉市| 建昌县| 密山市| 西畴县| 海南省| 绥宁县| 华安县| 富宁县| 凤凰县| 宿迁市| 北海市| 汽车| 万荣县| 石台县| 岑溪市| 新乡县| 台南县| 罗山县| 兴业县| 肥城市| 奉节县| 宜君县| 赤壁市| 绥宁县| 凤阳县| 安新县| 丹巴县| 蕲春县| 苍溪县| 阿合奇县| 翁牛特旗| 綦江县| 天等县| 溧阳市|