根据NVeloDocx Word模板引擎生成Word(六-结束)

前面几篇已经把E6开发平台配套的Word模版隐藏NVeloDocx的基础用法介绍了一遍,这些基础用法基本上可以完全覆盖实际业务的绝大部分需求。所以我们这一篇就介绍一些边边角角的内容,给本系列来一个首尾。

本篇的主要内容有:

1、汇总计算:比如我们经常遇到的Word报告中的配件清单,需要能够计算总耗时,总费用等等;

2、E6脚本:基于NVeloDocx,我们同样可以使用E6脚本,比如使用E6脚本进行日期格式化,进行金额字段的小写数字转换成中文等等;

3、水印:水印也可以通过NVelocity命令进行填充;

下面我们来一个个进行介绍:

汇总计算:

比如我们在使用子表数据填充Word表格的时候,很多时候需要显示一个汇总行,甚至于某些情况下还需要把金额转换成大写形式,如下图:

子表最后一行是汇总行

那么我们怎么设置这个模板呢?还记得前面《根据NVeloDocx Word模板引擎生成Word(二)》中已经介绍过子表输出到Word表格时的模板语法,这里也是一样的,只不过要汇总我们必须要一个新变量(下图模版中的$total)来保存每个循环的叠加汇总。

模版

变量的定义自然需要再循环开始前进行定义,所以我们在#foreach前定义变量#set($total=0)。

变量的汇总我们在#end前,先把要汇总的字段值取出来赋值给变量$baofei,也可以不用这么做,这么做的原因主要是让后面的汇总命令短一点,不易出错而已。所以下面两种写法都是对的:

第一种:就是上图中的这种:

#set(baofei={child.GetValue($item,"baodanbaofei")})

#set(total={utils.Add($total, $baofei)}) # 这里表示把total变量和保费变量相加后再复制给total

第二种 :直接相加(不建议这种方式)。

#set(total={utils.Add($total, {child.GetValue(item,"baodanbaofei")})})

这里为了实现两个变量相加,我们引入了一个工具方法utils.Add(参数1,参数2) ,为什么要这么做呢?因为如果直接使用#set($total = $total + $baofei)的话,就可能失败,我总觉得这是NVelocity的一个Bug!!!

汇总后要把汇总金额转成大写,通过工具方法{utils.ToCapital(tatal)} 即可,如上面的模版图。


E6脚本

在NVeloDocx模版引擎中也可以使用E6脚本,最常见的比如显示当前日期,比如报告日期就可以使用E6脚本来实现:

报告日期

模版如下:通过工具方法 ${script.Exc("Today()")} 来执行一个E6脚本,其中 "Today()"就是要执行的E6脚本。

模版


水印:

比如要在生成的Word中显示水印信息,当前"用户名+用户编号"这种显然是一个动态的信息,就可以通过设置水印为E6脚本,生成Word时再进行动态计算。

水印效果图

在Word中设置水印的方法:

设置中-水印菜单

选择自定义水印

设置水印"文字"为E6脚本

在水印设置时,就可以设置水印"文字"为执行E6脚本:

${script.Exc("UserName()+UserNO()")}

其中:

UserName():E6脚本,表示当前登录用户的姓名;

UserNO():E6脚本,表示当前登录用户编号;

这样生成的Word文档中,水印就会自动替换成当前操作用户的用户名+用户编号。

总算完结了,给有需要的朋友一个参考。

相关推荐
eybk2 天前
拖放WORD文件朗读全文
开发语言·c#·word
codelife3212 天前
记录word转xml文件踩坑
xml·word
老田低代码2 天前
根据NVeloDocx Word模板引擎生成Word(五)
开发语言·c#·word
xuanyu222 天前
Word使用手册
word
忧郁的蛋~2 天前
asp.net core调用wps实现word转pdf的方法
pdf·word·wps
zhangdabai13 天前
在Word中,用VBA比较两段文本的相似度
word·wps
weixin_457703923 天前
如何设置word页码从指定页开始
word
uolian3 天前
WORD批量转换器MultiDoc Converter
word
老田低代码3 天前
根据NVeloDocx Word模板引擎生成Word(三)
word