![]() |
|
#1
|
|||
|
|||
|
I have created a macro to number the pages of a book according to publishing convention:
- The preliminaries (section 1 of the file) is numbered by Roman numerals (i, ii, iii...x) - Sections 2 to x are numbered by Arabic numerals (1,2,3...500) - The first page of each section is unnumbered The file is divided into 15 sections, and different rules applied to the footers for section 1, section 2 (which switches from Roman to Arabic numbers and has the first page unnumbered), and the remaining sections (where each first page must be unnumbered). The trouble is that this code produces two {PAGE} fields in the footer to each section. Where is this field being created and how do I stop it? Code:
Sub CreatePageRefs()
Application.ScreenUpdating = False
Dim rng As Word.Range, Sec As Word.Section, ft As Word.HeaderFooter
Set Sec = ActiveDocument.Sections(1) 'The first section, in Roman (i, ii, iii)
Set ft = Sec.Footers(wdHeaderFooterPrimary)
Set rng = ft.Range
With ft.PageNumbers
.NumberStyle = wdPageNumberStyleLowercaseRoman
.RestartNumberingAtSection = True
.StartingNumber = 1
.ShowFirstPageNumber = False
End With
rng.Style = wdStyleFooter
rng.ParagraphFormat.Alignment = wdAlignParagraphCenter
rng.Collapse wdCollapseEnd
rng.Fields.Add Range:=rng, Type:=wdFieldPage
Set Sec = ActiveDocument.Sections(2) 'The second section,
'switch to Arabic numbering (1,2,3)
Set ft = Sec.Footers(wdHeaderFooterPrimary)
Set rng = ft.Range
ft.LinkToPrevious = False
With ft.PageNumbers
.NumberStyle = wdPageNumberStyleArabic
.RestartNumberingAtSection = True
.StartingNumber = 1
.ShowFirstPageNumber = False
End With
Dim numOfSections As Integer
numOfSections = ActiveDocument.Sections.Count
For i = 3 To numOfSections 'All remaining sections
' -- restart so that first page number set to "False"
Set Sec = ActiveDocument.Sections(i)
Set ft = Sec.Footers(wdHeaderFooterPrimary)
ft.LinkToPrevious = False
Set rng = ft.Range
With ft.PageNumbers
.NumberStyle = wdPageNumberStyleArabic
.RestartNumberingAtSection = False
.StartingNumber = 1
.ShowFirstPageNumber = False
End With
Next
End Sub
|
| Tags |
| field codes, headers and footers, page numbers |
|
|
Similar Threads
|
||||
| Thread | Thread Starter | Forum | Replies | Last Post |
Page-numbering question: continue numbering from one section to the next? {PAGE} of {SECTIONPAGES}
|
SDwriter | Word | 12 | 10-25-2017 06:56 AM |
How to add page numbering after next page break with landscape and portrait
|
Jashley1 | Word | 2 | 11-25-2014 10:36 PM |
begin each section with page 1 in header PLUS continuous page numbering in footer
|
onemorecupofcoffee | Word | 18 | 09-04-2013 04:31 PM |
Image page numbering macro
|
panel | PowerPoint | 1 | 08-16-2012 06:33 AM |
| Page Header and Page Numbering for Technical Book | SQLUSA | Word | 4 | 06-25-2012 09:53 AM |