Vba word выделить ячейку таблицы

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

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

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

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



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

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

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

Макрос

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 Макросы: Как обратиться/выделить текст в ячейке в таблице в ворде?

peaceowner

1

16.12.2010, 19:34. Показов 24955. Ответов 9


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

Ребята хелп ми, уже из сил выбился. Как выделить отдельную строку в ячейке таблицы Word? Ставлю курсор в начало строки и пробую различные методы типа MoveEnd(), EndOf(), MoveEndUntil() и другие. Все эти методы выделяют ВСЕ строки ячейки. Я даже в ворде проверил, поставил курсор на начало 2ой(из 4ех) строки ячейки и нажал клавишу End с зажатым Шифтом. В итоге выделились ВСЕ строки ячейки включая первую. Опытным путем установил, что двигаться нужно посимвольно, тогда строка выделяется как надо. Вопрос, как мне переместить выделение до последнего символа последней строки ячейки? Вообще пишу на Делфи, но все методы из ВБА. Помогите плиз.

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

1508 / 478 / 56

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

Сообщений: 8,008

16.12.2010, 20:29

2

АктивеДокумент.Таблес(1).Ровс(1).Селект
ОК???



1



306 / 187 / 26

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

Сообщений: 540

16.12.2010, 20:30

3

Selection.EndKey Unit:=wdLine, Extend:=wdExtend
Клавиатурой это Shift+End, почему у Вас это не работает, непонятно. По крайней мере в моем любимом 97 все нормально.



1



peaceowner

16.12.2010, 20:48

4

Всем спасибо, разобрался наконец) Узнал позиции первого и последнего символов желаемого выделения. А дальше при помощи SetRange установил нужное мне выделение.

kukuruku310
Не выделяется с помощью Енд именно в таблице. Видимо это так и нужно. Если текст набран вне таблицы, то помещая курсор в середину строки, при нажатии Шифт+Енд выделение происходит с середины до конца, как и должно быть. В ячейке кроме как посимвольно похоже не выделишь.

Ципихович Эндрю

1508 / 478 / 56

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

Сообщений: 8,008

17.12.2010, 03:30

5

Что Вам здесь

Visual Basic
1
ActiveDocument.Tables(1).Rows(1).Cells(2).Select

и здесь

Visual Basic
1
Номер_текущей_таблицы_где_находится_курсор = ActiveDocument.Range(0, Selection.Tables(1).Range.End).Tables.Count

не понравилось



0



306 / 187 / 26

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

Сообщений: 540

17.12.2010, 12:32

6

да хоть в таблице, хоть в тексте, Shift+End работает одинаково, проверьте настройки Word. Я сам не пользуюсь ничем, кроме 97, поэтому конкретнее сказать не могу.

Миниатюры

Выделение отдельной строки в ячейке таблицы Word
 



0



306 / 187 / 26

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

Сообщений: 540

17.12.2010, 14:46

7

Щательнее подумавши еще добавлю: в последней строке ячейки действительно будет выделять весь текст целиком. Во избежание, наиболее просто, моно сделать финт ушами: запомнить текущую позицию Range — это будет начало диапазона, а для определения его конца перейти в конец строки без выделения. Как второй вариант, использовать переход в начало (Shift+Home), который, в отличие от Shift+End, всегда срабатывает одинаково, но это более заморочно, если выделять не от начала строки.



0



Ksenya100

72 / 64 / 3

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

Сообщений: 349

27.02.2012, 18:11

8

в эту же тему
подскажите как выделить несколько символов в одной ячейке (в Word)
что-то типа

Visual Basic
1
set myrange=ActiveDocument.Tables(1).Cell(Row:=i,Column:=2).Range(start:=kk, end:=kkk)

но так, естественно не работает.

я так поняла peaceowner, разобрался…?



0



Ципихович Эндрю

1508 / 478 / 56

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

Сообщений: 8,008

27.02.2012, 18:30

9

Visual Basic
1
2
3
4
Последних_знака = 3
'... последних знака в 2 таблице, 3 строке, 4 ячейке выделить цветом ...
'1 в строке кода это последний знак в таблице - концевая сноска
ActiveDocument.Range(ActiveDocument.Tables(2).Rows(3).Cells(4).Range.End - 1 - Последних_знака, ActiveDocument.Tables(2).Rows(3).Cells(4).Range.End - 1).HighlightColorIndex = wdYellow



