Пакетные изменения шаблона (Microsoft Word)
Шаблоны используются для быстрого определения стандартного вида документа или группы документов. В шаблонах замечательно то, что вы можете определить один шаблон, чтобы придать документу один вид, и другой шаблон, чтобы придать ему совершенно другой вид. Все, что вам нужно сделать, это, конечно, изменить шаблон, связанный с документом.
Изменить шаблон, связанный с одним или двумя документами, довольно просто. Что делать, если у вас есть каталог, полный документов, шаблоны которых нужно изменить? Это очень быстро может стать довольно утомительным. Здесь на помощь может прийти макрос — избавить от старой скуки и очень быстро выполнить повседневную работу. Следующий макрос, ChangeTemplates, изменяет все документы в определенном каталоге, чтобы убедиться, что они используют нужный шаблон.
Sub ChangeTemplates() Dim strDocPath As String Dim strTemplateB As String Dim strCurDoc As String Dim docCurDoc As Document ' set document folder path and template strings strDocPath = "C:\path to document folder\" strTemplateB = "C:\path to template\templateB.dot" ' get first doc - only time need to provide file spec strCurDoc = Dir(strDocPath & "*.doc") ' ready to loop (for as long as file found) Do While strCurDoc <> "" ' open file Set docCurDoc = Documents.Open(FileName:=strDocPath & strCurDoc) ' change the template docCurDoc.AttachedTemplate = strTemplateB ' save and close docCurDoc.Close wdSaveChanges ' get next file name strCurDoc = Dir Loop MsgBox "Finished" End Sub
Чтобы использовать макрос, просто убедитесь, что переменные strDocPath и strTemplateB установлены правильно. Макрос изменяет ассоциации шаблона для всех документов в определенном каталоге. Если вы хотите чего-то более разборчивого, тогда вам подойдет другой макрос. Например, вы можете захотеть, чтобы макрос проверял каждый документ и изменял только те, которые используют TemplateA, чтобы они теперь использовали TemplateB. В этом случае вам очень пригодится следующий макрос:
Sub TemplateBatchChange() Dim objPropertyReader Dim strFolder As String Dim strFileName As String Dim objThisDoc As Word.Document Dim strFindTemplate As String Dim strReplaceTemplate As String Dim strAffectedDocs As String On Error Resume Next 'Create the PropertyReader object Set objPropertyReader = CreateObject("DSOleFile.PropertyReader") If Err.Number <> 0 Then MsgBox "You must install the DSOleFile component. See " & _ "http://support.microsoft.com/kb/224351" GoTo FinishUp End If 'Get the template names strFindTemplate = UCase(InputBox("Name of template to find (exclude the .dot)") & _ ".dot") strReplaceTemplate = InputBox("Name of replacement template (exclude the .dot)") & _ ".dot" 'Make sure it's a valid template. Try to create a new document based on it. Set objThisDoc = Word.Documents.Add(strReplaceTemplate, Visible:=False) If Err.Number <> 0 Then 'No such template MsgBox "There is no accessible template named " & strReplaceTemplate GoTo FinishUp End If 'Close the test document objThisDoc.Close wdDoNotSaveChanges On Error GoTo ErrorHandler 'Get the current documents path strFolder = Word.Application.Options.DefaultFilePath(wdDocumentsPath) _ & Word.Application.PathSeparator 'Examine all Word documents in the directory 'Get the first document name strFileName = Dir(strFolder & "*.doc") While strFileName <> "" 'Look at the template name If UCase(objPropertyReader.GetDocumentProperties _ (strFolder & strFileName).Template) = strFindTemplate Then 'It matches. Open the document Set objThisDoc = Word.Documents.Open _ (FileName:=strFileName, Visible:=False) 'Change the attached template objThisDoc.AttachedTemplate = strReplaceTemplate 'Save the change objThisDoc.Close wdSaveChanges 'Note the document strAffectedDocs = strAffectedDocs & strFileName & ", " End If 'Get the next document strFileName = Dir Wend 'Report the results If strAffectedDocs = "" Then MsgBox "No documents were changed.", , "Template Batch Change" Else 'Remove the trailing comma and space strAffectedDocs = Left(strAffectedDocs, Len(strAffectedDocs) - 2) MsgBox "These documents were changed: " & _ strAffectedDocs, , "Template Batch Change" End If GoTo FinishUp ErrorHandler: Set objThisDoc = Nothing Set objPropertyReader = Nothing Err.Raise vbError + 1001, "TemplateBatchChange", _ "TemplateBatchChange encountered an error: " & Err.Description FinishUp: 'Release object references Set objThisDoc = Nothing Set objPropertyReader = Nothing End Sub
Чтобы использовать этот макрос, вы должны сначала убедиться, что компонент DSOLEFILE (доступен бесплатно от Microsoft) установлен в вашей системе.
Вы можете узнать больше об этом компоненте, обратившись к статье базы знаний Microsoft 224351. Макрос дает вам возможность указать имя шаблона, который нужно заменить, и имя шаблона, которым его нужно заменить. Он даже проверяет, существует ли заменяющий шаблон.
Этот макрос ищет документы в папке документов Word по умолчанию.
Если вы хотите искать в другом месте напрямую, вы должны убедиться, что для переменной strFolder задан полный путь к папке, которую вы хотите использовать.
_Примечание: _
Если вы хотите знать, как использовать макросы, описанные на этой странице (или на любой другой странице на сайтах WordTips), я подготовил специальную страницу, содержащую полезную информацию.
link: / wordribbon-WordTipsMacros [Щелкните здесь, чтобы открыть эту специальную страницу в новой вкладке браузера]
.
WordTips — ваш источник экономичного обучения работе с Microsoft Word.
(Microsoft Word — самая популярная программа для обработки текстов в мире.) Этот совет (1437) применим к Microsoft Word 97, 2000, 2002 и 2003. Вы можете найти версию этого совета для ленточного интерфейса Word (Word 2007 и позже) здесь:
link: / wordribbon-Batch_Template_Changes [Пакетные изменения шаблона]
.