Vba word как выделить часть текста

1 / 1 / 0

Регистрация: 27.06.2012

Сообщений: 10

1

28.06.2012, 08:46. Показов 49459. Ответов 30


Студворк — интернет-сервис помощи студентам

Добрый день!
Помогите, пожалуйста с кодом макроса!
Дан файл с текстом:

………….
…Олег….
………….
…Иван….
………….

Необходимо выделить и скопировать все, что находится после слова «Олег» до слова «Иван».

Добавлено через 1 час 27 минут
Как поставить курсор после слова «Олег» я понял, но не понимаю, как выделить текст (или сосчитать количество символов) до слова Иван ((



1



Programming

Эксперт

94731 / 64177 / 26122

Регистрация: 12.04.2006

Сообщений: 116,782

28.06.2012, 08:46

30

KoGG

5590 / 1580 / 406

Регистрация: 23.12.2010

Сообщений: 2,366

Записей в блоге: 1

28.06.2012, 11:43

2

Лучший ответ Сообщение было отмечено как решение

Решение

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
Sub Выделить_между()
    Dim MyRange As Range, rStart&, rEnd&
    Set MyRange = ActiveDocument.Content
    With MyRange
        With .Find
            .ClearFormatting
            .Text = "Олег"
            .Forward = True
            .Wrap = wdFindStop
            .Format = False
            .MatchCase = False
            .MatchWholeWord = True
            .MatchWildcards = False
            .MatchSoundsLike = False
            .MatchAllWordForms = False
            .Execute
            If .Found Then rStart = MyRange.End: rEnd = rStart
        End With
    End With
    Set MyRange = ActiveDocument.Content
    With MyRange
        With .Find
            .Text = "Иван"
            .Execute
            If .Found Then rEnd = MyRange.Start
        End With
    End With
    If rEnd > rStart Then
        ActiveDocument.Range(rStart, rEnd).Select
        Selection.Copy
    End If
End Sub



3



1 / 1 / 0

Регистрация: 27.06.2012

Сообщений: 10

28.06.2012, 13:58

 [ТС]

3

спасибо большое



0



Казанский

15136 / 6410 / 1730

Регистрация: 24.09.2011

Сообщений: 9,999

28.06.2012, 20:28

4

Лучший ответ Сообщение было отмечено как решение

Решение

Можно одним поиском обойтись:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Sub Макрос1()
Dim r
Set r = ActiveDocument.Range
With r.Find
    .ClearFormatting
    .Text = "Олег*Иван"
    .Forward = True
    .Wrap = wdFindContinue
    .Format = False
    .MatchCase = False
    .MatchWholeWord = False
    .MatchAllWordForms = False
    .MatchSoundsLike = False
    .MatchWildcards = True
    If .Execute Then
        ActiveDocument.Range(r.Start + 4, r.End - 4).Select
        Selection.Copy
    Else
        MsgBox "Текст не найден!", vbExclamation
    End If
End With
End Sub



4



0 / 0 / 0

Регистрация: 23.10.2013

Сообщений: 4

29.10.2013, 09:53

5

А как быть если в тексте несколько фрагментов, которые нужно выделить по очереди?



0



Sasha_Smirnov

5561 / 1367 / 150

Регистрация: 08.02.2009

Сообщений: 4,107

Записей в блоге: 30

29.10.2013, 10:49

6

Если автоматизировать, то вот от этого можно плясать:

Цитата
Сообщение от Казанский
Посмотреть сообщение

Visual Basic
1
.Text = "Олег*Иван"

Конечно, с подгонкой длины ограничивающих слов:

Цитата
Сообщение от Казанский
Посмотреть сообщение

ActiveDocument.Range(r.Start + 4, r.End — 4).Select

Лучше опишите весь проект: возможно, чем менять код, легче поставить закладки — и по ним уже выделять.



0



0 / 0 / 0

Регистрация: 23.10.2013

Сообщений: 4

30.10.2013, 03:13

7

Имеется документ, состоящий из некоторого количества блоков текста. Каждый блок имеет вид [начало] текст [конец]. Текст выгружается из БД, причем без форматирования и каждая строка заканчивается символом абзаца (^p), и приходитсякаждый раз исправлять текст. Я написал макрос, который приводит текстовку в нормальный вид, разбивает на абзацы выбранный фрагмент документа, поэтому приходится постоянно самостоятельно выделять блок текста и выполнять макрос. За реальный абзац я беру только сочетание вида «.^p», остальные заменяю на пробелы. Код, который подсказал KoGG’a выделяет только первый блок, а хотелось бы чтобы происходило поочередное выделение и форматирование каждого блока текста во всем документе.
Спасибо за помощь)



0



0 / 0 / 0

Регистрация: 23.10.2013

Сообщений: 4

30.10.2013, 05:20

9

Спасибо за подсказку, но сейчас посидел, покрутил автоформат, он делает не совсем то, что нужно — форматирует весь документ, мне же нужно исправить только текстовку блока, не затрагивая иной информации., т.е. от выделения фрагментов врятли получится уйти, даже при использовании автоформата. Если есть код Вашего исправителя, было бы рад увидеть его



0



Sasha_Smirnov

5561 / 1367 / 150

Регистрация: 08.02.2009

Сообщений: 4,107

Записей в блоге: 30

30.10.2013, 10:17

10

И мне было бы радостно, но с собой не ношу — он в офисе…

Да и воздействует он на весь документ. А вот Автоформат, возможно, на выделение:

VB.NET
1
Selection.Range.Autoformat

(возможно, чушь написал: попробовать не могу: я не в офисе)



0



0 / 0 / 0

Регистрация: 23.10.2013

Сообщений: 4

30.10.2013, 10:23

11

Автоформат выполняется в выделенной области, но опять же, нужно выделить несколько областей, чтобы весь документ был в нормальном виде)



