图一
解决这个问题办法很多。第一种办法最简单,但比较繁琐,属于“笨办法”,针对只需加入页眉/页脚的空白页:人工检视文档,在必要的地方(也即空白页)插入一些不可见的文本。所谓不可见的文本,就是将普通文本的颜色设置成和底色一样,一般是白色。这样,打印时空白页上不会看到这些文本,不过word不会考虑到这一点,仍会象对待正常页那样在这个“空白”页上打印页眉/页脚。
如果要加入“(本页空白)”之类的文字,一种比较好的办法是利用域构造标准的“节终结文本”。
首先创建一个AutoText自动图文集,使它包含要打印在空白页上的文字,并在自动图文集的开始位置插入一个分页符。为该自动图文集词条指定适当的名称,例如BLANKPAGE。接下来,在每一个节的终结处,紧靠分节符之前,加入下面的复合域(如图二):{ if { =int( {page} / 2 ) * 2 } = { page } " " { autotext "BLANKPAGE" } }。
这组域代码判断当前的页号是奇数还是偶数,根据判断结果决定是否插入名为BLANKPAGE的自动图文集词条。
图二
注意域代码中的花括号(“{”和“}”)是域的标记,不能用输入普通文字的方法输入,每一对花括号必须按一次Ctrl+F9输入。
如果你经常要执行类似的操作,那么最好的办法还是利用word宏。下面的CheckSecPages宏遍历当前文档,对于文档的每一节,计算该节包含的页数,然后判断页数的奇偶性,必要时插入分页符。
Sub CheckSecPages()
Dim iSec As Integer
Dim oRng As Range
Dim iValue As Integer
With ActiveDocument
' 依次处理文档的每一节(最后一节除外)
For iSec = 1 To .Sections.Count - 1
' 创建区域(Range)对象
Set oRng = .Sections(iSec).Range
' 将该区域折叠
' (折叠之后起始位置和结束位置相同)
oRng.Collapse wdCollapseStart