用OpenXml SDK 2.0 创建一个页脚带页码的Word文档

2024-04-30 07:48

本文主要是介绍用OpenXml SDK 2.0 创建一个页脚带页码的Word文档,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实现环境:Visual Studio 2010, OpenXml SDK 2.0.50727

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using DocumentFormat.OpenXml;
using DocumentFormat.OpenXml.Packaging;
using DocumentFormat.OpenXml.Wordprocessing;namespace OpenXmlFooterPageNumber
{public partial class Form1 : Form{public Form1(){InitializeComponent();}private void button1_Click(object sender, EventArgs e){SaveFileDialog objSaveFileDialog = new SaveFileDialog();objSaveFileDialog.Filter = "Word Document (*.docx)|*.docx";objSaveFileDialog.ShowDialog();string strSavePath = objSaveFileDialog.FileName;if (strSavePath.Length > 0){using (WordprocessingDocument objWordprocessingDocument =WordprocessingDocument.Create(strSavePath, WordprocessingDocumentType.Document)){MainDocumentPart objMainDocumentPart =objWordprocessingDocument.AddMainDocumentPart();Document objDocument = new Document();objMainDocumentPart.Document = objDocument;Body objBody = new Body();SectionProperties objSectionProperties = new SectionProperties();FooterPart objFootPart = objMainDocumentPart.AddNewPart<FooterPart>();Footer objFooter = new Footer();objFootPart.Footer = objFooter;SdtBlock objSdtBlock_1 = new SdtBlock();SdtContentBlock objSdtContentBlock_1 = new SdtContentBlock();SdtBlock objSdtBlock_2 = new SdtBlock();SdtContentBlock objSdtContentBlock_2 = new SdtContentBlock();Paragraph objParagraph_1 = new Paragraph();ParagraphProperties objParagraphProperties = new ParagraphProperties();ParagraphStyleId objParagraphStyleId =new ParagraphStyleId() { Val = "Footer" };objParagraphProperties.Append(objParagraphStyleId);Justification objJustification = new Justification() { Val = JustificationValues.Right };objParagraphProperties.Append(objJustification);objParagraph_1.Append(objParagraphProperties);Run objRun_1 = new Run();Text objText_1 = new Text();objText_1.Text = "Page ";objRun_1.Append(objText_1);objParagraph_1.Append(objRun_1);Run objRun_2 = new Run();FieldChar objFieldChar_1 = new FieldChar() { FieldCharType = FieldCharValues.Begin };objRun_2.Append(objFieldChar_1);objParagraph_1.Append(objRun_2);Run objRun_3 = new Run();FieldCode objFieldCode_1 = new FieldCode() { Space = SpaceProcessingModeValues.Preserve };objFieldCode_1.Text = "PAGE ";objRun_3.Append(objFieldCode_1);objParagraph_1.Append(objRun_3);Run objRun_4 = new Run();FieldChar objFieldChar_2 = new FieldChar() { FieldCharType = FieldCharValues.Separate };objRun_4.Append(objFieldChar_2);objParagraph_1.Append(objRun_4);Run objRun_5 = new Run();Text objText_2 = new Text();objText_2.Text = "2";objRun_5.Append(objText_2);objParagraph_1.Append(objRun_5);Run objRun_6 = new Run();FieldChar objFieldChar_3 = new FieldChar() {FieldCharType = FieldCharValues.End };objRun_6.Append(objFieldChar_3);objParagraph_1.Append(objRun_6);Run objRun_7 = new Run();Text objText_3 = new Text();objText_3.Text = "of ";objRun_7.Append(objText_3);objParagraph_1.Append(objRun_7);Run objRun_8 = new Run();FieldChar objFieldChar_4 = new FieldChar() { FieldCharType = FieldCharValues.Begin };objRun_8.Append(objFieldChar_4);objParagraph_1.Append(objRun_8);Run objRun_9 = new Run();FieldCode objFieldCode_2 = new FieldCode() { Space = SpaceProcessingModeValues.Preserve };objFieldCode_2.Text = "NUMPAGES  ";objRun_9.Append(objFieldCode_2);objParagraph_1.Append(objRun_9);Run objRun_10 = new Run();FieldChar objFieldChar_5 = new FieldChar() { FieldCharType = FieldCharValues.Separate };objRun_10.Append(objFieldChar_5);objParagraph_1.Append(objRun_10);Run objRun_11 = new Run();Text objText_4 = new Text();objText_4.Text = "2";objRun_11.Append(objText_4);objParagraph_1.Append(objRun_11);Run objRun_12 = new Run();FieldChar objFieldChar_6 = new FieldChar() {FieldCharType = FieldCharValues.End };objRun_12.Append(objFieldChar_6);objParagraph_1.Append(objRun_12);objSdtContentBlock_2.Append(objParagraph_1);objSdtBlock_2.Append(objSdtContentBlock_2);objSdtContentBlock_1.Append(objSdtBlock_2);objSdtBlock_1.Append(objSdtContentBlock_1);objFooter.Append(objSdtBlock_1);string strFootrID =objMainDocumentPart.GetIdOfPart(objFootPart);FooterReference objFooterReference = new FooterReference() { Type = HeaderFooterValues.Default, Id = strFootrID };objSectionProperties.Append(objFooterReference);objBody.Append(objSectionProperties);objMainDocumentPart.Document.Append(objBody);DocumentSettingsPart objDocumentSettingPart =objMainDocumentPart.AddNewPart<DocumentSettingsPart>();objDocumentSettingPart.Settings = new Settings();Compatibility objCompatibility = new Compatibility();CompatibilitySetting objCompatibilitySetting =new CompatibilitySetting(){Name = CompatSettingNameValues.CompatibilityMode,Uri = "http://schemas.microsoft.com/office/word",Val = "14"};objCompatibility.Append(objCompatibilitySetting);objDocumentSettingPart.Settings.Append(objCompatibility);}}}}
}
相关资源: http://download.csdn.net/detail/tx_officedev/3972762

这篇关于用OpenXml SDK 2.0 创建一个页脚带页码的Word文档的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/948286

相关文章

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

Python创建Excel的4种方式小结

《Python创建Excel的4种方式小结》这篇文章主要为大家详细介绍了Python中创建Excel的4种常见方式,文中的示例代码简洁易懂,具有一定的参考价值,感兴趣的小伙伴可以学习一下... 目录库的安装代码1——pandas代码2——openpyxl代码3——xlsxwriterwww.cppcns.c

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超