0



361 / 38 / 2

Регистрация: 16.03.2013

Сообщений: 186

31.10.2013, 13:47

13

Как быть, если нужно выделить все вхождения между Иван*Олег?

Иван………..Олег
…………………….
…………………….
Иван…Олег
………………………
Иван…Олег



0



Аксима

6076 / 1320 / 195

Регистрация: 12.12.2012

Сообщений: 1,023

31.10.2013, 17:51

14

Цитата
Сообщение от Slamzor
Посмотреть сообщение

Как быть, если нужно выделить все вхождения между Иван*Олег?

Использовать замечательный код Казанского из поста №4 данной темы, конечно же:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
Sub Ìàêðîñ1()
    Dim r, f As Boolean, firstOccurence As Long
    Set r = ActiveDocument.Range
    Do
        With r.Find
            .ClearFormatting
            .Text = "Èâàí*Îëåã"
            .Forward = True
            .Wrap = wdFindContinue
            .Format = False
            .MatchCase = False
            .MatchWholeWord = False
            .MatchAllWordForms = False
            .MatchSoundsLike = False
            .MatchWildcards = True
            If .Execute Then
                If f Then
                    If r.Start = firstOccurence Then
                        MsgBox "Áîëüøå íè÷åãî íå íàéäåíî.", vbInformation
                        Exit Do
                    End If
                Else
                    firstOccurence = r.Start
                    f = True
                End If
                ActiveDocument.Range(r.Start + 4, r.End - 4).Select
                MsgBox "Íàéäåí ïîäõîäÿùèé òåêñò...", vbInformation
                Set r = ActiveDocument.Range(r.End, r.End)
            Else
                MsgBox "Òåêñò íå íàéäåí!", vbExclamation
                Exit Do
            End If
        End With
    Loop
End Sub

Как говорится, найдите 10 отличий .

  1. добавил цикл;
  2. ввел строку для обновления диапазона поиска;
  3. ввел проверку для предотвращения поиска уже найденных текстов;
  4. и… все.

С уважением,

Aksima



1



361 / 38 / 2

Регистрация: 16.03.2013

Сообщений: 186

31.10.2013, 18:58

15

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



0



Аксима

6076 / 1320 / 195

Регистрация: 12.12.2012

Сообщений: 1,023

31.10.2013, 23:11

16

Цитата
Сообщение от Slamzor
Посмотреть сообщение

нельзя этот текст обработать

Неправда — можно. Замените строчку, отвечающую за выделение текста…

Visual Basic
1
ActiveDocument.Range(r.Start + 4, r.End - 4).Select

…на код обработки текста.

Например, после замены ее на:

