学习C#调用OpenXml操作word文档的基本用法(14:学习文档编号定义类)

OpenXml中使用NumberingDefinitionsPart类保存Word文档的列表和编号定义,以便在正文中引用,当在Word文档中创建项目符号列表、编号列表或多级列表时,其格式和规则就存储在该类中。采用解压缩软件打开Word文档,其内的word文件夹中有独立的numbering.xml文件,用于保存文档中使用的编号信息,如下图所示:

  NumberingDefinitionsPart类的Numbering属性保存编号定义,主要包括抽象编号定义 (AbstractNum) 和编号实例定义 (NumberingInstance)两类数据,也即上图中间圈红的w:abstractNum和w:num。
  AbstractNum类定义编号模板,包括编号的外观和行为,主要包括以下属性。虽然AbstractNum类包含完整的编号规则,但不能直接应用于文档正文 。

序号 名称 说明
1 AbstractNumberId 抽象编号定义ID,也即抽象编号的唯一标识符
2 AbstractNumDefinitionName 抽象编号定义名称
3 MultiLevelType 抽象编号定义类型,从枚举值MultiLevelType内取值,包括SingleLevel(单级列表)、Multilevel(多级列表)、HybridMultilevel(混合多级列表)等值
4 Nsid 抽象编号定义标识符,该属性将唯一的十六进制ID关联到父抽象编号定义。对于基于同一初始编号定义的两个抽象编号定义,此数字应相同,如果文档被重新使用,并且基础编号定义已更改,则它应保留其原始 nsid
5 NumberingStyleLink 编号样式参考,可选字符串,该属性指定一抽象编号,该抽象编号不包含其编号类型的实际编号属性,而是充当对存储在文档中的编号样式的引用,该样式应在引用此抽象编号定义时应用,并且本身指向要使用的实际基础抽象编号定义
6 StyleLink 编号样式定义
7 TemplateCode 编号模板代码

AbstractNum类包含Level类集合(可通过调用Elements<Level>函数获取),Level类用于定义编号规则中每个级别的格式,其主要属性包括:

序号 名称 说明
1 LevelIndex 编号级别索引,从0开始
2 TemplateCode 模板代码(GUID),用于模板继承
3 Tentative 是否为暂定级别
4 StartNumberingValue 起始编号值
5 NumberingFormat 编号格式类型,从枚举值NumberFormatValues内取值,如UpperLetter、Ordinal等
6 LevelRestart 重启编号级别索引,该属性指定一个从 1 开始的索引,该索引确定何时应将编号级别索引重新启动到其起始值 。 当指定编号级别的实例(该实例应高于此级别 (在给定文档的内容中使用) )时,将重新启动编号级别。
7 ParagraphStyleIdInLevel 指定与此编号级别关联的段落样式ID
8 IsLegalNumberingStyle 是否使用阿拉伯数字显示所有级别,该属性指定是否应使用十进制数字格式显示给定编号级别文本之前显示的所有级别,而不考虑列表中该级别的实际数字格式
9 LevelSuffix 编号符号和段落文本之间的内容,从枚举值LevelSuffixValues内取值,如Tab、Space等
10 LevelText 编号级别文本,该属性的所有文本应被视为在此编号级别的每个实例中重复的文本文本,但使用百分比符号 (%) 后跟一个数字除外,该数字应用于指示在此级别中使用的数字的从1开始的索引。使用 % 语法时,该级别的每个后续段落的数量应递增, 直到在此级别的两个后续段落之间看到重启级别。举例而言,加入当前编号级别索引为4,编号级别文本为"%1.%2.%3.%4.%5.",其中的%5对应当前级别编号,%4对应上一级别的编号(5-4=1),%3对应上二级别的编号(5-3=2) ,以此类推
11 LevelPictureBulletId 图片项目符号的 ID
12 LegacyNumbering 旧编号级别属性,该属性指定给定的编号级别来自早期的word程序
13 LevelJustification 编号对齐方式,从枚举值LevelJustificationValues内取值,如Left、Center、Right等
14 PreviousParagraphProperties 编号级别关联的段落属性,类型为PreviousParagraphProperties ,其内的属性说明请对照参考文献5
15 NumberingSymbolRunProperties 编号符号的字符格式,类型为NumberingSymbolRunProperties ,其内的属性说明请对照参考文献6

NumberingInstance类定义编号实例,该类通过属性AbstractNumId与抽象编号定义模板关联,同时自身属性NumberID保存实例ID,用于在正文中设置段落编号时引用。
  NumberingInstance类支持添加LevelOverride类集合(可通过调用Elements<LevelOverride>函数获取),LevelOverride类用于在编号实例中覆盖抽象编号的特定级别属性,其主要属性包括:

序号 名称 说明
1 LevelIndex 设置要覆盖的级别索引
2 StartOverrideNumberingValue 设置要覆盖的级别的起始编号值
3 Level 该属性有值时,会完全替换抽象编号中对应编号级别的设置

参考文献

1\]https://github.com/dotnet/Open-XML-SDK \[2\]https://learn.microsoft.com/zh-cn/office/open-xml/open-xml-sdk \[3\]https://learn.microsoft.com/zh-cn/dotnet/api/documentformat.openxml.wordprocessing.style?view=openxml-3.0.1 \[4\]https://blog.csdn.net/i042416/article/details/126228816 \[5\]https://blog.csdn.net/gc_2299/article/details/154045042 \[6\]https://blog.csdn.net/gc_2299/article/details/154043115

相关推荐
chatexcel1 天前
ChatExcel AI文档上线:AI自动生成Word报告的完整工作流
人工智能·word
俊哥工具1 天前
不用安装不收费!多功能U盘修复工具,解决大部分U盘故障
学习·pdf·word·excel·音视频
草丛中的蝈蝈2 天前
word目录中的一级标题编号和标题之间距离很大,但是内容里是正常的
word
Metaphor6922 天前
使用 Python 设置 Word 文档文本的颜色
python·word
usdoc文档预览2 天前
国产化踩坑:Vue3 / React / 小程序如何免插件实现 OFD 及复杂 Office 文档同屏预览
前端·javascript·react.js·小程序·pdf·word·office文件在线预览
一头爱吃肉的牛2 天前
Word转PPT教程:三步用AI工具一键生成
人工智能·word·powerpoint
熟悉的新风景3 天前
word,wps使用技巧
word·wps
2601_958492553 天前
Webmaster Notes: Deploying HTML5 Word Environments
前端·word·html5
wujian83114 天前
AI表格怎么导出word
人工智能·ai·word·豆包·deepseek·ai导出鸭
zh路西法4 天前
【Word自动目录使用指南】告别手动修改格式,一次设置成功!
word