DocX在C#中的基本操作方法
用了一个星期把园子里2016年中有关.net的文章都看了,有些只是大致的看了一下,在看的同时也在记录一些通用的方法。发现有很多对NPOI的文档,主要是操作Excl的方法,却很少有关文档类型的方法。
在项目开发中,一般需要对文档进行操作,但是使用微软提供的插件,需要安装一些程序,并且如果使用wps类的文档软件就无法操作了,第三方插件DocX就可以很好的解决这些文档,结合官方提供的文档,稍作修改,总结如下的一些方法:
1.创建一个具有超链接、图像和表的文档:
/// <summary>
/// 创建一个具有超链接、图像和表的文档。
/// </summary>
/// <param name="path">文档保存路径</param>
/// <param name="imagePath">加载的图片路径</param>
public static void HyperlinksImagesTables(string path, string imagePath)
{
// 创建一个文档
using (var document = DocX.Create(path))
{
// 在文档中添加超链接。
var link = document.AddHyperlink("link", new Uri("http://www.google.com"));
// 在文档中添加一个表。
var table = document.AddTable(, );
table.Design = TableDesign.ColorfulGridAccent2;
table.Alignment = Alignment.center;
table.Rows[].Cells[].Paragraphs[].Append("");
table.Rows[].Cells[].Paragraphs[].Append("");
table.Rows[].Cells[].Paragraphs[].Append("");
table.Rows[].Cells[].Paragraphs[].Append("");
var newRow = table.InsertRow(table.Rows[]);
newRow.ReplaceText("", "");
// 将图像添加到文档中。
var image = document.AddImage(imagePath);
//创建一个图片(一个自定义视图的图像)。
var picture = image.CreatePicture();
picture.Rotation = ;
picture.SetPictureShape(BasicShapes.cube);
// 在文档中插入一个新段落。
var title = document.InsertParagraph().Append("Test").FontSize().Font(new FontFamily("Comic Sans MS"));
title.Alignment = Alignment.center;
// 在文档中插入一个新段落。
var p1 = document.InsertParagraph();
// 附加内容到段落
p1.AppendLine("This line contains a ").Append("bold").Bold().Append(" word.");
p1.AppendLine("Here is a cool ").AppendHyperlink(link).Append(".");
p1.AppendLine();
p1.AppendLine("Check out this picture ").AppendPicture(picture).Append(" its funky don't you think?");
p1.AppendLine();
p1.AppendLine("Can you check this Table of figures for me?");
p1.AppendLine();
// 在第1段后插入表格。
p1.InsertTableAfterSelf(table);
// 在文档中插入一个新段落。
Paragraph p2 = document.InsertParagraph();
// 附加内容到段落。
p2.AppendLine("Is it correct?");
// 保存当前文档
document.Save();
}
}
2.设置文档的标题和页脚:
/// <summary>
/// 设置文档的标题和页脚
/// </summary>
/// <param name="path">文档的路径</param>
public static bool HeadersAndFooters(string path)
{
try
{
// 创建新文档
using (var document = DocX.Create(path))
{
// 这个文档添加页眉和页脚。
document.AddHeaders();
document.AddFooters();
// 强制第一个页面有一个不同的头和脚。
document.DifferentFirstPage = true;
// 奇偶页页眉页脚不同
document.DifferentOddAndEvenPages = true;
// 获取本文档的第一个、奇数和甚至是头文件。
Header headerFirst = document.Headers.first;
Header headerOdd = document.Headers.odd;
Header headerEven = document.Headers.even;
// 获取此文档的第一个、奇数和甚至脚注。
Footer footerFirst = document.Footers.first;
Footer footerOdd = document.Footers.odd;
Footer footerEven = document.Footers.even;
// 将一段插入到第一个头。
Paragraph p0 = headerFirst.InsertParagraph();
p0.Append("Hello First Header.").Bold();
// 在奇数头中插入一个段落。
Paragraph p1 = headerOdd.InsertParagraph();
p1.Append("Hello Odd Header.").Bold();
// 插入一个段落到偶数头中。
Paragraph p2 = headerEven.InsertParagraph();
p2.Append("Hello Even Header.").Bold();
// 将一段插入到第一个脚注中。
Paragraph p3 = footerFirst.InsertParagraph();
p3.Append("Hello First Footer.").Bold();
// 在奇数脚注中插入一个段落。
Paragraph p4 = footerOdd.InsertParagraph();
p4.Append("Hello Odd Footer.").Bold();
// 插入一个段落到偶数头中。
Paragraph p5 = footerEven.InsertParagraph();
p5.Append("Hello Even Footer.").Bold();
// 在文档中插入一个段落。
Paragraph p6 = document.InsertParagraph();
p6.AppendLine("Hello First page.");
// 创建一个第二个页面,显示第一个页面有自己的头和脚。
p6.InsertPageBreakAfterSelf();
// 在页面中断后插入一段。
Paragraph p7 = document.InsertParagraph();
p7.AppendLine("Hello Second page.");
// 创建三分之一页面显示,奇偶页不同的页眉和页脚。
p7.InsertPageBreakAfterSelf();
// 在页面中断后插入一段。
Paragraph p8 = document.InsertParagraph();
p8.AppendLine("Hello Third page.");
// 将属性保存入文档
document.Save();
return true;
} }
catch (Exception ex)
{
throw new Exception(ex.Message);
}
//从内存中释放此文档。
}
DocX在C#中的基本操作方法的更多相关文章
- DOM中表格的操作方法总结
DOM中表格的操作方法总结 <table/>元素的方法如下: caption:指向<caption/>元素(如果存在): tBodies:<tbody/>元素的集合 ...
- python中字符串的操作方法
python中字符串的操作方法大全 更新时间:2018年06月03日 10:08:51 作者:骏马金龙 我要评论这篇文章主要给大家介绍了关于python中字符串操作方法的相关资料,文中通过示例代码详细 ...
- table不让td中文字溢出操作方法
table不让td中文字溢出操作方法 table{ width:100px; table-layout:fixed;/* 只有定义了表格的布局算法为fixed,下面td的定义才能起作用. */ } t ...
- 利用java从docx文档中提取文本内容
利用java从docx文档中提取文本内容 使用Apache的第三方jar包,地址为https://poi.apache.org/ docx文档内容如图: 目录结构: 每个文件夹的名称为日期加上来源,例 ...
- ECMAScript 6中的数组操作方法
本文介绍ECMAScript 6即将带给我们新的数组操作方法,以及在怎样在现有浏览器应用这些新的数组特性. Note: 我将使用交替使用构造器(constructor)和类(class)两个术语. 类 ...
- MVC架构下,使用NPOI读取.DOCX文档中表格的内容
1.使用NPOI,可以在没有安装office的设备上读wiod.office.2.本文只能读取.docx后缀的文档.3.MVC架构中,上传文件只能使用form表单提交,转到控制器后要依次实现文件上传. ...
- js中数组的操作方法
今天给大家带来一篇有关数组操作方法的文章. 新建数组 方法一:通过new运算符创建一个数组构造函数. var arr = new Array(); 方法二:通过方括号直接创建直接量数组. var ar ...
- JavaScript中数组的操作方法总汇
Array(数组)是JavaScript中最为常用的类型了.ECMAScript中的数组都是数据的有序列表.数组中可以保存任何类型的数据.数组的大小是可以动态调整的,既可以随着数据的添加自动增长以容纳 ...
- jquery中DOM的操作方法
先介绍几个比较简单的方法,不经常用到,做个记录 1. filter() 方法 顾名思义,filter是一个过滤器,如果给定表示 DOM 元素集合的 jQuery 对象,.filter() 方法会用匹配 ...
随机推荐
- 使用C#和Excel进行报表开发(三)-生成统计图(Chart)
有的Web项目选用Excel作为报表方案,在服务器端生成Excel文件,然后传送到客户端,由客户端进行打印.在国内的环境下,相对PDF方式,Excel的安装率应该比pdf阅读器的安装率要高,同时,微软 ...
- 一些值得练习的github项目
简单粗暴,一晚上用 node.Vue 写个联机五子棋 https://github.com/ccforward/cc/issues/51 Vue2.0实现简易豆瓣电影webApp https://gi ...
- mysql 连接慢的问题(超过了1秒)
http://www.cnblogs.com/isenhome/p/5133547.html 症状描述 本机连接mysql速度很快 远程ping mysql主机速度正常 远程连接mysql速度需要等待 ...
- 用itextsharp打印pdf示例
学习了用itextsharp输出PDF文档,支持用XML定义文档,可定义多个数据源,简单的表达式,用于项目中效果还不错,其中PdfPageEvent类由包大人提供. 示例程序定义了一个简单的xml文件 ...
- 开发便于运维的Windows服务
过去几个月,DevOps on Windows网站推出了一系列文章,详细讲解了开发者应怎样创建便于运维的Windows服务.这一系列文章详细分析了如何克服在运维部门看来最困难的部分:Windows服务 ...
- 发布两款JQ小插件(图片查看器 + 分类选择器),开源
图片查看器,github地址:https://github.com/VaJoy/imgViewer 效果如下: 这款当初大概写了2小时,有点匆忙地赶出来的,使用的接口很简单: $.bindViewer ...
- ENode通信层性能测试结果
测试环境 两台笔记本网线直连,通过测速工具(jperf)测试,确定两台电脑之间的数据传输速度可以达到1Gbps,即千兆网卡的最大速度.两台电脑硬件配置如下: client服务器,CPU:Intel i ...
- Hadoop学习笔记—4.初识MapReduce
一.神马是高大上的MapReduce MapReduce是Google的一项重要技术,它首先是一个编程模型,用以进行大数据量的计算.对于大数据量的计算,通常采用的处理手法就是并行计算.但对许多开发者来 ...
- CSS尺寸和字体单位-em、px还是%
在页面整体布局中,页面元素的尺寸大小(长度.宽度.内外边距等)和页面字体的大小也是重要的工作之一.一个合理设置,则会让页面看起来层次分明,重点鲜明,赏心悦目.反之,一个不友好的页面尺寸和字体大小设置, ...
- SQLSERVER语句 in和exists哪个效率高本人测试证明
SQLSERVR语句 in和exists哪个效率高本人测试证明 最近很多人讨论in和exists哪个效率高,今天就自己测试一下 我使用的是客户的数据库GPOSDB(已经有数据) 环境:SQLSERVE ...