Visual Basic
1
ActiveDocument.Range(r.Start + 4, r.End - 4).Style = ActiveDocument.Styles("Ñèëüíîå âûäåëåíèå")

найденный текст будет выделяться стилем «Сильное выделение».

С уважением,

Aksima



2



4 / 4 / 0

Регистрация: 18.02.2013

Сообщений: 539

31.10.2013, 23:15

17

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



0



361 / 38 / 2

Регистрация: 16.03.2013

Сообщений: 186

31.10.2013, 23:50

18

Лучший ответ Сообщение было отмечено как решение

Решение

Aksima спорить не буду). Я имел в виду, что средствами Word … Спасибо еще раз.

койтемиров

Миниатюры

Выделение фрагмента текста в Word, заключенного между заданными словами
 

Выделение фрагмента текста в Word, заключенного между заданными словами
 



0



4 / 4 / 0

Регистрация: 18.02.2013

Сообщений: 539

01.11.2013, 00:22

19

Slamzor, а для чего такая писанина в ворде нужна бывает? к примеру



0



361 / 38 / 2

Регистрация: 16.03.2013

Сообщений: 186

01.11.2013, 08:10

20

Цитата
Сообщение от койтемиров
Посмотреть сообщение

, а для чего такая писанина в ворде нужна бывает? к примеру

В дипломе, в диссертации, в тех документации. Да мало ли где.
Например, можно поправить текст между всеми словами как Рисунок — Таблица. Весь текст привести к единому формату. Макрос универсален, каждый сам себе применение найдет. Единственное, не привязаться к тексту, если он в таблице, у меня в некоторых случаях, вторая часть поиска в таблице находится.



0



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

Для начала давайте вспомним, что выделение фрагмента текста осуществляется следующим образом: в большинстве случаев нужно выбрать несколько фрагментов, для этого сначала выбираем один нужный фрагмент, далее удерживаем клавишу «Ctrl« и выбираем остальные фрагменты. Теперь перейдем к теме публикации…

Объект Word Selection содержит довольно много методов, большая часть из которых практически не используется, да и превращать блог в энциклопедию просто нет смысла. Поэтому, я решил разбить описание методов на две статьи, выбрав только те, которые чаще всего используются. В этой первой части я рассмотрю примеры работы с двумя категориями – методы с префиксомInsert и Move. Со второй частью можете ознакомиться в статье «Объект Word Selection — выделение текста, методы #2«.

Содержание

  1. Методы Insert… – выделение фрагментов текста в Word
  2. Методы Insert… – выделение фрагментов текста в Word
  3. Методы Insert… – выделение фрагментов текста в Word
  4. Методы Insert… – выделение фрагментов текста в Word

Методы Insert… – выделение фрагментов текста в Word

как выделить фрагмент в тексте

Примеры будут как для редактора VBA, так и для сценариев Windows Script Host, и так, начнем…

Методы с префиксом Insert… позволяют вставить текст в документ:

InsertAfter(text) и InsertBefore(text) – Вставка текста (text) в конец или в начало выделения. При отсутствии выделения вставка производится там, где находится курсор. Сам материал остается выделенным.

InsertBreak(type) — Вставляет страницу, колонку или секцию. Параметр type содержит значение константы WdBreakType:

  • wdTextWrappingBreak — 11 — Конец текущей строки и продолжение вставки ниже изображения, таблицы или другого объекта. Материал продолжается на следующей пустой строке, которая не содержит таблицу, совмещенную с левой или правой границей.
  • wdLineBreakClearRight — 10 — Перевод на новую строку.
  • wdLineBreakClearLeft — 9 — Перевод на новую строку.
  • wdColumnBreak — 8 — Разрыв колонки.
  • wdPageBreak — 7 — Вставка новой страницы.
  • wdLineBreak — 6 — Перевод на новую строку.
  • wdSectionBreakOddPage — 5 — Начало нового раздела со следующей нечетной страницы.
  • wdSectionBreakEvenPage — 4 — Начало нового раздела со следующей четной страницы.
  • wdSectionBreakContinuous — 3 — Новый раздел без разрыва страницы.
  • wdSectionBreakNextPage — 2 — Начало нового раздела со следующей страницы.

Прежде чем приступать к программированию, стоит сделать некоторое пояснение. По сути, ряд действий будут всегда одинаковыми – создание нового документа (за это будет отвечать функция или процедура Create_Doc). Изменяться будут только вызываемые методы.

