当前位置: 移动技术网 > IT编程>开发语言>c# > 利用Aspose.Word控件实现Word文档的操作

利用Aspose.Word控件实现Word文档的操作

2019年07月18日  | 移动技术网IT编程  | 我要评论
aspose系列的控件,功能都挺好,之前一直在我的winform开发框架中用aspose.cell来做报表输出,可以实现多样化的报表设计及输出,由于一般输出的内容比较正规化
aspose系列的控件,功能都挺好,之前一直在我的winform开发框架中用aspose.cell来做报表输出,可以实现多样化的报表设计及输出,由于一般输出的内容比较正规化或者多数是表格居多,所以一般使用aspose.cell来实现我想要的各种excel报表输出。虽然一直也知道aspose.word是用来生成word文档的,而且深信其也是一个很强大的控件,但一直没用用到,所以就不是很熟悉。

偶然一次机会,一个项目的报表功能指定需要导出为word文档,因此寻找了很多篇文章,不过多数介绍的比较简单一点,于是也参考了官方的帮助介绍,终于满足了客户的需求。下面我由浅入深来介绍这个控件在实际业务中的使用过程吧。

1、二维表格的word操作
日常中,常见的内容输出就是二维表格的方式,表头比较固定,内容每行一条,那么在实际的使用控件我们该如何操作呢,其实这个控件这方面介绍的文章很多,参考一下就能做出来了。其实介绍这个就是要说明书签的重要性,这个在aspose.cell控件也是如此,书签除了可以用来替换内容,还可以用来标记内容输入的开始位置等等功能。

首先我们在一个空白的word文档中绘制一个表格头,然后再换行的开始插入一个标签引用,插入书签有两种方式,一种是在word(2007、2010)的【插入】-【书签】中插入制定位置的书签引用,如下所示。

一种是在word的自定义快速访问工具栏上添加其他命令,如下步骤所示

前者插入的书签是没有文字或者特别的标记,但是确实存在,后者会插入一个灰色块作为占位符,如下所示,我这这个二维表格的例子里面使用后者进行测试(两者同等效果的)

这样设计好word模板后,下一步就是如何利用代码生成二维表格了。首先这里提示一下,就是我故意设置了每个表格单元格的宽度不同,所以也就要求生成的行要和头部对应,所以表格生成每行之前,肯定要获得对应列的样式属性的,否则就会对应不上了。下面看代码。

复制代码 代码如下:

try
                {
                    aspose.words.document doc = new aspose.words.document(templatefile);
                    aspose.words.documentbuilder builder = new aspose.words.documentbuilder(doc);

                    datatable namelist = datatablehelper.createtable("编号,姓名,时间");
                    datarow row = null;
                    for (int i = 0; i < 50; i++)
                    {
                        row = namelist.newrow();
                        row["编号"] = i.tostring().padleft(4, '0');
                        row["姓名"] = "伍华聪 " + i.tostring();
                        row["时间"] = datetime.now.tostring();
                        namelist.rows.add(row);
                    }

                    list<double> widthlist = new list<double>();
                    for (int i = 0; i < namelist.columns.count; i++)
                    {
                        builder.movetocell(0, 0, i, 0); //移动单元格
                        double width = builder.cellformat.width;//获取单元格宽度
                        widthlist.add(width);
                    }                   

                    builder.movetobookmark("table");        //开始添加值
                    for (var i = 0; i < namelist.rows.count; i++)
                    {
                        for (var j = 0; j < namelist.columns.count; j++)
                        {
                            builder.insertcell();// 添加一个单元格                   
                            builder.cellformat.borders.linestyle = linestyle.single;
                            builder.cellformat.borders.color = system.drawing.color.black;
                            builder.cellformat.width = widthlist[j];
                            builder.cellformat.verticalmerge = aspose.words.tables.cellmerge.none;
                            builder.cellformat.verticalalignment = cellverticalalignment.center;//垂直居中对齐
                            builder.paragraphformat.alignment = paragraphalignment.center;//水平居中对齐
                            builder.write(namelist.rows[i][j].tostring());
                        }
                        builder.endrow();
                    }
                    doc.range.bookmarks["table"].text = "";    // 清掉标示 

                    doc.save(savedocfile);
                    if (messageutil.showyesnoandtips("保存成功,是否打开文件?") == system.windows.forms.dialogresult.yes)
                    {
                        system.diagnostics.process.start(savedocfile);
                    }
                }
                catch (exception ex)
                {
                    loghelper.error(ex);
                    messageutil.showerror(ex.message);
                    return;
                }



以上代码的步骤就是
1)创建aspose.words.document 和 aspose.words.documentbuilder对象,然后生成数据的二维表格内容。
2)遍历模板表格,或者每一列的宽度,以备后用。
3)移动到表格的书签位置,然后开始录入数据,word表格的每个cell都要求制定样式和宽度,这样才能和表格头部吻合。
4)保存文件内容到新的文件里面即可。
输出的效果如下所示。

2、单元格合并的操作

常见的word文件或者excel文件中,都经常看到合并单元格的内容,因此这个部分也是非常常见的操作,必须掌握。

我们先看一个例子代码及效果。

复制代码 代码如下:

