Word vba выделить текст в таблице

Автор blacktesta, 04 ноября 2019, 20:19

С помощью мыши можно выделить ячейку, а можно выделить текст в ячейке полностью. Это будут два разных выделения.

Саму ячейку можно выделить таким кодом (выделяется первая ячейка в первой таблице):
ActiveDocument.Tables(1).Cell(1, 1).Select

А как выделить весь текст в ячейке при помощи VBA?



Администратор

  • Administrator
  • Сообщения: 2,253
  • Записан

Выделение текста ячейки:

Макрос

Sub Макрос1()

        Dim tbl As Table

            ‘ Присваиваем первой таблице имя «tbl», чтобы было удобно читать и писать код.
    Set tbl = ActiveDocument.Tables(1)
    ‘ Выделение первой ячейки в таблице.
    tbl.Cell(1, 1).Select
    ‘ Убираем с конца символ-кружок.
    Selection.MoveEnd Unit:=wdCharacter, Count:=-1

        ‘ Здесь у нас выделен весь текст ячейки.
        ‘ Например, можно посмотреть текст ячейки.
        ‘ Если ячейка пустая, то вернётся символ-кружок, а не пустая строка.
        ‘ Вывод текста в View — Immediate Window.
    Debug.Print Selection.Text

    End Sub

[свернуть]

Не всегда есть необходимость выделять (использование Selection), а достаточно использовать Range:

Макрос

Sub Макрос2()

       Dim tbl As Table, rng As Range

          ‘ Присваиваем первой таблице имя «tbl», чтобы было удобно читать и писать код.
    Set tbl = ActiveDocument.Tables(1)
    ‘ Присваиваем имя «rng» содержимому ячейки.
    Set rng = tbl.Cell(1, 1).Range.Duplicate
    ‘ Убираем с конца символ-кружок.
    rng.MoveEnd Unit:=wdCharacter, Count:=-1

        ‘ Здесь «rng» — это весь текст ячейки.
        ‘ Например, можно посмотреть текст ячейки.
        ‘ Если ячейка пустая, то вернётся пустая строка.
        ‘ Вывод текста в View — Immediate Window.
    Debug.Print rng.Text

    End Sub

[свернуть]


Огромное спасибо!!! Все работает. По видимому загвоздка была в этом символе-кружке.


  • Форум по VBA, Excel и Word

  • Word

  • Макросы в Word

  • Word VBA Макросы: Как обратиться/выделить текст в ячейке в таблице в ворде?

Всем привет, с вами автор блога scriptcoding.ru. В этой статье мы рассмотрим методы объекта Word Selection, которые позволяют очистить материал от форматирования, преобразовать в таблицу, а также производить копирование, вставку и так далее. Помним, что данный класс отвечает за выделение текста в Word.

Содержание

  1. Методы класса Word.Selection – выделение текста в Word
  2. Примера на языке VBScript – выделение текста в редакторе Word
  3. Примера на языке JScript – выделение текста в редакторе Word

Методы класса Word.Selection – выделение текста в Word

Я приведу по два примера программного кода на языках JScript, VBScript и VBA. Хотя по сути, код под макрос (VBA) и сценарий VBScript особо не отличается. Для тех, кто забыл: для создания макроса в документе Microsoft Office нужно вызвать редактор Visual Basic for Application (комбинация клавиш Alt + F11), далее, добавить в проект новый модуль (макрос).

Методы с префиксом Clear… позволяют очистить выделенный материал от форматирования (абзацы, стили, символы и так далее):

ClearCharacterAllFormatting() — Все форматирование.

ClearCharacterDirectFormatting() — Форматирование знаков.

ClearCharacterStyle() — Форматирование знаков, применяемых через стили.

ClearFormatting() – Все форматирования (параграфы, стили и так далее).

ClearParagraphAllFormatting() — Форматирование абзаца.

ClearParagraphDirectFormatting() — Форматирование абзацев, применяемых вручную.

ClearParagraphStyle() — Форматирование абзацев, применяемых через стили.

Collapse(Direction) – Позволяет убрать выделение текста Word и переместить указатель в начало или конец. VBA Selection. Если параметры отсутствуют, то просто убирается выделение. Параметр Direction содержит значение константы WdCollapseDirection:

  • wdCollapseEnd — 0 – Указатель вконец
  • wdCollapseStart — 1 – Указатель вначале

ConvertToTable(Separator, NumRows, NumColumns, InitialColumnWidth, Format, ApplyBorders, ApplyShading, ApplyFont, ApplyColor, ApplyHeadingRows, ApplyLastRow, ApplyFirstColumn, ApplyLastColumn, AutoFit, AutoFitBehavior, DefaultTableBehavior) – Довольно мощный метод, который позволяет преобразовать выделенный Word текст в таблицу.

Separator — Символ-разделитель, может быть знаком или значением константы WdTableFieldSeparator:

  • wdSeparateByParagraphs — 0 — абзаца.
  • wdSeparateByTabs — 1 — табуляции.
  • wdSeparateByCommas — 2 — запятая.
  • wdSeparateByDefaultListSeparator — 3 — разделитель списка по умолчанию.

NumRows— Количество строк.

NumColumns— Количество столбиков.

InitialColumnWidth— Начальная ширина каждого столбца, в пунктах.

Format– Определяет формат таблицы и содержит значение константы WdTableFormat.

ApplyBorders— TRUE — применять границы.

ApplyShading— TRUE — применить затенение.

ApplyFont— TRUE применять свойства шрифтов.

ApplyColor— TRUE применять цветовые свойства.

ApplyHeadingRows— TRUE — применить свойства заголовок-строка.

ApplyLastRow— TRUE — применить свойства последней строке.

ApplyFirstColumn— TRUE — применить свойства первого столбцов.

ApplyLastColumn— TRUE — применить свойства последнего столбца.

AutoFit— TRUE — уменьшить ширину столбцов таблицы как можно больше.

AutoFitBehavior — Устанавливает правила авто-подбора (если DefaultTableBehavior содержит значение wdWord8TableBehavior, то этот аргумент игнорируется, VBA Selection), содержит значения константы WdAutoFitBehavior:

  • wdAutoFitContent — 1 — автоматически размер
  • wdAutoFitFixed — 0 — фиксированный размер
  • wdAutoFitWindow — 2 — автоматический размер по ширине активного окна

DefaultTableBehavior— Значение, указывающее, следует ли автоматически изменять размер ячеек таблицы по содержимому. Selection VBA. Содержит значение константы WdDefaultTableBehavior:

  • wdWord8TableBehavior — 0 — отключает Авто-подбор (по умолчанию)
  • wdWord9TableBehavior — 1 — включить Авто-подбор

Выделение блока текста в Word, VBA Selection

Хорошо, с теоретической частью мы закончили, теперь можно приступить к программированию.

Примера на языке VBScript – выделение текста в редакторе Word

' ----------------------------------------------------------------------------
' Объект Selection - выделение текста в Word
' Преобразование в таблицу - язык VBScript
' VBA_Selection_Table.vbs
' ----------------------------------------------------------------------------
Option Explicit
 
dim oWord, oDoc, oSel, i
 
Set oWord = CreateObject("Word.Application")
Set oDoc = oWord.Documents
oDoc.Add()
Set oSel = oWord.Selection
oWord.Visible = True
 
For i = 0 To 10
With oSel
.InsertBreak 6
.InsertBefore "один, два, три, четыре, пять, шесть, selection word vba"
.EndOf
.InsertBreak 6
End With
Next
 
oWord.Documents(1).Select()
oSel.ConvertToTable ",", 31,,,18

В данном примере в цикле For (смотрите статью «Урок 6 по VBScript: Циклы for…next и for each…next«), который выполняется шесть раз, происходит вставка перевода на новую строку, вставка текстовой фразы и перемещаем курсов к конец строки. С помощью оператора with мы можем экономить размер программного кода – не нужно лишний раз писать имя класса. Вконце происходит выделение текста Word и преобразование его в таблицу.

Примера на языке JScript – выделение текста в редакторе Word

// ----------------------------------------------------------------------------
// Объект Selection - выделение текста в Word
// Преобразование в таблицу - язык JScript
// VBA_Selection_Table.js
// ----------------------------------------------------------------------------
 
var oWord1, oDoc1, oSel1, i;
 
oWord1 = WScript.CreateObject("Word.Application");
oDoc1 = oWord1.Documents;
oDoc1.Add();
oSel1 = oWord1.Selection;
oWord1.Visible = true;
 
for (i=0; i<=10;i++){
with(oSel1){
InsertBreak(6);
InsertBefore("один, два, три, четыре, пять, шесть, selection word vba");
EndOf();
InsertBreak(6);
}
}
 
oWord1.Documents(1).Select();
oSel1.ConvertToTable(",", 31,"","",18);

Логика работы данного программного кода аналогичны предыдущему примеру, тут мы уже использовали цикл for языка JS, читайте в статье «Урок 9 по JScript — оператор цикла for«. Тут тоже использовался оператор with, обратите внимание, что имена переменных изменились, а в конце каждой строки кода прописана точка с запятой.

Примера на языке Visual Basic for Application – выделение текста в редакторе Word

'VBA
Dim oWord2 As Object, oDoc2 As Object, oSel2 As Object, i
 
Set oWord2 = CreateObject("Word.Application")
Set oDoc2 = oWord2.Documents
oDoc2.Add
Set oSel2 = oWord2.Selection
oWord2.Visible = True
 
For i = 0 To 10
With oSel2
.InsertBreak 6: .InsertBefore "один, два, три, четыре, пять, шесть, selection word vba"
.EndOf: .InsertBreak 6
End With
Next
 
oWord2.Documents(1).Select
oSel2.ConvertToTable Separator:=",", NumRows:=31, Format:=18

Хорошо, давайте продолжим рассматривать методы класса Selection.

выделение текста в редакторе Word, Selection VBA

EndOf() – Перемещает курсор в конец выделения.

StartOf() – Перемещает курсор в начало выделения.

SetRange(start, end) – Позволяет задать начальное и конечное значение для выделения текста Word.

TypeText() – Выполняет ту же функцию, что и свойство Text – ввод информации.

TypeParagraph() — Метод вставляет параграф.