Программный код на VBScript:

' ----------------------------------------------------------------------------
' Объект Word Selection - методы
' Пример на языке VBScript - выделение фрагментов Word текста
' Selection-1.vbs
' ----------------------------------------------------------------------------
Option Explicit
' Глобальные переменные
dim oWord, oDoc, oSel, i
 
' Процедура создания нового документа
Sub Create_Doc()
Set oWord = CreateObject("Word.Application")
Set oDoc = oWord.Documents
oDoc.Add()
Set oSel = oWord.Selection
oWord.Visible = True
End Sub
 
Sub Insert_After_Before()
     With oSel
     .Text = "как выделить фрагмент текста "
     .InsertAfter "          ............Конец"
     .InsertBefore "Начало......    "
     .EndOf
     .InsertBreak 6
     End With
End Sub
 
call Create_Doc
call Insert_After_Before

Давайте посмотрим, что данный пример делает. При вызове процедуры Insert_After_Before происходит добавление в документ текстовой строки, далее в конец добавляется фраза » …………Конец», а в начало — «Начало…… «. Потом происходит перевод курсора в конец и добавление перевода строки.

Пример на JScript:

// ----------------------------------------------------------------------------
// Объект Word Selection - методы
// Пример на языке JScript - выделение фрагмента в тексте
// Selection-1.js
// ----------------------------------------------------------------------------
 
// глобальные переменные
var oWord, oDoc, oSel, i
 
function Create_Doc(){
oWord = WScript.CreateObject("Word.Application");
oDoc = oWord.Documents;
oDoc.Add();
oSel = oWord.Selection;
oWord.Visible = true;
}
 
function Insert_After_Before(){
     with(oSel){
                 Text = "как выделить в документе фрагмент текста ";
                 InsertAfter("          ............Конец");
                 InsertBefore("Начало......    ");
                 EndOf();
                 InsertBreak(6);
     }
}
 
Create_Doc();
Insert_After_Before();

Для VBA мы просто запускаем редактор кода, добавляем новый модуль и прописываем код, в моем случае имя модуля — Module1:

Sub Module1()
' ----------------------------------------------------------------------------
' выделение в Word фрагментов текста
' ----------------------------------------------------------------------------
 
Dim oWord1 As Object, oDoc1 As Object, oSel1 As Object, i
 
Set oWord1 = CreateObject("Word.Application")
Set oDoc1 = oWord1.Documents
oDoc1.Add
Set oSel1 = oWord1.Selection
oWord1.Visible = True
 
'***************************************
With oSel1
     .Text = "как выделить фрагмент текста "
     .InsertAfter "          ............Конец"
     .InsertBefore "Начало......    "
     .EndOf
     .InsertBreak wdLineBreak
End With
'***************************************
 
End Sub

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

Методы Insert… – выделение фрагментов текста в Word

InsertCaption(Label, Title, TitleAutoText, Position, ExcludeLabel) — Вставляет заголовок сразу после или перед указанным выбором. Обязательным является только параметр Label.

Label – Нумерационный заголовок. Параметр может быть строкой или значением константы WdCaptionLabelID:

  • wdCaptionEquation — Уравнение
  • wdCaptionFigure — Рисунок
  • wdCaptionTable – Таблица

Если метка (Label) не определена, то возникнет ошибка. Для определения метки надо использовать метод Add коллекции CaptionLabels, например:

Applicationd.CaptionLabels.Add Name:="Рисунок"

Title– Заголовок, который будет отображаться справа от метки.

TitleAutoText– Авто-заголовок, перекрывает параметр Title.

Position— Указывает, будет ли вставлен заголовок выше или ниже. Может быть одной из констант WdCaptionPosition:

  • wdCaptionPositionAbove — 0 — Метка название добавляется выше.
  • wdCaptionPositionBelow — 1 — Метка название добавляется ниже.

ExcludeLabel— TRUE — отключить метку, заданную в параметре Label. FALSE — включить метку. Дополнительно.

Ниже я приведу примеры, что бы не дублировать программный код, я привел только содержимое процедуры Sub Insert_Caption.

