濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > vbs 多線程下載實(shí)現(xiàn)代碼

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

熱門(mén)標(biāo)簽:加盟電銷(xiāo)機(jī)器人好的品牌 辦理膠州400電話財(cái)稅 百度地圖標(biāo)注怎么卸載 前鋒辦理400電話申請(qǐng) 陜西高頻外呼回?fù)芟到y(tǒng)哪家好 外呼營(yíng)銷(xiāo)下單系統(tǒng) 新密防封卡外呼系統(tǒng)違法嗎 海外美發(fā)店地圖標(biāo)注 打電話的外呼系統(tǒng)貴不貴
話說(shuō)還是閑來(lái)練手,初步實(shí)現(xiàn)了自己認(rèn)為的“多線程”下載。(至于是不是多線程,可以參考12樓鏈接)
為避免冗余,省了一些錯(cuò)誤檢查。我覺(jué)得沒(méi)多大實(shí)際用途,有興趣的兄弟一起學(xué)習(xí)討論唄。歡迎大家指正:

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

'by wankoilz

url=InputBox("輸入完整下載地址:")
threadCount=InputBox("輸入線程數(shù)(不超過(guò)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)建一個(gè)和下載文件同樣大小的臨時(shí)文件,供下面ado分段重寫(xiě)
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對(duì)象的數(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
'每當(dāng)一個(gè)線程下載完畢就將其寫(xiě)入臨時(shí)文件的相應(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秒超時(shí)!"
WScript.Quit
End If
Loop
If fso.FileExists(filePathfileName) Then fso.DeleteFile(filePathfileName)
fso.DeleteFile(filePath"TmpFile")
ado.SaveToFile(filePathfileName)
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=GetFilePatharrTmp(i)"\"
Next
End Function


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

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


VBS實(shí)現(xiàn) 多線程 補(bǔ)充

今天有人發(fā)郵件問(wèn)我一個(gè)問(wèn)題:

想請(qǐng)教一下VBS中INPUTBOX函數(shù)能否超時(shí)關(guān)閉?
如果可以的話,應(yīng)該如何超時(shí)關(guān)閉輸入框? 萬(wàn)分感謝

乍一看這是不可能實(shí)現(xiàn)的,因?yàn)镮nputBox函數(shù)本身沒(méi)有超時(shí)關(guān)閉的參數(shù),而且程序會(huì)一直等待InputBox返回才繼續(xù)運(yùn)行,后面的語(yǔ)句不可能在InputBox返回之前執(zhí)行。

如果VBS能實(shí)現(xiàn)高級(jí)語(yǔ)言的多線程的話……只可惜VBS不可能實(shí)現(xiàn)多線程,但是可以用setTimeout方法模擬“多線程”。

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

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


用setTimeout方法設(shè)定3秒超時(shí),3秒后用SendKeys方法發(fā)送ESC鍵結(jié)束InputBox。當(dāng)然,用SendKeys是很不靠譜的,我一般很少用SendKeys方法,因?yàn)樗隽颂嗟募僭O(shè),萬(wàn)一InputBox不是激活窗口呢?這里只是為了程序簡(jiǎn)單而用了SendKeys,可以換成結(jié)束腳本本身。

同理,想在VBS中實(shí)現(xiàn)VB中的Timer事件的話可以用setInterval方法,我就不寫(xiě)例子了,自己看文檔。

參考鏈接:setTimeout Method (window, Window Constructor)
您可能感興趣的文章:
  • VBS讀取注冊(cè)表的兩種方法
  • VB實(shí)現(xiàn)的倒計(jì)時(shí)類(lèi)代碼詳解
  • VB調(diào)用Word拼寫(xiě)檢查功能實(shí)例
  • VB6中的LSet語(yǔ)句和RSet語(yǔ)句詳解
  • VB實(shí)現(xiàn)的16位和32位md5加密代碼分享
  • 通過(guò)VB6將ASP編譯封裝成DLL組件最簡(jiǎn)教程 附全部工程源文件
  • VB6反編譯軟件VB RezQV2.4a 正式版注冊(cè)碼
  • VB讀取線程、句柄及寫(xiě)入內(nèi)存的API代碼實(shí)例

標(biāo)簽:咸陽(yáng) 牡丹江 梅州 河南 四平 阜陽(yáng) 伊春 武威

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《vbs 多線程下載實(shí)現(xiàn)代碼》,本文關(guān)鍵詞  vbs,多,線程,下載,實(shí)現(xiàn),代碼,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《vbs 多線程下載實(shí)現(xiàn)代碼》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于vbs 多線程下載實(shí)現(xiàn)代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    南宫市| 紫云| 长垣县| 玉屏| 青海省| 正镶白旗| 清徐县| 锡林浩特市| 东乌珠穆沁旗| 南开区| 易门县| 大安市| 中牟县| 迭部县| 铁岭市| 开远市| 邯郸县| 巨野县| 嵩明县| 铜川市| 廊坊市| 上杭县| 满洲里市| 张掖市| 育儿| 甘泉县| 习水县| 临洮县| 常宁市| 蒙山县| 益阳市| 当涂县| 石楼县| 琼海市| 宜宾县| 红安县| 明溪县| 当阳市| 宜昌市| 淮阳县| 陆河县|