博客
关于我
Java 添加Word目录的2种方法
阅读量:413 次
发布时间:2019-03-06

本文共 3079 字,大约阅读时间需要 10 分钟。

目录是一种能够快速、有效地帮助读者了解文档或书籍主要内容的方式。在Word中,插入目录首先需要设置相应段落的大纲级别,根据大纲级别来生成目录表。本文中生成目录分2种情况来进行:

1.文档没有设置大纲级别,生成目录前需要手动设置

2.文档已设置大纲级别,通过域代码生成目录

 

使用工具:

  • Free Spire.Doc for Java (免费版)
  • IntelliJ IDEA

工具获取途径1:通过jar文件包,解压并导入jar文件到IDEA程序。

工具获取途径2:通过Maven仓库导入到Maven项目中,参考。

 

Java示例代码(供参考)

【示例1】手动设置大纲级别并生成目录

import com.spire.doc.*;import com.spire.doc.documents.BuiltinStyle;import com.spire.doc.documents.HorizontalAlignment;import com.spire.doc.documents.Paragraph;import com.spire.doc.fields.TextRange;import java.awt.*;public class AddToc {    public static void main(String[]args){        //加载测试文档        Document doc = new Document("test.docx");        //在文档最前面插入一个段落,写入文本并格式化        Paragraph parainserted = new Paragraph(doc);        TextRange tr= parainserted.appendText("目 录");        tr.getCharacterFormat().setBold(true);        tr.getCharacterFormat().setTextColor(Color.gray);        doc.getSections().get(0).getParagraphs().insert(0,parainserted);        parainserted.getFormat().setHorizontalAlignment(HorizontalAlignment.Center);                //设置文档中指定段落的大纲级别        doc.getSections().get(0).getParagraphs().get(2).applyStyle(BuiltinStyle.Heading_1);        doc.getSections().get(0).getParagraphs().get(3).applyStyle(BuiltinStyle.Heading_2);        doc.getSections().get(0).getParagraphs().get(5).applyStyle(BuiltinStyle.Heading_2);        doc.getSections().get(0).getParagraphs().get(7).applyStyle(BuiltinStyle.Heading_2);        doc.getSections().get(0).getParagraphs().get(13).applyStyle(BuiltinStyle.Heading_2);        doc.getSections().get(0).getParagraphs().get(14).applyStyle(BuiltinStyle.Heading_3);        doc.getSections().get(0).getParagraphs().get(15).applyStyle(BuiltinStyle.Heading_3);        //添加目录        doc.getSections().get(0).getParagraphs().get(0).appendTOC(1,3);        //更新目录表        doc.updateTableOfContents();        //保存文档        doc.saveToFile("AddToc.docx",FileFormat.Docx_2010);    }}

目录生成效果:

 

 

【示例2】已设置大纲级别,通过域代码直接生成目录

import com.spire.doc.Document;import com.spire.doc.FileFormat;import com.spire.doc.documents.HorizontalAlignment;import com.spire.doc.documents.Paragraph;import com.spire.doc.fields.TableOfContent;import com.spire.doc.fields.TextRange;import java.awt.*;public class AddTOC2 {    public static void main (String[] args){        //加载已设置大纲级别的测试文档        Document doc = new Document("sample.docx");        //在文档最前面插入一个段落,写入文本并格式化        Paragraph parainserted = new Paragraph(doc);        TextRange tr= parainserted.appendText("目 录");        tr.getCharacterFormat().setBold(true);        tr.getCharacterFormat().setTextColor(Color.gray);        doc.getSections().get(0).getParagraphs().insert(0,parainserted);        parainserted.getFormat().setHorizontalAlignment(HorizontalAlignment.Center);        //通过域代码添加目录表        TableOfContent toc = new TableOfContent(doc, "{\\o \"1-3\" \\h \\z \\u}");        doc.getSections().get(0).getParagraphs().get(0).appendTOC(1,3);        doc.updateTableOfContents();        //保存文档        doc.saveToFile("AddToc2.docx", FileFormat.Docx_2010);    }}

目录生成效果:

 

PS:关于通过域代码生成目录,可参考,获取更多目录设置方法

 

转载请注明出处!

 (本文完)

 

你可能感兴趣的文章
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>