' VBScript
Sub Insert_Caption()
     oWord3.CaptionLabels.Add "Номер"
     For i = 0 To 10
                 oSel3.InsertCaption "Номер", "    как выделять фрагменты текста " & i
                 oSel3.InsertBreak 6
     Next
End Sub

Тут используется цикл for для вставки нескольких фрагментов — «Урок 6 по VBScript: Циклы for…next и for each…next«.

//JScript
function Insert_Caption(){
oWord4.CaptionLabels.Add("Номер");
     for (i = 0; i<=10; i++){
                 oSel4.InsertCaption("Номер", "    выделение фрагмента текста " + i);
                 oSel4.InsertBreak(6);
     }
}

Тут тоже используется цикл for, но уже для JS кода — «Урок 9 по JScript — оператор цикла for«.

' VBA
oWord5.CaptionLabels.Add "Номер"
For i = 0 To 10
     oSel5.InsertCaption Label:="Номер", Title:="    Фраза VBA Selection " & i
     oSel5.InsertBreak wdLineBreak
Next

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

Методы Insert… – выделение фрагментов текста в Word

как можно выделить фрагмент текста

InsertDateTime(DateTimeFormat) – Метод позволяет вставить дату или время в документ, или одновременно оба значения. Помимо параметра DateTimeFormat есть еще четыре, но они практически не используются.

DateTimeFormat – Необязательный параметр, позволяет указать формат даты и времени.

' VBScript
Sub Insert_Date
    With oSel4
        .Text = "как выделить фрагмент текста "
        .EndOf
        .InsertBreak 6
        .InsertDateTime
        .InsertBreak 6
        .InsertDateTime "MMMM dd, yyyy"
        .InsertBreak 6
        .InsertDateTime "MMMM dd, yyyy - H:M:S"
    End With
End Sub

Обратите внимание на оператор with, он позволяет не писать каждый раз имя класса.

//JScript
function Insert_Date(){
    with(oSel4){
        Text = " выделение фрагментов Word текста ";
        EndOf();
        InsertBreak(6);
        InsertDateTime();
        InsertBreak(6);
        InsertDateTime("MMMM dd, yyyy");
        InsertBreak(6);
        InsertDateTime("MMMM dd, yyyy - H:M:S");
    }
}

Тут логика работы аналогична.

' VBA
With oSel5
     .Text = " как выделить в Word фрагмент текста "
     .EndOf
     .InsertBreak wdLineBreak
     .InsertDateTime
     .InsertBreak wdLineBreak
     .InsertDateTime "MMMM dd, yyyy"
     .InsertBreak wdLineBreak
     .InsertDateTime "MMMM dd, yyyy - H:M:S"
End With

Хорошо, осталось рассмотреть последнюю третью часть статьи.

Методы Insert… – выделение фрагментов текста в Word

InsertFile(FileName) – Позволяет вставить содержимое указанного файла в документ, параметр FileName хранит имя или путь к файлу, если путь отсутствует, то будет подразумеваться текущий каталог.

InsertNewPage — Вставляет новую страницу в место, где находится указатель.

InsertParagraph— Заменяет выделение знаком абзаца.

InsertParagraphAfter— Вставляет знак абзаца после выделения .

InsertParagraphBefore— Вставляет новый абзац перед выделением.

Методы с префиксом Move… также встречаются едва ли не в любой программе, связанной с вводом текста в Word. Самые важные и удобные из этих методов:

MoveLeft(), MoveRight(), MoveUp(), MoveDown() – Методы дают возможность переместить курсор влево, вправо, вверх и вниз. Все четыре метода принимают следующие параметры (Unit, Count, Extend), являющиеся необязательными:

Unit — Блок, по которым выбор должен быть перемещен. Параметр Unit содержит значения константы wdUnits.

Count – Единица перемещения. Значение по умолчанию 1.

Extend — Может быть либо wdMove (по умолчанию) или wdExtend.

MoveEnd(), MoveStart() – Перемещение курсора в конец или начало выделения, параметры — Unit, Count.

MoveStartUntil(), MoveStartWhile(), MoveEndUntil(), MoveEndWhile() – Позволяют переместить курсор к заданному символу или последовательности символов. Параметры Cset (обязательный) и Count (дополнительный):

Cset — Один или несколько символов. Аргумент является чувствительным к регистру.

