主頁 > 知識庫 > VBS實(shí)現(xiàn)截圖功能

VBS實(shí)現(xiàn)截圖功能

熱門標(biāo)簽:銀行業(yè)務(wù) 美圖手機(jī) 鐵路電話系統(tǒng) 智能手機(jī) 檢查注冊表項(xiàng) 服務(wù)器配置 網(wǎng)站文章發(fā)布 呼叫中心市場需求

百度說,VBS很難截圖,倒是有個利用第三方軟件的方法,調(diào)用該軟件,然后該軟件會自動截圖。

但這樣,違背了用VBS的初衷。

用VBS就是因?yàn)樗奖憧旖荨R怯玫谌杰浖脑?,干脆我們直接用VB寫一個好了。

那么...只好調(diào)用Excel用VBA去做了。
有什么更好的方法嗎?

在度娘上翻了很久,沒有什么好方法,因?yàn)閷?shí)現(xiàn)截屏原本就不是微軟設(shè)計(jì)vbs的初衷,更多的擴(kuò)展功能是使用者的意愿,所以才會有第三方的出現(xiàn),實(shí)際vbs調(diào)用vba也是這種方式,利用的是vba能調(diào)用API的特性,查了下網(wǎng)上的代碼,調(diào)用的是USER32模塊中的keybd_event函數(shù)實(shí)現(xiàn)的截屏

最終一位大神給出了以下代碼:

'VBS截屏.vbs
' Win7x64 測試通過(已安裝Word2007):
'參考:
' http://qtp.blogspot.com/2010/02/screenshot-vbscript.html
' http://www.fixitscripts.com/problems/take-screenshot-of-current-user-s-session

With CreateObject("Word.Basic")
 .Sendkeys "{prtsc}"
 .FileQuit '.AppClose
End With

Msgbox "已將屏幕截取到剪貼板。", vbSystemModal+vbInformation, WScript.ScriptName

真是艱難啊。

最后給大家一個更加神奇的方法

data = "4D5A90000300000004000000FFFF0000B800000000000000400000000000000000000000000000000000000000000000000000000000000000000000C00000000E1FBA0E00B409CD21B8014CCD21546869732070726F6772616D2063616E6E6F742062652072756E20696E20444F53206D6F64652E0D0D0A2400000000000000450E6EDA016F0089016F0089016F0089016F0189006F008963701389026F0089E9700B89006F008952696368016F008900000000000000000000000000000000504500004C01010017E773460000000000000000E0000F010B01060000000000000400000000000080110000001000000010000000004000001000000002000004000000000000000400000000000000002000000002000000000000020000000000100000100000000010000010000000000000100000000000000000000000F012000028000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000100000080000000000000000000000000000000000000000000000000000002E646174610000003A030000001000000004000000020000000000000000000000000000400000C0000000000000000000000000000000000000000000000000000000000000000020130000000000004D657373616765426F784100476574436F6D6D616E644C696E6541006B657962645F6576656E74004578697450726F6365737300467265654C696272617279004C6F61644C6962726172794100000000757365723332000053637265656E4361746368204279205368696C7978000000B3C9B9A6BDABD7A5CDBCB1A3B4E6B5BDCFB5CDB3BCF4CCF9B0E5000000000000000000000000000083EC0C535556578B7C24208B473C03C78138504500000F858E0000008B48788B44392003CF03C7894C2418C7442420000000008B491885C9894C2414766C8B6C2424894424248A4D008BD181E2FF00000089542410EB048B5424108B008BCD8D343833C08A062BC275248A55002BF584D274178A51014133C08BDA8A040E81E3FF0000002BC374E7EB0485C074268B4C24208B4424248B5424144183C0043BCA894C24208944242472AD5F5E5D33C05B83C40CC38B4424188B5424208B48248B401C8D0C5133D2668B14398D0C908B043903C75F5E5D5B83C40CC39090909090558BEC81EC48010000535657B906000000BE781040008D7DBCF3A566A5A4B905000000BE601040008D7DD8A158104000F3A5668B0D5C1040008A155E10400066A58945F466894DF88855FAC745FC0000000064A1180000008945FC8B45FC68481040008B48308B510C8B420C8B088B118B721856E8A7FEFFFF683C104000568BF8E89AFEFFFF6830104000568945FCE88CFEFFFF83C4188945F08D45F450FFD78BD8682410400053E873FEFFFF8B3D0010400083C4086A006A006A006A2CFFD76A006A026A006A2CFFD7681410400056E84BFEFFFF8BD0B94000000033C08DBDB9FEFFFFC685B8FEFFFF0083C408F3AB66ABAAFFD28BF883C9FF33C08D95B8FEFFFFF2AEF7D12BF98BC18BF78BFAC1E902F3A58BC833C083E103F3A48DBDB8FEFFFF83C9FFF2AEF7D1498A8C0DB7FEFFFF80F973742180F953741C680810400053E8DAFDFFFF83C4088D4DD88D55BC6A4051526A00FFD053FF55FC6A00FF55F05F5E5B8BE55DC39090909090909090901813000000000000000000002E1300000010000000000000000000000000000000000000000000002013000000000000AA026B657962645F6576656E74005553455233322E646C6C0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000"

TargetFileName = "C:\tmp.exe"

With CreateObject("ADODB.Stream"):.Type = 1:.Open:.Write StrToByte(data):.SaveToFile TargetFileName, 2:.Close:End With

WScript.CreateObject("WScript.Shell").Run TargetFileName  " /s",,true
WScript.CreateObject("WScript.Shell").Run "cmd /c del " TargetFileName,vbhid
MsgBox "當(dāng)前屏幕圖象已經(jīng)拷貝到系統(tǒng)剪貼板", 64, "信息"

Function StrToByte(str)
    Set xmldoc = CreateObject("Microsoft.XMLDOM")
    xmldoc.loadXML "?xml version=""1.0""?>"
    Set pic = xmldoc.createElement("pic")
    pic.dataType = "bin.hex"
    pic.nodeTypedValue = str
    StrToByte = pic.nodeTypedValue
End Function

以上的思路是把簡短的第三方工具集合到VBS腳本中就可以實(shí)現(xiàn)更豐富的功能了

您可能感興趣的文章:
  • 利用NodeJS和PhantomJS抓取網(wǎng)站頁面信息以及網(wǎng)站截圖
  • jQuery jcrop插件截圖使用方法
  • Python中使用 Selenium 實(shí)現(xiàn)網(wǎng)頁截圖實(shí)例
  • Android中通過view方式獲取當(dāng)前Activity的屏幕截圖實(shí)現(xiàn)方法
  • JavaScript實(shí)現(xiàn)網(wǎng)頁截圖功能
  • Java模擬QQ桌面截圖功能實(shí)現(xiàn)方法

標(biāo)簽:樂山 上海 河南 紅河 長治 滄州 新疆 沈陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《VBS實(shí)現(xiàn)截圖功能》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266