Copy(), Cut(), Paste(), Delete() – Копирует, вырезает, вставляет и удаляет выделенный текст в Word.

CopyAsPicture() – Копирует выбранный материал как изображение.

И так, теперь рассмотрим программный код с данными методами.

' ----------------------------------------------------------------------------
' Класс Selection - выделение текста в Word
' Копирование и вставка - язык VBScript
' VBA_Selection_Copy_Paste.vbs
' ----------------------------------------------------------------------------
Option Explicit
 
dim oWord3, oDoc3, oSel3, i
 
Set oWord3 = CreateObject("Word.Application")
Set oDoc3 = oWord3.Documents
oDoc3.Add()
Set oSel3 = oWord3.Selection
oWord3.Visible = True
 
' Вводим информацию в документ сто раз
For i=0 to 100
  oSel3.TypeText "Пример ввода данных - selection word vba. "
Next
 
With oSel3
  ' Выделяем, копируем и вставляем
  .SetRange 100, 300
  .Copy
  .MoveDown
  .Paste
 
  ' Выбираем материал и копируем ее как изображение
  .SetRange 100, 300
  .CopyAsPicture
End With

По сути, данный программный код практически аналогичен предыдущим. Тут в цикле происходит вставка данных несколько раз, а далее следуют операции выделения текста в документе Word, его копирование и вставка.

// ----------------------------------------------------------------------------
// Класс Selection - выделение текста в Word
// Копирование и вставка - язык JScript
// VBA_Selection_Copy_Paste.js
// ----------------------------------------------------------------------------
 
var oWord5, oDoc5, oSel5, i;
 
oWord5 = WScript.CreateObject("Word.Application");
oDoc5 = oWord5.Documents;
oDoc5.Add();
oSel5 = oWord5.Selection;
oWord5.Visible = true;
 
// Вводим данные в документ сто раз
for(i=0; i<=100; i++){
  oSel5.TypeText("Пример ввода информации - selection word vba. ");
}
 
with(oSel5){
  // Выделяем, копируем и вставляем
  SetRange(100, 300);
  Copy();
  MoveDown();
  Paste();
 
  // Выделяем и копируем как изображение
  SetRange(100, 300);
  CopyAsPicture();
}

Ну и в заключение, привожу программный код для макроса:

' VBA
Dim oWord6 As Object, oDoc6 As Object, oSel6 As Object, i
 
Set oWord6 = CreateObject("Word.Application")
Set oDoc6 = oWord6.Documents
oDoc6.Add
Set oSel6 = oWord6.Selection
oWord6.Visible = True
 
For i = 0 To 100
  oSel6.TypeText "Пример ввода информации - selection word vba. "
Next
 
With oSel6
  .SetRange 100, 300: .Copy: .MoveDown: .Paste
  .SetRange 100, 300: .CopyAsPicture
End With

