跳到主要內容

發表文章

目前顯示的是有「Word」標籤的文章

讓IE會提示使用者可以開啟/儲存Word檔

很奇怪,在Word 2000以後,IE預設都會提示使用者要開啟或儲存word檔。這個資訊相當難找,其實微軟有出 Office 文件開啟確認工具 ,但是在網域內設定當然得靠修改機碼才方便。 最後終於找到 這 ,在HKEY_CLASSES_ROOT\Word.Document.8的EditFlags設成REG_BINARY的4個byte的0即可。( 這 份文件似乎有點錯誤,上面寫dword,但鳥毅手上的電腦內機碼都是binary,懶得去試設成dword效果是否相同了) 以下存成confirmdoc.reg匯入即可: Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\Word.Document.8] "EditFlags"=hex:00,00,00,00

用VBA刪除Word裏的巨集(Macro、宏)

VBA是Visual Basic for Applications,和Visual Basic 6並不是同個東西。 在下敝人小弟我遇到某些Word檔裏有AutoClose的巨集,而且內容不正確,可能是刪除病毒留下來的?OfficeScan並不把它視為病毒,但ClamAV、Nod32等均視為病毒直接刪除整個檔案,造成user困擾,而且AutoClose巨集會造成自動感染Normal.dot(Word 97)。 本來想用Apache POI 處理,但沒找到VBE相關的東西,只好以夷制夷,呼叫Word自己來刪Macro。由於我並沒有裝VSTO套件,所以也沒有試用.net存取Word的方式,直接用長得很像的VB6。在下手上沒有VBA的書,照著網路上的範例在Word的VB編輯器可以,但試半天用VB6呼叫都沒有成功。隔天敝公司的VB超人出差回來,他告訴我兩個key point: Word必須信任存取 Visual Basic 專案 要引用Microsoft Visual Basic for Application Extensibility 我只注意到要引用Word Object Library,忽略了VBE引擎,所以才會一直無法使用VBE。 請在VB6專案引用Microsoft Word 11.0 Object Library (這是Word 2003,從8.0~12.0應該都可以,看Client的Word,所以這個程式還和Word綁在一起)及Microsoft Visual Basic for Application Extensibility 5.3 (同樣和Word綑綁,Word 97的VBE無版號),我再加上了Microsoft Scripting Runtime以提供FileSystemObject。 開檔的部份就不寫了,以下是刪除巨集的subroutine: Public Sub EraseWordMacro(wdApp As Word.Application) Dim wdDoc As Word.Document Set wdDoc = wdApp.ActiveDocument Dim j As Integer Dim i As Integer Dim nLines As Integer Dim oVBComp As VBID...