话说还是闲来练手,初步实现了自己认为的“多线程”下载。(至于是不是多线程,可以参考12楼链接)
为避免冗余,省了一些错误检查。我觉得没多大实际用途,有兴趣的兄弟一起学习讨论呗。欢迎大家指正:
复制代码 代码如下:
'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://www./images/logo.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
'By Demon
'http://demon.tw
Sub on_timeout()
Dim WshShell
set WshShell = CreateObject("wscript.Shell")
WshShell.SendKeys "{ESC}"
End Sub
用setTimeout方法设定3秒超时,3秒后用SendKeys方法发送ESC键结束InputBox。当然,用SendKeys是很不靠谱的,我一般很少用SendKeys方法,因为它做了太多的假设,万一InputBox不是激活窗口呢?这里只是为了程序简单而用了SendKeys,可以换成结束脚本本身。
同理,想在VBS中实现VB中的Timer事件的话可以用setInterval方法,我就不写例子了,自己看文档。
参考链接:setTimeout Method (window, Window Constructor)
相关推荐:
SEO抢权:如何在竞争激烈的市场中占得先机,正规网站建设口碑好
优方法-高效生活与工作的秘密武器,钻石营销推广方案
SEO全套秘籍:提升网站流量与排名的终极指南,荣昌手机网站建设
SEO快速优化文章排名:提升网站流量的必备技巧,ai小苹果会员分享
seo适合什么职业,seo有前途么 ,ai小精灵
内容创作新时代:自动生成文章的AI如何改变写作生态
seo线索收集是什么,seo线索收集是什么意思 ,ai生活ai童童
什么是神马排名?让你的网站脱颖而出,轻松占据搜索引擎的C位!,乳山网站优化关键词排名
为什么说seo这么重要,seo重要吗 ,ai19920403
seo词库优化,搜索词条优化 ,ai点选择
SEO就业前景如何?打造数字时代的职业新风口,常州武进区水产网站建设
seo相当于什么职业,seo相当于什么职业类别 ,usatisfy ai
SEO薪资这些,你也能月入过万!,天水网站建设公司
SEO调整,助力网站流量爆发式增长!,江都seo优化排名
seo高手有什么条件,seo难上手吗 ,指南ai写作电力创新
“扩写AI”-引领写作革命,开启智能创作新时代,dede seo 标题如何填写
怎么用AI写出高质量科普文章?揭秘新时代创作利器!
软件AI:颠覆未来的智能革命
SEO大量优化:如何通过精准策略提升网站流量,突破搜索引擎排名瓶颈,吕梁本地网站推广平台
AI文章概括缩写:让内容高效获取的智能工具,ai 处理文件
SEO量:提升网站流量和排名的关键法则,德兴seo
主流seo是什么,seo是什么推广网站 ,AI心理师
什么是SEO可以自学吗,seo零基础可以自学吗 ,ai1紫
seo资源指的是什么,seo资料 ,绿眼AI
seo要学会什么,seo要学多长时间 ,NTU AI 录取
GoogleGPT-引领未来智能对话的革命,灵境ai画质
WPJVX:开启数字化未来的智慧平台,关键词排名技术咨询乐云seo
ChatGPT不能用了?了解这一背后的真相及解决方法,ai恐怖头像
SEO职责:为网站注入流量,提升品牌竞争力,拼多多女装关键词排名
WPQQ-开启数字时代的智能连接新纪元,杭州网站推广厂家电话
AI撰写大数据解决方案:开启智能数据时代的新篇章,ai头号公敌
为什么要做seo si,为什么要做* ,ai里面怎么扣二维码
SEO表述:如何通过精准优化让你的内容脱颖而出,江阴网站建设怎么样啊
在线AI生成文章:智能写作的未来趋势
ChatGLM不能搜索网页内容,你真的了解它的局限性吗?,ai修复情侣
SEO外链建设:提升网站排名的关键策略,ai偏执
seo组建需要什么条件,seo建站的步骤 ,ai肌肉宝宝
SEO模块:提升网站排名,驾驭数字营销未来,营口网站建设制作平台
SEO文案:如何通过巧妙布局提升网站排名,吸引更多流量,娄底网站建设工作文案
未来写作新方式原创AI文章的无限可能
SEO师:如何在数字时代为企业赢得流量与销量,十堰网站关键词优化教程
AI写作免费一键生成下载,助您轻松创作!
360关键:打造全方位安全保护,守护您的数字世界,ai乘bi
SEO优化:如何让网站更具有吸引力,散文ai写作咒语是什么
AI一键生成原创文章,让创作更高效更轻松!
ChatGPT桌面应用安装了,不能用?解决方案全攻略,让你轻松畅享AI助手!,绫波丽ai智能
ChatGPT无法加载?检查您的网络设置并尝试重启,轻松解决常见问题!,ai招生广告设计
SEO才能:提升网站排名,突破网络营销的核心竞争力,南宁本地seo营销公司
SEO选择:如何挑选最合适的SEO优化策略?,wb免费刷粉网站推广
ChatGPT安装包Windows版-让智能助手触手可得,q和ai