• 根据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文档中,水印就会自动替换成当前操作用户的用户名+用户编号。

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

  • 相关阅读:
    开放式激光振镜运动控制器(二):ZMC408SCAN激光接口与控制
    【Flutter】Flutter 使用 RxDart 实现异步编程
    java-net-php-python-ssm公交查询系统计算机毕业设计程序
    【状态估计】将Transformer和LSTM与EM算法结合到卡尔曼滤波器中,用于状态估计(Python代码实现)
    数据宝董事长汤寒林分享保险行业数据产品场景案例
    Element UI + tree组件 + 面包屑 实现导航
    C++入门学习(3)函数重载
    abc324 e
    C++/Qt音视频通话开发MetaRTC源码解读,音频推流和拉流
    6 JS 和 Jquery 删除标签元素
  • 原文地址:https://blog.csdn.net/RonoTian/article/details/142264366