среда, 3 августа 2011 г.

Word Поиск и замена в нескольких файлах (VBA)

Данный код поможет заменить определенную строку в нескольких файлах Word одновременно.
Например это может пригодится, если необходимо заменить номер счета или телефона в корпоративных бланках и т.д.


Инструмент сделан на основе документа Word, с помощью кода VBA. Внешне документ выглядит так:

Два поля, с привязанными Bookmark-ами (SearchFor и ReplaceWith) позволяют обратиться к ним из кода:

    searchFor = ThisDocument.Bookmarks("SearchFor").Range.Text
    replaceWith = ThisDocument.Bookmarks("ReplaceWith").Range.Text

Кнопка вызывает стандартный диалог выбора файлов. Для обработки файлов создается отдельный объект Word, который на всякий случай делается видимым:

    Set wordApp = New Application
    wordApp.Visible = True

Выключаются предупреждения:

    Application.DisplayAlerts = wdAlertsNone
    wordApp.DisplayAlerts = wdAlertsNone

Все файлы последовательно открываются, обрабатываются в цикле и закрываются с сохранением.

    For Each FileName In picker.items
        Set wordDocument = wordApp.Documents.Open(FileName)
        With wordDocument.Content.Find
            .Text = searchFor
            .Replacement.Text = replaceWith
            .Forward = True
            .MatchCase = False
            .Execute Replace:=wdReplaceAll
        End With
        wordDocument.Close SaveChanges:=True
    Next




понедельник, 1 августа 2011 г.

Внедрение скрипта VBScript в EXE-файл (C#)

Создаем пустой консольный проект в C#.

Затем добавляем файл скрипта в ресурсы проэкта
В VS2010 это можно сделать через:
RMB на имени проекта->Properties->Resources->Add Resource->Add New Text File

Теперь можно получить содержимое скрипта, сохранить и запустить его.
Исходный код достаточно прост.


Чтобы получить содержимое скрипта, я использую:

Properties.Resources.MyEmbeddedScript
где MyMbeddedScript - имя ресурса со скриптом.

Получить случайное, временное имя файла для сохранения скрипта:
string scriptFileName = Path.GetTempFileName().Replace(".tmp",".vbs");

Сохранение и запуск скрипта:
File.WriteAllText(scriptFileName, content);
startedProcess = Process.Start(scriptFileName);

Чтобы запустить скрипт под другим пользователем, можно использовать следующий метод:
RunAs без ввода пароля

Аналогичным способом можно превратить любой скрипт (.vbs, .js, .ahk и т.д) в исполняемый .exe-файл.

Исходный код программы:
using System;
using System.Security;
using System.Diagnostics;
using System.IO;

namespace scriptEmbed
{
    class Program
    {
        static int Main(string[] args)
        {
            return RunScript(Properties.Resources.MyEmbeddedScript);
        }
        static int RunScript(string content)
        {
            string scriptFileName = Path.GetTempFileName().Replace(".tmp",".vbs");
            Process startedProcess;
            try
            {
                File.WriteAllText(scriptFileName, content);
                startedProcess = Process.Start(scriptFileName);
                
                while (!startedProcess.HasExited) ;

                File.Delete(scriptFileName);
                
                return startedProcess.ExitCode;
            }
            catch (Exception e)
            {
                Console.WriteLine(e.Message);
                return 1;
            }
        }
        static string GetTempFolder()
        {
            return System.Environment.GetEnvironmentVariable("TEMP");
        }
    }

}