try
                {
                    aspose.words.document doc = new aspose.words.document(templatefile);
                    aspose.words.documentbuilder builder = new aspose.words.documentbuilder(doc);

                    builder.insertcell();
                    builder.cellformat.borders.linestyle = linestyle.single;
                    builder.cellformat.borders.color = system.drawing.color.black;
                    builder.cellformat.verticalmerge = cellmerge.first;
                    builder.write("text in merged cells.");

                    builder.insertcell();
                    builder.cellformat.borders.linestyle = linestyle.single;
                    builder.cellformat.borders.color = system.drawing.color.black;
                    builder.cellformat.verticalmerge = cellmerge.none;
                    builder.write("text in one cell");
                    builder.endrow();

                    builder.insertcell();
                    builder.cellformat.borders.linestyle = linestyle.single;
                    builder.cellformat.borders.color = system.drawing.color.black;
                    // this cell is vertically merged to the cell above and should be empty.
                    builder.cellformat.verticalmerge = cellmerge.previous;

                    builder.insertcell();
                    builder.cellformat.borders.linestyle = linestyle.single;
                    builder.cellformat.borders.color = system.drawing.color.black;
                    builder.cellformat.verticalmerge = cellmerge.none;
                    builder.write("text in another cell");
                    builder.endrow();

                    doc.save(savedocfile);
                    if (messageutil.showyesnoandtips("保存成功,是否打开文件?") == system.windows.forms.dialogresult.yes)
                    {
                        system.diagnostics.process.start(savedocfile);
                    }
                }
                catch (exception ex)
                {
                    loghelper.error(ex);
                    messageutil.showerror(ex.message);
                    return;
                }

他的效果如下

关于合并单元格的介绍,你还可以参考下这篇官方介绍:

如果上面的例子还不够明白,ok,我在介绍一个实际的例子,来说明合并单元格的操作模式。

实际文档生成如下所示:

文档的模板如下所示:

其实这个里面的“测试”内容是使用代码写入的,其实就是一行业务数据,用两行来展示,其中有些合并的单元格,这是一个实际项目的表格形式。我们注意到,每行有13个单元格,其中第一、第二、第十三列是合并列。和并列有一个特点,就是它的两个索引都有效,不过只是能使用第一个索引来对它进行操作复制,利用第二个没有用处的。

如第一个列是和并列,它应该有0、13这样的索引,第二列也是和并列,它也有1、14的索引,其他的类推。

了解这样的逻辑关系后,我们看实际操作的代码如下所示。

撰写人:伍华聪

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

  • c# 面试必备线程基础知识点

    c# 面试必备线程基础知识点

    线程的知识太多,知识点有深有浅,往深的研究会涉及操作系统、cpu、内存,往浅了说就是一些语法。没有一定的知识积累,很难把线程的知识写得全面,当然我也没有这个能力... [阅读全文]
  • C#使用System.Net邮件发送功能踩过的坑

    C#使用System.Net邮件发送功能踩过的坑

    1.eazyemail邮件发送类库net 类库自带了邮件发送功能。笔者对该类库,从使用的角度进行了二次封装,nuget上可搜索eazyemail,注入容器时通过... [阅读全文]
  • C#基于Modbus三种CRC16校验方法的性能对比

    C#基于Modbus三种CRC16校验方法的性能对比

    1.背景介绍主要应用场景在物联网中,底端设备注册报文的上报,需要对报文的有效载荷(data)进行crc16的复验,验证与设备端的crc校验是否相等,如果相等,报... [阅读全文]
  • 深入谈谈C#9新特性的实际运用

    前言你一定会好奇:“老周,你去哪开飞机了?这么久没写博客了。”老周:“我买不起飞机,开了个铁矿,挖了一年半的石头。谁知铁矿垮了,压死了几条蜈蚣,什么也没挖着。”... [阅读全文]
  • C# 泛型集合的自定义类型排序的实现

    C# 泛型集合的自定义类型排序的实现

    一、泛型集合list<t>排序经sort方法之后,采用了升序的方式进行排列的。二、对自定义类型进行排序定义一个普通类:接下来,将定义的person实... [阅读全文]
  • C#开发中常用的加密解密方法汇总

    相信很多人在开发过程中经常会遇到需要对一些重要的信息进行加密处理,今天给大家分享我个人总结的一些加密算法:常见的加密方式分为可逆和不可逆两种方式可逆:rsa,a... [阅读全文]
  • C# 如何添加错误日志信息

    系统日志系统日志包含了由windows系统组件记录的事件。例如,在启动期间装入驱动程序或其他系统组件失败被记录到系统日志。要查看系统日志: 打开命令提示符。 ... [阅读全文]
  • 关于C#委托三种调用的分享使用

    关于C#委托三种调用的分享使用

    一、同步调用1、同步调用会按照代码顺序来执行2、同步调用会阻塞线程,如果是要调用一项繁重的工作(如大量io操作),可能会让程序停顿很长时间,造成糟糕的用户体验,... [阅读全文]
  • 用c# 自动更新程序

    作者:冰封一夏出处:hzhcontrols官网:首先看获取和更新的接口更新程序program.cs更新程序界面定义服务端接口,你可以用任意接口都行,我这里用we... [阅读全文]
  • c# 生成二维码的示例

    二维码是越来越流行了,很多地方都有可能是使用到。如果是静态的二维码还是比较好处理的,通过在线工具就可以直接生成一张二维码图片,比如:草料二维码。但有的时候是需要... [阅读全文]
验证码:
移动技术网