Хорошо, на этом можно закончить данную статью. Параллельно, информацию по работе с классом Selection можете рассмотреть еще две публикации, в которых я рассмотрел остальные методы и свойства класса Selection.

    msm.ru

    Нравится ресурс?

    Помоги проекту!

    Здесь обсуждаются вопросы по языку Visual Basic 1-6 (а так же по схожим языкам, как, например, PowerBASIC).
    Вопросы по Visual Basic .NET (это который входит в состав Visual Studio 2002/2003/2005/2008+, для тех, кто не в курсе) обсуждаются в разделе .NET.

    Обратите внимание:
    1. Прежде чем начать новую тему или отправить сообщение, убедитесь, что Вы не нарушаете правил форума!
    2. Обязательно воспользуйтесь поиском. Возможно, Ваш вопрос уже обсуждали. Полезные ссылки приведены ниже.
    3. Темы с просьбой выполнить какую-либо работу за автора в этом разделе не обсуждаются. Студенты, вам сюда: ПОМОЩЬ СТУДЕНТАМ!
    4. Используйте теги [ code=vba ] …текст программы… [ /code ] для выделения текста программы подсветкой.
    5. Помните, здесь телепатов нет. Формулируйте свой вопрос максимально грамотно и чётко: Как правильно задавать вопросы
    6. Запрещено отвечать в темы месячной (и более) давности, без веских на то причин.

    Полезные ссылки:
    user posted image FAQ Сайта user posted image FAQ Раздела user posted image Кладовка user posted image Наши Исходники user posted image API-Guide user posted image Поиск по Разделу user posted image MSDN Library Online user posted image Google


    Ваше мнение о модераторах: user posted image SCINER, user posted image B.V.

    >
    Выделение одновременно 2-х ячеек в макросе Word

    • Подписаться на тему
    • Сообщить другу
    • Скачать/распечатать тему



    Сообщ.
    #1

    ,
    27.09.03, 09:50

      Народ, помогите, пожалуйста, программисту на С++.
      Задача такая. Когда записывается макрос в Word, мышью я не могу выделить несколько ячеек таблицы. С помощью верхнего меню Таблица->Выделить и т.д. могу выделить только одну ячейку. А нужно более одной для дальнейшего объединения. В макросе я пишу конкретно:

      Sub Макрос2()

      ActiveDocument.Tables(1).Cell(1, 2).Select
      ActiveDocument.Tables(1).Cell(1, 3).Select

      End Sub

      Выделяется ячейка 3-тья по последней строки, а со второй выделение слетает. По поводу Or или And  в справке VBA ничего найти не могу. Как все-таки выделить? Помогите дилетанту  VBA. ???


      Lamerroot



      Сообщ.
      #2

      ,
      27.09.03, 15:49

        Попробуй так, врядли заработает, неуверен я. В любом случае надо ипользовать класс Range:
        ActiveDocument.Tables(1).Range.SetRange 1, 5
        ActiveDocument.Tables(1).Range.Select


        brovey



        Сообщ.
        #3

        ,
        28.09.03, 06:38

          rs = ActiveDocument.Tables(1).Cell(1, 2).Range.Start
          re = ActiveDocument.Tables(1).Cell(1, 3).Range.End
          ActiveDocument.Range(rs, re).Select


          Lamerroot



          Сообщ.
          #4

          ,
          28.09.03, 17:59

            Ну или так!


            laifik



            Сообщ.
            #5

            ,
            29.09.03, 07:12

              Спасибо огромное! Все получилось. :D


              Lamerroot



              Сообщ.
              #6

              ,
              29.09.03, 18:43

                ;D

                0 пользователей читают эту тему (0 гостей и 0 скрытых пользователей)

                0 пользователей:

                • Предыдущая тема
                • Visual Basic: Общие вопросы
                • Следующая тема

                Рейтинг@Mail.ru

                [ Script execution time: 0,0841 ]   [ 16 queries used ]   [ Generated: 15.04.23, 00:24 GMT ]  

                1. Объекты
                  Range и Selection.
                  Работа с текстом.
                2. Выделенный
                  текст.
                3. Текстовый
                  диапазон.
                4. Выделение
                  текста.
                5. Вырождение
                  диапазона.
                6. Форматирование
                  текста.
                7. Поиск
                  и замена
                8. Коллекция
                  Tables.

                1.Объекты Range и Selection.Работа с текстом.

                Работа с текстом осуществляется с помощью ряда объектов.
                Весь текст документа можно представить в виде пирамиды, основой которой
                являются символы, а вершиной – собственно документ. В иерархическом порядке
                объектов VBA документ Word можно представить как:

                Символы (Characters) ® Слова (Words) ®
                Предложения (Sentences) ® ®Абзацы
                (Paragraphs) ®Разделы
                (Sections) ®Документ
                (Document)

                Кроме этих объектов, явно указывающих на тот или иной
                элемент документа, в VBA имеется два объекта, которые позволяют работать с
                текстом как с целым, без явного структурного разделения: объект Rahge ассоциируется с любым фрагментом документа, а объект Selection – с любым выделенным фрагментом текста. Оба эти
                объекта похожи по своему действию, однако они различаются по своим
                функциональным возможностям.

                2.Выделенный текст.

                Объект Selection является одним из
                базовых объектов. Это глобальный объект и предварительного объявления для него
                не требуется. в целом этот
                объект любое выделение в документе, а в случае если выделение вырождено, т.е.
                ничего не выделено, то объект описывает текущее положение указателя.

                Эта особенность часто используется для получения ссылки на
                объект, описывающий текущий элемент документа.

                Пример: получить ссылку на объект типа Paragraphs,
                являющегося семейством всех выделенных или затронутых выделением абзацев.

                Dim e As Paragraphs

                Set e = Selection.Paragraphs

                MsgBox e.Count

                Свойством по умолчанию для объекта типа Selection
                является свойство Text, возвращающее выделенный
                текст.

                Selection.[.Text][=Text]

                Для замены текущего выделенного текста используется метод
                TypeText
                .

                Selection.TypeText(Text)

                Пример: вставляем в документ текст «ХХХ» и начинаем новый
                абзац.

                With
                Selection

                .TypeText Text:=«XXX»

                .TypeParagraph

                End With

                Для управления параметрами вставки текста можно использовать
                свойство ReplaceSelection.

                Selection.ReplaceSelection [=Boolean]

                Если true – текущее выделение
                замещается, если False – то вставлять перед
                выделением.

                3.Текстовый диапазон. Объект Range
                предназначен для выделения и обработки фрагментов текста. Этот объект является
                семейством многих объектов.

                Например для выделения
                абзаца, в котором сейчас находится указатель достаточно использовать код

                Selection.Paragraphs(1).Range.Select

                 Область текста,
                связанная с объектом типа Range, характеризуется
                начальными и конечными символами. Для получения информации о них нужно
                использовать свойства Start и End.

                objrange.Start [=Position]

                objrange.End [=Position]

                параметр Position (типа Long) позволяет задать индекс символа, с которого должен
                начаться или которым должен закончится фрагмент
                текста, связанного с данным объектом objRange.

                Для получения ссылки на текстовый диапазон можно
                использовать метод Range.

                ObjDocumet.Range(Start, End)

                Параметр Start указывает на индекс
                символа, с которого должен начаться диапазон, а параметр End
                – на индекс последнего символа. Индексы символов соответствуют их порядковым
                номерам в семействе Words, ссылку на которое
                возвращает свойство Words объекта Document.

                4. Выделение текста.

                Формально объект Range связан
                только с диапазоном текста. Этот диапазон может быть никак не связан с текущим
                положением курсора или выделением. Однако диапазон, связанный с объектом Range, можно выделить в любой момент времени с помощью метода
                Select.

                ObjRange.Select

                Пример: выделить второй абзац текущего документа.

                ThisDocument.Paragraphs(2).Range.Select

                5.Вырождение диапазона.

                Для создания вырожденного диапазона можно использовать метод
                Collapse
                .

                objRange.Collapse [(Direction)]

                 Параметр Direction позволяет задать направление, в котором будет
                выполнено вырождение. Если параметр имеет значение wdCollapseStart,
                то вырождение выполняется в направлении начала диапазона, т.е. End:=Start. Если параметр имеет значение wdCollapseEnd, то Start:=End

                Пример: снятия выделения в документе, курсор помещен в конец
                выделеного диапазона.

                Selection.Collapse wdCollapseEnd

                6.Форматирование текста.

                Объект Range чаще используется как
                инструмент для форматирования выделенного текстового диапазона. Для этого, кроме
                свойства объекта Font  объект Range имеет
                целый ряд свойств, позволяющих настроить параметры шрифта данного диапазона.

                Свойство Bold – позволяет установить параметры
                жирного начертания символов.

                Если свойство имеет значение True, то начертание жирное , если False
                нежирное. Свойство также может возвращать значение wdUnderfined,
                указывающее на смешанное начертание. Для установления стиля начертания можно
                использовать следующие значения True,
                False или wdToggle,
                позволяющие переключить текущее написание шрифта.

                objRange.Bold
                [=Boolean]

                Свойство  CombineCharacters

                Свойство позволяет сжать все символы выделенного диапазона.  Если свойство имеет значение true, то выполняется сжатие.

                Свойство FilTextWidth

                Свойство позволяет указать ширину(в
                текущих единицах измерения, в которых должен быть размещен данный диапазон).
                Размер шрифта и ширину межсимвольного пространства Word подбирает автоматически

                В приведенном ниже примере показан код, позволяющий уместить
                текущее выделение на отрезке документа , ширина
                которого эквивалентна пяти сантиметрам.

                Selection.Range.FilTextWidth=CentimetersToPoints(5)

                Свойство objRange.FormattedText

                Свойство возвращает ссылку на объект типа Range ,
                который ассоциируется с текстом в пределах данного диапазона objRange,
                имеющего специфическое форматирование.

                 Cвойство
                Italic
                позволяет установить параметры курсивного начертания символов.

                Свойство ListFormat
                возвращает ссылку на объект типа Listformat, содержащего
                нумерованные или маркированные списки, используемые в данном диапазоне.

                Свойство ListParagraph

                Свойство возвращает ссылку на объект типа ListParagraph,
                содержащего нумерованные абзацы, имеющиеся в данном диапазоне.

                Свойство Shadingвозвращает ссылку на объект типа Shading, позволяющего указать цвет и
                формат заливки для данного диапазона.

                Свойство Revisions

                Свойство возвращает ссылку на объект типа Revisions , который
                связан с исправлениями , находящимися  в данном диапазоне.

                Свойство Showall[=Boolean]

                Свойство позволяет указать на отображение непечатаемых
                символов: табуляций, пробелов, символов абзаца, скрытого текста. True -символы
                отображаются.

                Свойство Style[=Style]

                Свойство позволяет задать стиль для данного абзаца. Параметр
                Stile(тип Stile) позволяет указать один
                из существующих типов.

                Свойство Underline[=Underline]

                Свойство позволяет указать , как
                должен быть подчеркнут текст в данном диапазоне. Параметр Underline( тип Underline) позволяет указать тип
                линии подчеркивания

                Метод InsertAfter вставляет
                заданный текст в конце диапазона или выделения.

                Синтаксис:

                objRange.InsertAfter(Text)

                Пример:

                ActiveDocument.Range.InsertAfter
                «пример»

                Метод InsertParagraph
                позволяет заменить заданный диапазон символов или выделения на новый абзац.
                После его использования объект Range отождествляется
                с новым абзацем.

                Метод InsertSymbol
                предназначен для вставки символа в заданное место диапазона или выделения. При
                использовании данного метода содержимое диапазона или выделения удаляется. Если
                этого не требуется, то перед вызовом этого метода следует использовать метод Collapse.

                Синтаксис:

                ObjRange.InsertSimbol (CharacterNumber, Font, Unicode)

                Параметр CharacterNumber
                определяет код символа. Параметр Font
                определяет имя шрифта, используемого в качестве источника символов. Параметр Unicode если значение True,
                то вставляется юникодовый символ, заданный аргументом
                CharacterNumbe. В противном случае (по умолчанию False) будет вставлен символ ANSI, заданный аргументом CharacterNumbe.

                Пример:

                Selection.Collapse direction:=wdCollapseStart

                Selection.InsertSymbol characterNumber:=171, Font:=»Symbol», unicode:=False           «

                Метод Paste позволяет
                вставить содержимое буфера обмена в заданный диапазон или выделение. При его
                использовании содержимое диапазона или выделения заменяется содержимым буфера
                обмена. В случае если требуется вставить абзац из буфера обмена без замены
                текущего абзаца, перед вызовом этого метода следует использовать метод Collapse.

                7.Поиск и замена

                Поиск   и замена- это
                стандартные инструменты любого приложенияMicrosoft Office .Как правило, команды
                вызова соответствующих диалоговых окон располагаются в меню Правка(Edit). Инструменты поиска и
                замены в VBAреализуются
                с помощью объектов Find и Replacement.

                Задачи по поиску и замене требуют своей реализации в VBA в
                редких случаях, например при частом поиске и замене одного и того же сочетания , вложенном поиске или при контекстном поиске.

                Стандартный инструмент поиска и замены работает следующим образом
                : вы открываете окно диалога Поиск и замена(Find and Replace) , вводите в соответствующие поля необходимые значения , определяете дополнительные параметры поиска и нажимаете
                кнопку Поиск(Find) или
                Заменить(RepleceОднако
                при частом поиске или замене одних и тех же значений для этой операции удобно
                назначить кнопку на панели инструментов , комбинацию клавиш или разместить ее в
                контекстном меню. Для реализации этой задачи нужно сначала создать
                соответствующий макрос.

                Для упрощения (ускорения) создания соответствующего
                программного кода можно автоматизировать процесс написания макроса.

                1. Подготовить
                  документ к поиску
                2. Выбрать
                  команду Сервис +Макросачать запись
                3. В
                  поле Имя макроса введите имя макроса , в поле
                  Описание добавьте описание макроса
                4. Нажмите
                  кнопку Ok – откроется панель инструментов Остановит запись , содержащая кнопки управления записью макроса:
                  Остановить запись и Пауза.
                5. Выберите
                  команду Правкаайти

                Укажите необходимые параметры
                поиска и нажмите кнопку Найти

                На панели инструментов Остановить запись нажмите кнопку Остановить
                запись

                Откройте окно редактирования Visual Basic for Application и
                перейдите к записанному макросу.

                Выполните ручное редактирование
                макроса

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

                Пример:

                 Sub ReplaceSpace4()

                Selection.Find.ClearFormatting

                Selection.Find.Replacement.ClearFormatting

                With Selection.Find

                .Text=space(4)

                .Replacement.text=”^t”

                .forward=true

                .Wrap=WdfindWrap.wdfindall

                End With

                Selection.Find.Execute Replace:=wdReplaceall

                End Sub

                В ситуации ,
                когда нужно найти фрагмент документа , а в нем еще один фрагмент – задача
                становится неоднозначной. В этом случае можно создать два макроса , один из которых будет вызываться и другого.

                В приведенном ниже примере
                реализован одкратно вложенный поиск и замена , однако число вложений может быть и больше.

                Переменная strText(тип string) содержит текст, вкотром осуществляется поиск .
                Если заданный текст будет найден (метод Execute возвращает True), то осуществляется вызов процедуры
                ReplaceSpace4,
                показанной в предыдущем примере .

                Пример:

                Selection.Find.ClearFormatting

                Selection.Find.Replacement.ClearFormatting

                 With Selection.Find

                .Text= strText

                If .Execute Then ReplaceSpace4

                End With

                8.Коллекция Tables.

                Таблица представляет собой
                упорядоченную структуру, предназначенную для хранения организованных в виде
                строк и столбцов наборов данных. Элемент таблицы, находящийся на пересечении
                строки и столбца, называется ячейкой.

                Таблица Word
                имеет такую же структуру, как и электронная таблица Excel
                – элемент таблицы, находящийся на пересечении строки и столбца, называется
                ячейкой и идентифицируется по имени столбца и номеру строки.

                В VBA для доступа к таблицам
                используется объект Tables, являющийся семейством
                объектов Table, каждый из которых связан с конкретной
                таблицей. Для получения ссылки на семейство Tables
                можно использовать свойство Tables объекта Document.

                Общее число таблиц, имеющихся в
                документе, содержится в свойстве Count. Для
                получения доступа к конкретной таблице можно использовать метод Item, который является методом по
                умолчанию.

                Синтаксис:

                Set oblTable=objDocument.Tables.Item(Key)

                Параметр Key,
                является уникальным идентификатором каждой таблицы, хранящейся в объекте Tables.

                Для создания новой таблицы
                используется метод Add объекта Tables. Этот метод возвращает ссылку на созданную таблицу(Table).

                objTables.Add
                (Range, NumRows, NumColums)

                Параметр Range
                позволяет указать область документа, куда будет вставлена таблица. Если
                параметр не пустой, т.е. имеется выделенная область, то она будет заменена
                вставляемой таблицей.

                Параметры NumRows,
                NumColums
                позволяют указать на число строк и
                столбцов таблицы.

                Пример: создадим таблицу в выделенном
                месте или там где стоит курсор.

                Set instable = ActiveDocument.Tables.Add(Selection.Range, 4, 10)

                Аннотация: Лекция посвящена описанию объектов Selection и Range, описанию особенностей работы с автоматически выполняемыми макросами и шаблонами.

                11.1. Объект Selection

                Выше нам уже встречался и объект Selection, и объект Range. Здесь пришло время поговорить о них подробнее, обсудить особенности их использования.

                Напомню, что объект Application.Selection представляет собой выделенный участок документа или, если ничего не выделено, позицию курсора. Именно этим объектом пользуется макрорекордер при записи макроса, выполняющего какие-либо операции с текстом.

                У Selection есть два основных применения. Первое — автоматическое создание документов, не требующее правки шаблонов и других подобных операций. И второе — работа с фрагментом документа, предварительно выделенного пользователем.

                Выделения можно создавать и программно, но эту методику практически никогда не используют на практике. Например, код листинга 11.1 выделяет седьмое слово в документе и форматирует его курсивом:

                ActiveDocument.Words.Item(7).Select
                Selection.Font.Italic = True


                Листинг
                11.1.
                Выделяем седьмое слово и форматируем его

                Предположим, мы используем такую конструкцию в шаблоне для автоматического форматирования текста. Если мы правильно рассчитаем номер слова, которое нужно отформатировать (или отредактировать, вставить в документ и т.д.) — то все будет работать правильно. Но стоит нам отредактировать шаблон — даже совсем немного, но так, что количество слов в нем изменится, наш макрос будет работать неправильно.

                Объект Selection обычно используют без объявления объектной переменной. Например, для вставки в выделенную позицию документа текста «Привет» достаточно конструкции листинга 11.2.

                Selection.Text = "Привет"


                Листинг
                11.2.
                Добавляем текст в выделенную позицию документа

                Минус использования Selection при автоматической обработке текста зависит от того, что он слишком чувствителен к действиям пользователя. Например, мы напишем программу, которая, имитируя выделение фрагментов текста с клавиатуры, обрабатывает текст. Если во время обработки текста пользователь вмешается, случайно кликнув мышью в документе, работа такой программы будет нарушена.

                Рассмотрим основные свойства и методы объекта Selection.

                11.2. Методы объекта Selection

                11.2.1. ClearFormatting — очистить форматирование

                Этот метод очищает форматирование выделенного участка документа.

                11.2.2. Copy, Cut, Paste, Delete

                Методы Copy и Cut, соответственно, копируют и вырезают выделенный фрагмент в буфер обмена, а метод Paste — вставляет материалы из буфера в область выделения.

                Метод Delete удаляет выделенный фрагмент

                11.2.3. InsertAfter, InsertBefore — добавление текста

                Как следует из их названий, методы InsertAfter и InsertBefore позволяют вставить текст после или до выделения. Существуют и другие методы, название которых начинается с Insert. Они позволяют вставлять множество других объектов в выделенную область. Например, InsertBreak вставляет разрыв страницы, колонки или раздела, InsertCells вставляет в выделенную таблицу ячейки и т.д.

                11.2.4. TypeBackspace — удалить символ

                Удаляет один символ, предшествующий позиции курсора, имитируя нажатие клавиши Backspace на клавиатуре.

                11.2.5. TypeParagraph — перевод строки

                Имитирует нажатие клавиши Enter на клавиатуре — вставляет в текст знак перевода строки.

                11.2.6. TypeText — вывести текст в документ

                Вводит в документ текст. У метода есть лишь один параметр — Text. Он должен содержать тот текст, который должен быть выведен в документ. Ниже мы рассмотрим примеры, где используется этот метод.

                11.2.7. WholeStory — выделить весь документ

                Позволяет выделить весь документ. Пожалуй, это единственный удобный метод программного управления выделением.

                11.3. Свойства объекта Selection

                11.3.1. Bookmarks и другие

                Это свойство возвращает коллекцию Bookmarks, которая содержит все закладки, имеющиеся в выделении. Существуют подобные свойства для символов ( Characters ), таблиц ( Tables ) и многих других коллекций объектов. Работа с ними ни чем не отличается от работы с аналогичными коллекциями, входящими в Document.

                11.3.2. End и Start

                Эти свойства позволяют узнать и модифицировать, соответственно, конечную ( End ) и начальную ( Start ) позиции выделения.

                11.3.3. Font — шрифт

                Это свойство позволяет узнавать и настраивать параметры шрифта выделенного фрагмента. Например, код, приведенный в листинге 11.3 форматирует текст. Пояснения к примеру приведены в комментариях.

                'Полужирный
                    Selection.Font.Bold = wdToggle
                    'Курсивный
                    Selection.Font.Italic = wdToggle
                    'Подчеркнутый
                    Selection.Font.Underline = wdUnderlineSingle
                    'Гарнитура Arial Narrow
                    Selection.Font.Name = "Arial Narrow"
                    'Размер шрифта - 14
                    Selection.Font.Size = 14
                    'Цвет шрифта - красный - из
                    'перечисления wdColorR
                    Selection.Font.Color = wdColorRed


                Листинг
                11.3.
                Форматируем текст

                11.3.4. Information — подробности о выделении

                Позволяет узнать подробности о выделении. Это свойство может принимать параметр типа wdInformation, который и определяет, что именно возвратит свойство.

                11.3.5. Range — переход от Selection к Range

                Это свойство позволяет получить объект Range, соответствующий выделению.

                Например, этим свойством можно воспользоваться так, как показано в листинге 11.4.

                Dim obj_Range As Range
                Set obj_Range = Selection.Range


                Листинг
                11.4.
                Получаем объект Range из Selection

                11.3.5. Text — текст выделения

                Это свойство позволяет получить текст, содержащийся в выделении, и изменить его.

                11.4. Пример работы с Selection

                11-01-Selection.docm— пример к п. 11.4.

                Рассмотрим пример использования вышеперечисленных свойств и методов (а заодно – и некоторых других), решив небольшую задачу.

                11.4.1. Задание

                Создать новый документ, и добавить в него текст, который был выделен в текущем документе. Каждое слово этого текста надо напечатать отдельно, с новой строки. Каждое слово должно предваряться таким текстом: «Слово №x:», где x — номер слова в выделенном тексте. После вывода слов нужно подсчитать количество слов и количество букв в этих словах и вывести строку «Всего обработано «x» слов, состоящих из «xx» букв». Готовый документ сохранить на диске C:, задав в качестве его имени такую структуру:

                "Имя_исходного_документа"+ "текущая дата"+ "обработано".docm

                После того, как слова будут выведены, нужно заключить выделенный участок исходного документа в скобки, отметить синим цветом шрифта и выделить первый символ текущего выделения.

                11.4.2. Решение

                Создадим новый макрос ( Copy_To_File ), воспользовавшись окном Макросы, которое можно открыть с вкладки Вид.

                Добавим в макрос код из листинга 11.5.

                'Переменая для хранения ссылки на новый документ
                    Dim obj_NewDoc As Document
                    'Для ссылки на исходный документ
                    Dim obj_OurDoc As Document
                    'Динамический массив для хранения слов
                    Dim WordsArray() As String
                    'Переменная для хранения количества слов
                    Dim WordsCount
                    'Переменная для формирования строк,
                    'которые выводятся в новый документ
                    Dim OutString
                    'Переменная для хранения количества
                    'символов в обработанных словах
                    Dim LettersCount
                    'В этой переменной будем создавать
                    'имя файла
                    Dim NewDocName
                    'Запишем ссылку на активный документ
                    'Для того, чтобы вернуться в него
                    'после работы с новым документом
                    Set obj_OurDoc = ActiveDocument
                    WordsCount = Selection.Words.Count
                    LettersCount = Selection.Characters.Count
                    ReDim WordsArray(WordsCount)
                    'Переносим слова из выделения
                    'в массив для удобства работы с ними
                    For i = 1 To WordsCount
                        WordsArray(i) = Selection.Words.Item(i)
                    Next i
                    'Создадим новый документ
                    Set obj_NewDoc = Documents.Add
                    'И сделаем его активным
                    obj_NewDoc.Activate
                    'Теперь объект Selection относится к активному
                    'документу и мы начинаем вводить в него данные
                    Selection.TypeText ("Список выделенных слов")
                    Selection.TypeParagraph
                    For i = 1 To WordsCount
                        OutString = "Слово №" + Str(i) + ": " + _
                        WordsArray(i)
                        Selection.TypeText (OutString)
                        Selection.TypeParagraph
                    Next i
                    Selection.TypeText ("Всего обработано " + _
                    Str(WordsCount) + _
                    " слов(а), в которых содержится " + _
                    Str(LettersCount) + " символа(ов)")
                    'Создаем имя нового документа
                    NewDocName = obj_OurDoc.Name + " " + _
                    Str(Date) + " Обработано.docx"
                    'Установим корневой каталог диска C:
                    'для сохранения нового файла по умолчанию
                    ChangeFileOpenDirectory "C:"
                    'Используем метод SaveAs для
                    'автоматического сохранения
                    'документа
                    ActiveDocument.SaveAs _
                    FileName:=NewDocName, _
                    FileFormat:=wdFormatDocumentDefault
                    'Закрываем активный документ
                    ActiveDocument.Close
                    'Активируем документ, в котором мы выделяли
                    'слова
                    obj_OurDoc.Activate
                    'Отмечаем обработанный участок
                    'скобками и выделением синим цветом
                    Selection.InsertAfter (") ")
                    Selection.InsertBefore (" (")
                    Selection.Font.Color = wdColorBlue
                    'Выделяем первый символ текущего выделения и
                    'выводим сообщение о том, что операция
                    'выполнена
                    Selection.Characters(1).Select
                    MsgBox ("Выполнено!")


                Листинг
                11.5.
                Решение задачи

                Как видите, в этом примере мы используем исключительно объект Selection для работы с текстом документов. Обратите внимание на то, что мы нигде специально не храним информацию о выделенной области первого документа. Создав второй документ, мы просто делаем его активным и работаем с ним, используя его объект Selection. В это время выделение сохраняется в исходном документе. Однако, если в это время пользователь случайно или умышленно изменит выделение текущего документа — программа будет работать неправильно — она выделит не тот фрагмент, который был передан ей для обработки, а совсем другой.

                Понравилась статья? Поделить с друзьями:
              • Word vba выделить найденный текст
              • Word vba вставить текст в документ
              • Word vba word wrap
              • Word vba tables range
              • Word vba string find