Count – Задает целое или отрицательное значение, на которое происходит перемещение курсора.

Move(Unit, Count) – Фактически, тут мы может указать направление (Count) и текстовую единицу (Unit).

Логика работы для следующих примеров остается та же – меняется только код вызываемой процедуры. Фактически, код для языка VBScript и VBA является идентичным.

' VBScript
Sub Get_Move()
With oSel6
     ' вставляем в документ фразу сто раз
     For i = 0 To 10
                 .Text = "как выделить фрагменты нужного текста "
                 ' Перемещаем курсор в конец
                 .EndOf
     Next
 
     For i = 0 To 300
                 .MoveLeft
     Next
 
     For i = 0 To 100
                 .MoveRight
     Next
 
     For i = 0 To 4
                 .MoveUp
     Next
 
     .MoveStartUntil "Word"
 
     For i = 0 To 15
                 .Move 2, 5
     Next
End With
End Sub

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

//JScript
function Get_Move(){
with(oSel6){
     for (i=0; i<=10; i++){
                 .Text = "Текстовая строка: выделение фрагментов текста  ";
                 .EndOf();
     }
 
     for (i=0; i<= 300; i++){ .MoveLeft(); }
     for (i=0; i<= 100; i++){ .MoveRight(); }
     for (i=0; i<= 4; i++){ .MoveUp(); }
     .MoveStartUntil("Word");
     for (i=0; i<= 15; i++){ .Move(2, 5); }
}
}

Обратите внимание на приведенные в самом начале статьи примеры кода для языков VBA и VBScript, в макросе мы можем использовать именованные константы объекта Word, но в теле Windows Script Host сценария нет, так как там они не доступны. Описание свойств класса Selection я рассмотрел в этой статье.

Sub макрос()

    Dim rng As Range

            ‘ Присваиваем выделенному фрагменту имя ‘rng’. Далее в коде будем
        ‘ обращаться к выделенному фрагменту по имени ‘rng’.
        ‘ Может быть так будет удобнее писать и читать код.
    Set rng = Selection.Range.Duplicate

        Do

            ‘ Если последний символ во фрагменте ‘rng’ русская или английская буква, то выход из цикла.
        If rng.Characters.Last.text Like «[А-Яа-яЁёA-Za-z]» Then
            Exit Do
        End If

                ‘ Уменьшаем выделение на один символ.
        rng.End = rng.End — 1

                ‘ Если конец и начало фрагмента совпали, то выход из цикла.
        If rng.End = rng.Start Then
            Exit Do
        End If

            Loop

        ‘ Выделение фрагмента ‘rng’.
    rng.Select

End Sub

[свернуть]

Формулировка задачи:

Добрый день!
Помогите, пожалуйста с кодом макроса!
Дан файл с текстом:

………….
…Олег….
………….
…Иван….
………….

Необходимо выделить и скопировать все, что находится после слова «Олег» до слова «Иван».

