Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/13: Рейтинг темы: голосов - 13, средняя оценка - 4.77
1 / 1 / 0
Регистрация: 27.03.2015
Сообщений: 36
1

Создание структуры на первой странице документа

15.05.2015, 09:27. Показов 2495. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте, есть много документов word, в каждом много заголовков, но нет структуры(содержания) можно ли сделать макрос, чтобы создавать структуру документа автоматически на первом листе?

Добавлено через 22 минуты
запись макросов вот что выводит:
Visual Basic
1
2
3
4
    Application.Templates( _
        "C:\Users\te\AppData\Roaming\Microsoft\Document Building Blocks\1049\15\Built-In Building Blocks.dotx" _
        ).BuildingBlockEntries("Автособираемое оглавления 1").Insert Where:= _
        Selection.Range, RichText:=True
Он работает, но если я буду выполнять на другом компьютере то путь придется менять. От пути как можно избавится?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
15.05.2015, 09:27
Ответы с готовыми решениями:

Вывод подписей на первой странице табличного документа
Всем привет! Делаю печатную форму. В ней шапка, табличная часть, итоги и подписи. Нужно, чтобы...

1с УТ 10.3. Создание документа на основании при проведении другого документа. Реализация механизма перепроведения.
Доброго времени суток, задача стояла при проведении одного документа1, создавался другой документ2...

Автоматическое создание документа на основании другово документа
У меня возникла проблема, как сделать так чтобы при создании Документа1 создавались и заполнялись...

Удаление на каждой странице пол документа
Помогите с документом в нем порядка 1500 страниц и на каждой странице мне нужно только верхняя...

5
5612 / 1596 / 414
Регистрация: 23.12.2010
Сообщений: 2,389
Записей в блоге: 1
15.05.2015, 11:15 2
Лучший ответ Сообщение было отмечено EdoBedo как решение

Решение

Надо было записать макрос другим способом, без использования шаблона:
Visual Basic
1
2
3
4
5
6
7
8
9
With ActiveDocument
    .TablesOfContents.Add Range:=Selection.Range, RightAlignPageNumbers:= _
        True, UseHeadingStyles:=True, UpperHeadingLevel:=1, _
        LowerHeadingLevel:=3, IncludePageNumbers:=True, AddedStyles:="", _
        UseHyperlinks:=True, HidePageNumbersInWeb:=True, UseOutlineLevels:= _
        True
    .TablesOfContents(1).TabLeader = wdTabLeaderDots
    .TablesOfContents.Format = wdIndexIndent
End With
1
1 / 1 / 0
Регистрация: 27.03.2015
Сообщений: 36
15.05.2015, 13:52  [ТС] 3
KoGG, Спасибо, работает!

Добавлено через 1 час 59 минут
KoGG, еще вопрос, вставил код в форму документа, он вставляет на первую страницу вместе с текстом, как сделать чтобы это содержание было только на первой странице, а текст и остальное на следующих
0
5612 / 1596 / 414
Регистрация: 23.12.2010
Сообщений: 2,389
Записей в блоге: 1
15.05.2015, 14:29 4
Лучший ответ Сообщение было отмечено EdoBedo как решение

Решение

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
Selection.HomeKey wdStory
With ActiveDocument
    .TablesOfContents.Add Range:=Selection.Range, RightAlignPageNumbers:= _
        True, UseHeadingStyles:=True, UpperHeadingLevel:=1, _
        LowerHeadingLevel:=3, IncludePageNumbers:=True, AddedStyles:="", _
        UseHyperlinks:=True, HidePageNumbersInWeb:=True, UseOutlineLevels:= _
        True
    .TablesOfContents(1).TabLeader = wdTabLeaderDots
    .TablesOfContents.Format = wdIndexIndent
End With
Selection.Collapse Direction:=wdCollapseEnd
Selection.InsertBreak Type:=wdPageBreak
1
1 / 1 / 0
Регистрация: 27.03.2015
Сообщений: 36
15.05.2015, 15:19  [ТС] 5
KoGG, мой код ниже, выводит выбранный заголовок в новый документ, я вставил ваш код, и при выполнение его, сколько я заголовков вывел, столько и дублируется содержание страниц.
Например я вывел 5 заголовков, и у меня первые пять страниц идет содержание. Можете помочь?
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
36
37
38
39
40
41
42
43
44
 Dim wd As Document
  Dim wd_temp As Document
    Set wd = Documents.Add
    wd.Save
    For i = 0 To ListBox3.ListCount - 1
        Set wd_temp = Documents.Open(ListBox3.List(i, 2) & "\" & ListBox3.List(i, 1))
        wd_temp.Activate
        Selection.GoTo what:=wdGoToHeading, which:=wdGoToAbsolute, Count:=ListBox3.List(i, 3)
        Selection.ExtendMode = True
        Selection.GoTo what:=wdGoToHeading, which:=wdGoToNext
        Selection.Copy
           wd.Activate
     With wd.PageSetup
           .MirrorMargins = True
           .TwoPagesOnOne = False
           .SectionStart = wdSectionNewPage
           .OddAndEvenPagesHeaderFooter = True
           .DifferentFirstPageHeaderFooter = False
     End With
     wd.Sections(1).PageSetup.DifferentFirstPageHeaderFooter = True
        Selection.EndKey Unit:=wdStory
        Selection.Paste
 
              Selection.HomeKey wdStory
With wd
    .TablesOfContents.Add Range:=Selection.Range, RightAlignPageNumbers:= _
        True, UseHeadingStyles:=True, UpperHeadingLevel:=1, _
        LowerHeadingLevel:=3, IncludePageNumbers:=True, AddedStyles:="", _
        UseHyperlinks:=True, HidePageNumbersInWeb:=True, UseOutlineLevels:= _
        True
    .TablesOfContents(1).TabLeader = wdTabLeaderDots
    .TablesOfContents.Format = wdIndexIndent
End With
Selection.Collapse Direction:=wdCollapseEnd
Selection.InsertBreak Type:=wdPageBreak
    wd.Save
    Call wd.Sections.Last.Range.Find.Execute(FindText:="^b", _
                                                     ReplaceWith:="", _
                                                     Replace:=wdReplaceOne)
    
    wd.Save
        wd_temp.Close SaveChanges:=wdDoNotSaveChanges
    Next
   wd.Close
0
5612 / 1596 / 414
Регистрация: 23.12.2010
Сообщений: 2,389
Записей в блоге: 1
15.05.2015, 15:58 6
Лучший ответ Сообщение было отмечено EdoBedo как решение

Решение

Мой блок и wd.Save надо вставить в конце после Next и перед wd.Close
1
15.05.2015, 15:58
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
15.05.2015, 15:58
Помогаю со студенческими работами здесь

Как я оказался на первой странице в Яндексе?
Я тут оказался по слову Дока на первой странице в яндексе. Это глюк, случайность или закономерно?...

Оптимальное количество текста на первой странице ?
Каково ориентировачно оптимальное количество символов на первой странице ?

Обращение ко всем кнопкам на странице документа Word
На странице Word документа есть около 10 кнопок. Как мне с помощью VBA обратиться ко всем этим...

Вывод информации из документа Excel на ASP странице
Люди! У меня есть файл Excel и мне надо бы сделать его доступным для скачивания с асп страницы, а...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru