学习C#调用OpenXml操作word文档的基本用法(16:学习文档脚注类)

  OpenXml中使用FootnotesPart类保存Word文档内所有脚注的定义和文本。采用解压缩软件打开Word文档,其内的word文件夹中有独立的footnotes.xml文件,用于保存文档中使用的脚注信息,如下图所示。

  FootnotesPart类的Footnotes属性保存脚注集合,其命名空间及类型为DocumentFormat. OpenXml.Wordprocessing.Footnotes,通过调用Footnotes.Elements函数获取DocumentFormat. OpenXml.Wordprocessing.Footnote类型集合,Footnote类保存具体的脚注信息,继承自FootnoteEndnoteType类。
  FootnoteEndnoteType类的主要属性包括Id和Type,前者为脚注唯一ID,用于在文档正文中引用,而后者为脚注类型,包括ContinuationNotice(连续通知)、ContinuationSeparator(连续分隔符)、Normal(普通脚注或尾注)、Separator(分隔符)等,同时可通过Elements函数或GetFirstChild等函数获取脚注内容,可能的内容类型如下所示:

csharp 复制代码
DocumentFormat.OpenXml.Wordprocessing.AltChunk <w:altChunk>
DocumentFormat.OpenXml.Wordprocessing.BookmarkStart <w:bookmarkStart>
DocumentFormat.OpenXml.Wordprocessing.ContentPart <w:contentPart>
DocumentFormat.OpenXml.Wordprocessing.CustomXmlBlock <w:customXml>
DocumentFormat.OpenXml.Wordprocessing.CustomXmlInsRangeEnd <w:customXmlInsRangeEnd>
DocumentFormat.OpenXml.Wordprocessing.CustomXmlDelRangeEnd <w:customXmlDelRangeEnd>
DocumentFormat.OpenXml.Wordprocessing.CustomXmlMoveFromRangeEnd <w:customXmlMoveFromRangeEnd>
DocumentFormat.OpenXml.Wordprocessing.CustomXmlMoveToRangeEnd <w:customXmlMoveToRangeEnd>
DocumentFormat.OpenXml.Office2010.Word.CustomXmlConflictInsertionRangeEnd <w14:customXmlConflictInsRangeEnd>
DocumentFormat.OpenXml.Office2010.Word.CustomXmlConflictDeletionRangeEnd <w14:customXmlConflictDelRangeEnd>
DocumentFormat.OpenXml.Wordprocessing.BookmarkEnd <w:bookmarkEnd>
DocumentFormat.OpenXml.Wordprocessing.CommentRangeStart <w:commentRangeStart>
DocumentFormat.OpenXml.Wordprocessing.CommentRangeEnd <w:commentRangeEnd>
DocumentFormat.OpenXml.Wordprocessing.MoveFromRangeEnd <w:moveFromRangeEnd>
DocumentFormat.OpenXml.Wordprocessing.MoveToRangeEnd <w:moveToRangeEnd>
DocumentFormat.OpenXml.Wordprocessing.MoveFromRangeStart <w:moveFromRangeStart>
DocumentFormat.OpenXml.Wordprocessing.MoveToRangeStart <w:moveToRangeStart>
DocumentFormat.OpenXml.Wordprocessing.Paragraph <w:p>
DocumentFormat.OpenXml.Wordprocessing.PermEnd <w:permEnd>
DocumentFormat.OpenXml.Wordprocessing.PermStart <w:permStart>
DocumentFormat.OpenXml.Wordprocessing.ProofError <w:proofErr>
DocumentFormat.OpenXml.Wordprocessing.InsertedRun <w:ins>
DocumentFormat.OpenXml.Wordprocessing.DeletedRun <w:del>
DocumentFormat.OpenXml.Wordprocessing.MoveFromRun <w:moveFrom>
DocumentFormat.OpenXml.Wordprocessing.MoveToRun <w:moveTo>
DocumentFormat.OpenXml.Office2010.Word.RunConflictInsertion <w14:conflictIns>
DocumentFormat.OpenXml.Office2010.Word.RunConflictDeletion <w14:conflictDel>
DocumentFormat.OpenXml.Wordprocessing.SdtBlock <w:sdt>
DocumentFormat.OpenXml.Wordprocessing.Table <w:tbl>
DocumentFormat.OpenXml.Wordprocessing.CustomXmlInsRangeStart <w:customXmlInsRangeStart>
DocumentFormat.OpenXml.Wordprocessing.CustomXmlDelRangeStart <w:customXmlDelRangeStart>
DocumentFormat.OpenXml.Wordprocessing.CustomXmlMoveFromRangeStart<w:customXmlMoveFromRangeStart>
DocumentFormat.OpenXml.Wordprocessing.CustomXmlMoveToRangeStart<w:customXmlMoveToRangeStart>
DocumentFormat.OpenXml.Office2010.Word.CustomXmlConflictInsertionRangeStart<w14:customXmlConflictInsRangeStart>
DocumentFormat.OpenXml.Office2010.Word.CustomXmlConflictDeletionRangeStart

  下面的代码示例用于获取word文档的脚注及内容:

csharp 复制代码
using (WordprocessingDocument document = WordprocessingDocument.Open(txtFilePath.Text, false))
{
    FootnotesPart fPart = document.MainDocumentPart.FootnotesPart;
    if (fPart != null && fPart.Footnotes != null)
    {
        Footnotes footnotes = fPart.Footnotes;

        // 遍历所有脚注
        foreach (Footnote fn in footnotes.Elements<Footnote>())
        {
            // 获取脚注ID
            Console.WriteLine($"脚注ID: {fn.Id?.Value}");

            // 获取脚注类型
            FootnoteEndnoteValues? footnoteType = fn.Type?.Value;

            // 提取脚注的段落文本内容
            DocumentFormat.OpenXml.Wordprocessing.Paragraph para = fn.GetFirstChild<DocumentFormat.OpenXml.Wordprocessing.Paragraph>();
            if (para != null)
            {
                Console.WriteLine($"内容: {para.InnerText}");
            }
        }
    }
}

  Word文档中的尾注类EndnotesPart的用法与脚注类FootnotesPart极其相似,EndnotesPart类的Endnotes属性保存尾注集合,其命名空间及类型为DocumentFormat.OpenXml.Wordprocessing. Endnotes,通过调用Endnotes.Elements函数获取DocumentFormat.OpenXml.Wordprocessing. Endnote类型集合,Endnote类保存具体的尾注信息,继承自FootnoteEndnoteType类。

参考文献

1https://github.com/dotnet/Open-XML-SDK

2https://learn.microsoft.com/zh-cn/office/open-xml/open-xml-sdk

3https://learn.microsoft.com/zh-cn/dotnet/api/documentformat.openxml.wordprocessing.style?view=openxml-3.0.1

4https://blog.csdn.net/i042416/article/details/126228816

5https://zhuanlan.zhihu.com/p/40256815

相关推荐
qq_5469372717 天前
Excel批量转PDF_Word_图片,支持自动合并报表,效率翻倍。
pdf·word·excel
(Charon)17 天前
【C++ 面试高频:内存管理、RAII 和智能指针详解】
java·开发语言·word
江畔柳前堤18 天前
github实战指南03-Pull Request 全流程实战
开发语言·人工智能·python·深度学习·github·word
2603_9541383918 天前
PDF 转 Word 工具深度评测:从参数解析到实战避坑
pdf·word
知南x18 天前
【DPDK例程学习】(4) l2fwd
学习·word
江畔柳前堤19 天前
github实战指南00-命令在哪里执行?
人工智能·线性代数·oracle·数据挖掘·github·word
江畔柳前堤19 天前
github实战指南05-Fork与开源协作
人工智能·线性代数·oracle·开源·github·word
yivifu19 天前
怎样将Word文档中脚注引用后面的空格轻松删除
word·vba
Sour20 天前
Word 文档翻译后保留格式的检查清单:标题、表格、图片、目录和批注
pdf·word·办公软件·office·文档翻译
qq_4221525720 天前
Word 文件太大怎么压缩?2026 年文档瘦身方案对比
开发语言·c#·word