2



72 / 64 / 3

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

Сообщений: 349

27.02.2012, 18:50

10

Ципихович Эндрю, Спасибо!!
все работат.



0



    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,0430 ]   [ 16 queries used ]   [ Generated: 14.04.23, 17:32 GMT ]  

                Вы не вошли. Пожалуйста, войдите или зарегистрируйтесь.

                Страницы 1

                Чтобы отправить ответ, вы должны войти или зарегистрироваться

                Сообщений [ 7 ]

                1 07.02.2014 18:13:48

                • aap77
                • генерал-полковник
                • Неактивен
                • Зарегистрирован: 12.09.2011
                • Сообщений: 925
                • Поблагодарили: 243

                Тема: Особенности таблицы Word и ее связь с кодом VBA

                Здесь я рассказываю об особенностях таблицы Word, как объекта VBA.
                1-я особенность: Многие пользователи часто сравнивают таблицу Word с  таблицей Excel. Отчасти это верно, и там, и там у них общие основные свойства. Общая схема обеих таблиц в порядке подчинения выглядит так:
                Таблица —> Строка (Столбец) —> Ячейка
                Дальше начинаются разногласия, в основном из-за разного свойства Range (Область) в объектных моделей программ.
                1. В Excel в объект Range может входить набор ячеек, которые не соседствуют между собой, как по горизонтали, так и по вертикали. А в Word это непрерывный поток данных.
                Например, условновно мы имеем таблицу, состоящую из 1 строки и 3 столбцов (A1, B1, C1), то при выделении ячеек A1 и C1, Excel включит в объект Range 2-е ячейки A1 и C1, а Word — только A1, т.к. между ними есть разрыв ячека B1.
                2. В Excel и в Word есть понятие Cell (Ячейка) и Cells (Ячейки).
                В Word Cell и Cells представляются одноименными классами с отдельными свойствами и методами, а в Excel они представлены объектом Range, что дает намного больше преймуществ.
                3. Разница получения данных из ячеек.

                • В Excel мы обращаемся к одному свойству Value и получаем чистый результат. Например, если в ячейке стоит 2, то для дальнейшего использования мы имеем [переменную] = 2, как число, если ячейка имеет общий или числовой формат.

                • В Word таже ячейка (как и любая ячейка Word) представляет собой текстовую строку с двумя лишними знаками «¶» и «¤»

                Пишите мне в эту тему с отдельными вопросами связанными с данной темой. Постепенно буду здесь расмещать более развернутые вопросы.

                2 Ответ от Зульфия 14.12.2016 18:11:37

                • Зульфия
                • рядовой
                • Неактивен
                • Зарегистрирован: 14.12.2016
                • Сообщений: 2

                Re: Особенности таблицы Word и ее связь с кодом VBA

                Добрый день! Буквально два дня изучаю макросы и пытаюсь создать макрос для таблиц. Необходимо применить ко всем таблицам стиль, задать стиль текста, стиль шапки и копирование её на следующих страницах, задать стиль подписи к таблице. Последний пункт вызывает трудности, с остальными более-менее справилась.

                3 Ответ от Зульфия 14.12.2016 19:12:10

                • Зульфия
                • рядовой
                • Неактивен
                • Зарегистрирован: 14.12.2016
                • Сообщений: 2

                Re: Особенности таблицы Word и ее связь с кодом VBA

                Зульфия пишет:

                Добрый день! Буквально два дня изучаю макросы и пытаюсь создать макрос для таблиц. Необходимо применить ко всем таблицам стиль, задать стиль текста, стиль шапки и копирование её на следующих страницах, задать стиль подписи к таблице. Последний пункт вызывает трудности, с остальными более-менее справилась.

                Уточнение, работа идет с Word.

                4 Ответ от Boris_R 21.12.2016 09:44:08

                • Boris_R
                • полковник
                • Неактивен
                • Зарегистрирован: 07.08.2012
                • Сообщений: 234
                • Поблагодарили: 110

                Re: Особенности таблицы Word и ее связь с кодом VBA

                Зульфия пишет:

                Зульфия пишет:

                Необходимо применить ко всем таблицам стиль, задать стиль текста, стиль шапки и копирование её на следующих страницах, задать стиль подписи к таблице. Последний пункт вызывает трудности, с остальными более-менее справилась.

                Уточнение, работа идет с Word.

                По последнему пункту — смотрите в Справке свойства и методы объектов CaptionLabel и CaptionLabels.

                5 Ответ от Fck_This 28.12.2016 16:33:24

                • Особенности таблицы Word и ее связь с кодом VBA
                • Fck_This
                • генерал-полковник
                • Неактивен
                • Откуда: Минск, Беларусь
                • Зарегистрирован: 13.07.2016
                • Сообщений: 648
                • Поблагодарили: 97

                Re: Особенности таблицы Word и ее связь с кодом VBA

                Буду признателен, если поделитесь своими знаниями в отношении объединённых ячеек таблицы по вертикали и горизонтали.

                Спасибо можно перевести на WebMoney-кошелёк R378231864568 или на Яндекс-деньги 410015093172871

                6 Ответ от aequit 02.03.2017 15:54:30

                • aequit
                • сержант
                • Неактивен
                • Зарегистрирован: 31.03.2015
                • Сообщений: 13

                Re: Особенности таблицы Word и ее связь с кодом VBA

                Здравствуйте!
                Подскажите, можно ли занести значение в ячейку таблицы Word одной командой, вместо двух:

                ActiveDocument.Tables(1).Cell(1, 2).Select
                Selection.TypeText

                7 Ответ от yshindin 02.03.2017 16:10:10

                • yshindin
                • генерал-полковник
                • Неактивен
                • Откуда: Москва
                • Зарегистрирован: 12.05.2012
                • Сообщений: 447
                • Поблагодарили: 171
                • За сообщение: 1

                Re: Особенности таблицы Word и ее связь с кодом VBA

                aequit пишет:

                Здравствуйте!
                Подскажите, можно ли занести значение в ячейку таблицы Word одной командой, вместо двух:

                ActiveDocument.Tables(1).Cell(1, 2).Select
                Selection.TypeText

                Попробуйте так:

                 
                ActiveDocument.Tables(1).Cell(1, 2).Range.Text = "123" ' или другое значение

                Сообщений [ 7 ]

                Страницы 1

                Чтобы отправить ответ, вы должны войти или зарегистрироваться

                Похожие темы

                • Связь таблицы excel и документа word
                • особенности форматирования в word 2003
                • Связь Word и excel
                • Разорвать связь Word-Excel
                • Связь документов Word и Excel
                • Связь таблиц екселя с таблицей Word
                • Помогите с кодом Макроса
                • Импорт переменной, связь Word и Excel с помощью макроса

                Особенности таблицы Word и ее связь с кодом VBA

                Любую работу можно сделать несколькими различными способами. В силах человека выбрать наиболее удобный для себя, оптимальный и рациональный. На портале о Microsoft Office Word вы узнаете про: как расставить нумерацию страниц в ворде с рамкой на 15.
                Если говорить о работе с текстами: написании рефератов, дипломов, статей, редактировании различных документов и оформлении презентаций, то Microsoft Word дает массу возможностей для этого. Наш сайт о Microsoft Office Word даст ответ про: как поместить таблицу на одной странице.

                Познакомиться с ними,  расширить свои познания о программе или поделиться секретами и хитростями с другими пользователями вы можете на форуме Ворд Эксперт. На портале о Microsoft Office Word вы узнаете про: сохранить документ автоматически.

                Здесь собрана основная информация и ответы на наиболее популярные вопросы по работе с приложением. Например, о создании макросов, о колонтитулах, удалении лишних пробелов. На портале о Microsoft Office Word вы узнаете про: как бруть непечатаемые символы в word 2010.

                В основных разделах можно обсудить настройки самого Ворда и способы работы с текстом в различных версиях программы. На портале о Microsoft Office Word вы узнаете про: изменить лист на альбомный ворд 2010.
                Подфорум «Автоматизация» предлагает освоить технику создания макросов и задания шаблонов для различных операций и функций. На портале о Microsoft Office Word вы узнаете про: как расположить страницу альбомно.

                Здесь же на форуме можно найти готовые решения, разнообразные шаблоны, макросы для редактирования таблиц, оглавлений и многое другое. На портале о Microsoft Office Word вы узнаете про: преобразование презентации в word.
                Возможно и оставить заявку, описав свою проблему в соответствующем подразделе. Если у вас есть какие –то оригинальные идеи и решения – форум лучшее место поделиться ими с другими пользователями Ворда. Наш сайт о Microsoft Office Word даст ответ про: антоним к слову уважаемым.

                1. Коллекция
                  Tables.
                2. Форматирование
                  таблицы.
                3. Строки
                  и столбцы.
                4. Ячейки.
                5. Вычисления.

                1.Коллекция 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
                позволяют указать на число строк и
                столбцов таблицы.

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

                2.Форматирование таблицы.

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

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

                Для их применения используется метод
                AutoFormat
                .

                objTable.AutoFormat(Format, [ApplyBorders,
                ApplyShading, ApplyFont, ApplyColor, ApplyHeadingRows, ApplyLastRow, ApplyFirstColumn, ApplyLastColumn, AutoFit])

                Параметр Format
                содержит один из допустимых форматов. Список всех имеющихся форматов и
                результат их применения можно увидеть в списке Стили таблицы окна диалога Автоформат таблицы (таблица®автоформат).

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

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

                Параметр ApplyFont
                указывает, должен ли изменятся шрифт таблицы. Если True, то для текста в таблице будет применен шрифт, предусмотренный
                в применяемом автоформате.

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

                Параметр ApplyHeadingRows
                указывает на необходимость изменения формата заголовков столбцов (первой строки
                таблицы). По умолчанию имеет значение True.

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

                Параметр ApplyFirstColumn
                указывает на необходимость изменение формата первого столбца таблицы. По
                умолчанию имеет значение True.

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

                Параметр AutoFit
                указывает на автоматический подбор ширины столбцов в зависимости от размещаемых
                в них данных. По умолчанию имеет значение True.

                Пример: применяем автоформат Классический2  к таблице, расположенной первой от начала
                активного документа.

                ActiveDocument.Tables(1).AutoFormat
                Format:=WdTableFormat.wdTableFormatClassic2

                 Тип
                используемого пользовательского форматирования содержится в свойстве AutoFormatType. Свойство возвращает одно из значений
                типа wdTableFormat.

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

                Синтаксис:

                objTable.Borders

                Пример: назначение первой таблице
                в документе оформление границ.

                 With ActiveDocument.Tables(1).Borders

                .OutsideLineStyle = wdLineStyleSingle             внешние границы

                .OutsideLineWidth =
                wdLineWidth100pt

                .InsideLineStyle = wdLineStyleSingle                внутренние границы

                .InsideLineWidth =
                wdLineWidth300pt

                End With

                3.Строки и столбцы.

                Таблица состоит из набора строк и
                столбцов. Строки содержатся в семействе Rows, возвращаемое свойством Rows, а
                столбцы – в семействе Columns, возврщаемое
                свойством Columns.

                Определенная строка или столбец связаны с объектами типа Row или Column. Доступ к конкретной строке или столбцу
                осуществляется с помощью метода Item,
                являющегося для объектов Rows  и Columns методом
                по умолчанию.

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

                Пример: выпадающее окно с
                сообщением о количестве столбцов в таблице 1.

                 MsgBox ActiveDocument.Tables(1).Columns.Count

                Для получения ссылок на первую
                или последнюю строку (столбец) можно использовать свойства First и Last.

                Для добавления в таблицу новых
                строк (столбцов) используется метод Add.

                Синтаксис:

                ObjTable.Rows.Add (Before)

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

                Пример:

                Set tabv = ActiveDocument.Tables(1).Rows.Add(beforerow:=ActiveDocument.Tables(1).Rows(1))

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

                Синтаксис:

                objRow.SetHeight(RowHeight, HeightRule)

                параметр RowHeight
                указывает на новую высоту строки в пунктах.

                Параметр HeightRule
                – указывает на способ изменения высоты:

                WdRowHeightAtLeast
                – размер, указанный в параметре RowHeigh, является
                минимальным.

                WdRowHeightAuto
                — размер, указанный в параметре RowHeigh ,является
                точным.

                WdRowHeightExactly
                – автоматический подбор высоты строк (параметр RowHeigh
                игнорируется).

                Получить информацию о текущей
                ширине строки и правиле ее изменения можно с помощью свойств Height и HeightRule.

                Синтаксис:

                objRow.
                Height [=Height]

                Параметр Height
                (тип Single) позволяет задать необходимую высоту
                строки в пунктах.

                Синтаксис:

                objRow.
                HeightRule[=Rule]

                Параметр Rule
                указывает на правило изменения ширины ячейки:

                   wdRowHeightAtLeast
                — минимальная ширина, которая может быть на­значена строке, указывается в
                свойстве Height;

                   wdRowHeightExactly
                — ширина строки должна быть точно равна зна­чению, указанному в свойстве Height;

                   wdRowHeightAuto
                ширина строки подбирается автоматически в за­висимости от размера используемого
                шрифта или размера вставок.

                Чтобы установить одинаковую
                высоту всех строк, необходимо исполь­зовать метод DistributeHeight
                объекта Rows.

                objRows.
                DistributeHeight

                Для украшения текста документа
                часто используются прием создания отступа между левой границы ячейки и текстом.
                Этот прием часто применяют при создании таблиц на web-страницах. Для создания
                отступа в ячейках таблицы можно использовать свойство SpaceBetweenColumns.
                При использовании этого свойства в объекте Rows
                выполняется добавление отступа во все ячейки таблицы, а при использовании в Row — только для ячеек данной строки.

                Синтаксис

                objRows.SpaceBetweenColumns[ = Space]

                Параметр Space
                (тип Single) позволяет указать на ширину отступа
                в пунктах. Значение, передаваемое параметром Space,
                не может быть меньше 0 и больше ширины ячейки.

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

                Пример

                With ActiveDocument.Tables(l)

                .Rows(l).SpaceBetweenColumns = InchesToPoints(0.5)

                 End With

                Чтобы установить ширину столбца и
                правило ее изменения применя­ется метод SetWidth.
                Этот метод используется как в объекте типа Columns,
                так и объекте типа Column. Если используется метод
                объекта Columns, то изменения ширины касаются всех
                столбцов, а если метод объекта Column— то только
                данного столбца.

                оbjColumns.SetWidth(ColumnWidth,  RulerStyle)

                Параметр ColumnWidth
                (тип Single) указывает на новую ширину столб­ца в
                точках, а параметр RulerStyle (тип WdRulerStyle) — на способ изме­нения ширины. Параметр RulerStyle может принимать следующие
                значения:

                       wdAdjustNone (значение по умолчанию) — ширина столбца
                соответ­ствует указанному значению. Изменение ширины столбца выполня­ется за
                счет смещения левой или правой границы таблицы (столбца).

                        wdAdjustSameWidth
                ширина столбца соответствует указанному значению. Изменение ширины выполняется
                за счет смещения внутрен­них границ таблицы. Правая граница сохраняет свое
                положение.

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

                       wdAdjustProportional — ширина первого столбца соответствует
                ука­занному значению. Размер остальных столбцов подбирается авто­матически, так
                чтобы общая ширина таблицы сохранилась.

                       Для
                получения информации о текущей ширине столбца можно использовать свойство Width.

                       Синтаксис:

                       ОbjColumns.Width[=Width]

                       Параметр
                Width (типа Single)
                позволяет указать нужную ширину столбца.

                       Чтобы
                установить одинаковую ширину всех столбцов, необходимо использовать метод DistributeWidth объекта Columns.

                       Objcolumns.DistributeWidth

                       Для
                автоматического подбора ширины столбцов используется метод AutoFit.

                       ObjColumn.AutoFit

                       Для
                удаления строк (столбцов) используется метод Delete.

                       4.Ячейки.

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

                       Синтаксис:

                      
                Set
                objCells = objTables.Rows(key).Cells

                       или

                      
                Set
                objCells=objTables.Columns(key).Cells

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

                        

                       Ссылку
                на определенную ячейку можно получить с помощью метода Cell
                объекта Table.

                       Синтаксис:

                       ObjTable.Cell (Row,Column)

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

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

                Синтаксис:

                ObjCells.Add [(BeforeCell)]

                Параметр BeforeCell
                указывает на ячейку, перед которой должна быть вставлена новая ячейка. Если
                параметр опущен, то ячейка вставляется в конец столбца (строки). Метод
                возвращает ссылку на созданную ячейку.

                Все ячейки таблицы имеют свой уникальный индекс. Для
                получения ссылки на ячейку из определенного семейства используется ее
                порядковый номер: крайняя правая (или верхняя) ячейка имеет номер один, а
                последняя (нижняя) – значение, определяемое свойством Count
                для данного объекта Cells.

                Чтобы узнать положение текущей ячейки в строке или столбце,
                можно использовать свойство RowIndex или ColumnIndex. Оба свойства возвращают ссылку
                на объект типа Cell и предназначены только для
                чтения.

                Для выделения (активизации) текущей ячейки используется
                метод Select.

                Синтаксис:

                objCell.Select

                Для объединения нескольких ячеек в одну (инструмент слияния)
                используется метод Merge.

                Синтаксис:

                ObjCell.Merge (MergeTo)

                Параметр MergeTo  (типа Cell)
                содержит объект типа Cell (ячейка), с которым
                выполняется слияние. Если указана ячейка, не имеющая общей
                границы с текущей, то выполняется слияние всех ячеек, находящихся в
                прямоугольнике, у которого данная ячейка и ячейка, указанная в параметре MergeTo, являются угловыми.

                Для разбиения объединенных ячеек или одной ячейки на
                несколько используется метод Split.

                Синтаксис:

                ObjCell.Split[(NumRows,NumColumns)]

                Параметр NumRows (типа long) содержит значение,
                указывающее на число строк, на которые должна быть разбита данная ячейка.
                Параметр NumColumns (типа long)
                содержит значение, указывающее на число столбцов, на которые должна быть
                разбита данная ячейка.

                Пример:

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

                5.Вычисления.

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

                Для указания ячейке, что в ней будет выполнятся
                вычисление, используется метод Formula
                объекта Cell.

                Синтаксис:

                ObjCell.Formula (Formula, NumFormat)

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

                При использовании стандартных инструментов вставки формул
                эти выражения содержатся в соответствующих полях. Например,
                выражение “=SUM(A4:
                C4)” позволяет отобразить значение,
                получаемое в результате выполнения суммирования значений трех ячеек: А4, В4,
                С4. Кроме непосредственной ссылки на конкретные ячейки можно использовать общие
                ссылки, например на все ячейки, расположенные выше(Above) или левее (Left).

                По умолчанию в таблицах Word можно использовать следующие функции:

                       Abs(X) — возвращает абсолютное значение
                числа или формулы (без знака);

                       And(X;Y) — возвращает значение 1, если оба логических выраже­ния, X и
                У, истинны, или 0 (ноль), если хотя бы одно из них ложно;

                       Average(List) — возвращает среднее значение из
                списка значений List,

                       Count (List) — возвращает
                количество элементов в списке List;

                       Defined(X) — возвращает значение 1, если
                выражение X допустимо, или 0 (ноль), если выражение не может быть
                вычислено;

                       Fal se
                возвращает значение 0 (ноль);

                       Int(X) — возвращает целую часть
                числа или значения формулы X;

                       Min(List) — возвращает наименьшее значение в
                списке List;

                       Max(List) — возвращает наибольшее значение в
                списке List;

                       Mod(X;Y) — возвращает остаток от деления X на Y;

                       Not(X) — возвращает значение 0 (ложь), если
                логическое выражение X истинно, или 1 (истина), если оно ложно;

                       Or(X;Y) — возвращает значение 1 (истина),
                если хотя бы одно  из двух логических
                выражений X и Y
                истинно, или 0 (ложь), если оба  ложны;

                       Product (List) — возвращает произведение
                значений, включенных в список List.
                Например функция «= Product (1,3,7,9)» возвращает значение 189;

                       Round(X; У) — возвращает значение X, округленное до
                указанного десятичного разряда Y;

                       Sign (X) указывает
                знак числа: возвращает значение 1, если X > О, или -1 в противном случае;

                       Sum(List) — возвращает сумму
                значений или формул, включенных в список. List;

                       True — возвращает значение 1.

                       Параметр
                NumFormat,
                является маской, которая определяет формат числовых значений. Эта маска
                может содержать ряд специальных сим­волов, которые приведены ниже.

                       0
                (нуль) — возвращает цифру. Если полученное значение не содер­жит цифру в этой
                позиции, то возвращается 0 (нуль). Например, если имеется выражение типа Formula:=»= 4 + 5″,
                NumFormat:=
                «00,00», то возвращаемое значение будет следующим: «09,00».

                       #
                — возвращает цифру. Если полученное значение не содержит цифру в этой позиции,
                возвращается пробел. Например, Formula:=”=
                11 + 5″, NumFormat:=
                «###» возвращает значение «-15».

                       х — если «х»
                находится слева от десятичного разделителя, цифры расположенные слева от него,
                отбрасываются, а если справа — то значение округляется до указанного знака.
                Например, Formula:=»=
                111053 + 111439″, NumFormat:= «x$$$» возвращает значение «492», а Formula:=»= 1/8″, NumFormat:=
                «0,00x»
                возвращает значение «0,125».

                       .
                или , (десятичный разделитель) —задает
                положение десятичного разделителя. Например, выражение NumFormat:
                = «###, 00») возвращает значение типа «495,47».

                       пробел
                (разделитель групп разрядов) — разделяет число на группы по   три  
                цифры   в   каждой.  
                Например,   выражение   NumForrcat:»###» возвращает значение
                типа «2 456 800».

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

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

                       %,
                $, * и т. д. — включает в значение указанный знак. Например, выражение (NumFormat:=
                «##%») возвращает значение типа «33 %».

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

                       Синтаксис:

                       ObjCell.AutoSum

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

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

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

                Параметр ApplyFont
                указывает, должен ли изменятся шрифт таблицы. Если True, то для текста в таблице будет применен шрифт, предусмотренный
                в применяемом автоформате.

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

                Параметр ApplyHeadingRows
                указывает на необходимость изменения формата заголовков столбцов (первой строки
                таблицы). По умолчанию имеет значение True.

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

                Параметр ApplyFirstColumn
                указывает на необходимость изменение формата первого столбца таблицы. По
                умолчанию имеет значение True.

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

                Параметр AutoFit
                указывает на автоматический подбор ширины столбцов в зависимости от размещаемых
                в них данных. По умолчанию имеет значение True.

                Пример: применяем автоформат Классический2  к таблице, расположенной первой от начала
                активного документа.

                 Тип
                используемого пользовательского форматирования содержится в свойстве AutoFormatType. Свойство возвращает одно из значений
                типа wdTableFormat.

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

                Пример: назначение первой таблице
                в документе оформление границ.

                3.Строки и столбцы.

                Таблица состоит из набора строк и
                столбцов. Строки содержатся в семействе Rows, возвращаемое свойством Rows, а
                столбцы – в семействе Columns, возврщаемое
                свойством Columns.

                Определенная строка или столбец связаны с объектами типа Row или Column. Доступ к конкретной строке или столбцу
                осуществляется с помощью метода Item,
                являющегося для объектов Rows  и Columns методом
                по умолчанию.

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

                Пример: выпадающее окно с
                сообщением о количестве столбцов в таблице 1.

                Для получения ссылок на первую
                или последнюю строку (столбец) можно использовать свойства First и Last.

                Для добавления в таблицу новых
                строк (столбцов) используется метод Add.

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

                Set tabv = ActiveDocument.Tables(1).Rows.Add(beforerow:=ActiveDocument.Tables(1).Rows(1))

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

                параметр RowHeight
                указывает на новую высоту строки в пунктах.

                WdRowHeightAtLeast
                – размер, указанный в параметре RowHeigh, является
                минимальным.

                WdRowHeightAuto
                — размер, указанный в параметре RowHeigh ,является
                точным.

                WdRowHeightExactly
                – автоматический подбор высоты строк (параметр RowHeigh
                игнорируется).

                Получить информацию о текущей
                ширине строки и правиле ее изменения можно с помощью свойств Height и HeightRule.

                Параметр Height
                (тип Single) позволяет задать необходимую высоту
                строки в пунктах.

                   wdRowHeightAtLeast
                — минимальная ширина, которая может быть на­значена строке, указывается в
                свойстве Height;

                   wdRowHeightExactly
                — ширина строки должна быть точно равна зна­чению, указанному в свойстве Height;

                Понравилась статья? Поделить с друзьями:
              • Vba word paragraphformat alignment
              • Vba word выделить все таблицы в word
              • Vba word number of words
              • Vba word выделенный текст в переменную
              • Vba word no spacing