Как поставить курсор после слова «Олег» я понял, но не понимаю, как выделить текст (или сосчитать количество символов) до слова Иван ((

Код к задаче: «Выделение фрагмента текста в Word, заключенного между заданными словами»

textual

Sub Макрос1()
Dim r
Set r = ActiveDocument.Range
With r.Find
    .ClearFormatting
    .Text = "Олег*Иван"
    .Forward = True
    .Wrap = wdFindContinue
    .Format = False
    .MatchCase = False
    .MatchWholeWord = False
    .MatchAllWordForms = False
    .MatchSoundsLike = False
    .MatchWildcards = True
    If .Execute Then
        ActiveDocument.Range(r.Start + 4, r.End - 4).Select
        Selection.Copy
    Else
        MsgBox "Текст не найден!", vbExclamation
    End If
End With
End Sub

Полезно ли:

8   голосов , оценка 4.375 из 5

WORD ВБА как выделить часть текста в Shape.Textbox?

Roman777

Дата: Суббота, 03.12.2016, 23:40 |
Сообщение № 1

Группа: Проверенные

Ранг: Ветеран

Сообщений: 980


Репутация:

127

±

Замечаний:
0% ±


Excel 2007, Excel 2013

Добрый всем вечер! Создал программно Shapes.AddTextBox… вручную в нём могу выделять диапазон, как хочу. Программного решения этого действия я не нашёл. Максимум до чего дошёл — выделение произвольного символа, но не диапазона.
[vba]

Код

ActiveDocument.Shapes(1).TextFrame.TextRange.Characters(3).select

[/vba]
возможно ли?
Мне необходимо в определённых участках текста задать необходимое форматирование (разное).

К сообщению приложен файл:

4434074.docx
(15.7 Kb)


Много чего не знаю!!!!

 

Ответить

krosav4ig

Дата: Воскресенье, 04.12.2016, 02:04 |
Сообщение № 2

Группа: Друзья

Ранг: Старожил

Сообщений: 2346


Репутация:

989

±

Замечаний:
0% ±


Excel 2007,2010,2013

Здравствуйте.
Как-то так можно
[vba]

Код

Sub d()
    Dim start&, count&
    start = 3: count = 5
    Dim rng As Range
    With ActiveDocument.Shapes(1).TextFrame.TextRange
        Set rng = .Characters(start)
        rng.End = .Characters(start + count).End
        rng.Select
    End With
End Sub

[/vba]


email:krosav4ig26@gmail.com WMR R207627035142 WMZ Z821145374535 ЯД 410012026478460

 

Ответить

Roman777

Дата: Воскресенье, 04.12.2016, 10:05 |
Сообщение № 3

Группа: Проверенные

Ранг: Ветеран

Сообщений: 980


Репутация:

127

±

Замечаний:
0% ±


Excel 2007, Excel 2013

krosav4ig, Спасибо большое! макрос работает. rng у меня отображается как range. Я вчера часа 3 изучал деревья свойств объектов и их функции в мануале смотрел — не увидел там таких range. Что же это за невидимый объект,который не отображается у объекта:
[vba]

Код

Set o = ActiveDocument.Shapes(1).TextFrame.TextRange.Characters

[/vba]
в окошке Locals. Я так понимаю, это объекты First и Last являются составляющими этого объекта Range, благодаря которому мы можем выполнить такое выделение?


Много чего не знаю!!!!

 

Ответить

krosav4ig

Дата: Воскресенье, 04.12.2016, 15:01 |
Сообщение № 4

Группа: Друзья

Ранг: Старожил

Сообщений: 2346


Репутация:

989

±

Замечаний:
0% ±


Excel 2007,2010,2013

а если через Object Browser?
в VBE жмем F2, в поле поиска пишем TextRange, жмем Enter, выбираем строку из результатов поиска, соответствующую классу предка (столбец Class, в нашем случае TextFrame)

Видим внизу

Цитата

Property TextRange As Range
read-only
Member of
Word.TextFrame

=> объект TextRange это экземпляр класса Range
тыкаем внизу по зелененькому Range, выбираем справа (Members of ‘Range’) Characters
Видим внизу

Цитата

Property Characters As Characters
read-only
Member of
Word.Range

тыкаем внизу по зелененькому Characters, выбираем справа (Members of ‘Characters’) Item
Видим внизу

Цитата

Function Item(Index As Long) As Range
Default member of
Word.Characters

Обращаем внимание на => Characters(i) = Characters.Item(i)
и на класс возвращаемого объекта => Characters(i) это экземпляр класса Range

К сообщению приложен файл:

5446907.gif
(44.9 Kb)


email:krosav4ig26@gmail.com WMR R207627035142 WMZ Z821145374535 ЯД 410012026478460

Сообщение отредактировал krosav4igВоскресенье, 04.12.2016, 15:14

 

Ответить

Roman777

Дата: Воскресенье, 04.12.2016, 22:06 |
Сообщение № 5

Группа: Проверенные

Ранг: Ветеран

Сообщений: 980


Репутация:

127

±

Замечаний:
0% ±


Excel 2007, Excel 2013

krosav4ig, ого! спасибо ещё раз за такие подробные разъяснения. Вродебы уже не первый день юзаю ВБА, но про окошко Object Browser ни слухом ни духом. Всё по дереву в Locals изучал… а тут вот оно гораздо подробнее развёрнуто и даже в mdsn не нужно лезть…=)


Много чего не знаю!!!!

 

Ответить

Like this post? Please share to your friends:
  • Vba word имя файла
  • Vba word имя документа
  • Vba word изменить шрифт
  • Vba word изменить цвет текста
  • Vba word значения таблицы