[译]在InfoPath的重复表中使用公式去筛选最小值数据

在InfoPath的重复表中使用公式去筛选最小值数据

by S.Y.M. Wong-A-Ton

学习如何在INFOPATH中去使用公式(而不使用代码)去找到重复表中某个栏的最小值并且高亮显示。

 

需求:

当你创建一个重复表,里面包括了一个数字栏,你又想去找到并且高亮显示最小值这些行,怎么呢?

 

解决方案:

可以使用公式和条件格式,去找到这些最小值。

步骤:

示例:

  1. 在InfoPath 2007, 创建一个新的空的模板.
  2. 添加一个重复表,并且这个表包括一个隐藏的栏,(示例为:field2,可以创建3列的重复表,然后删除中间一栏来完成)。
  3. 把表的第一个栏转换成具有日期选取器的控件。
  4. 在数据源面板中,右击myFields节点添加一个节点叫minDate 并且设置这个节点是日期类型,如下图所示
    Repeating table with date and hidden fields and the Main data source in InfoPath Design mode
    Figure 1. Repeating table with date and hidden fields and the Main data source in InfoPath Design mode.

     

  5. 在数据源面板中,双击这个在重复表中你隐藏的那个字段,打开它的属性对话框,在这个示例中这个字段为Field2
  6. 域或组属性对话框中,单击公式按钮,Fx。
  7. 在插入公式对话框,勾选编辑XPath(高级)选择框。.
  8. 在插入公式对话框中,复制、粘贴下面的公式到公式文本框中:

    substring(../my:field1, 9, 2) + ((153 * (substring(../my:field1, 6, 2) + 12 * ((14 - substring(../my:field1, 6, 2)) div 12) - 3) + 2) div 5) + 365 * (substring(../my:field1, 1, 4) + 4800 - ((14 - substring(../my:field1, 6, 2)) div 12)) + ((substring(../my:field1, 1, 4) + 4800 - ((14 - substring(../my:field1, 6, 2)) div 12)) div 4) - 32083

    这里 在第一栏的field1 (是一个日期选择器控件),就是你想找到最小值。

  9. 单击 OK 关闭所有的对话框。
  10. 数据源面板中, 双击 minDate 字段打开它的属性对话框.
  11. 域或组属性 对话框中,单击值文本框后的公式按钮FX
  12. 插入公式对话框中,选择编辑Xpath(高级) 选择框。
  13. 插入公式对话框,复制粘贴如下的公式到公式文本框中:

    ../my:group1/my:group2/my:field1[../my:field2 = xdMath:Min(/my:myFields/my:group1/my:group2/my:field2)]

     

  14. 单击OK 关闭所有找开的窗口
  15. 双击 重复表第一栏的日期选取器控件,打开属性窗口
  16. 日期选取器属性, 选择显示选项卡, 然后单击条件格式.
  17. 条件格式对话框中,单击添加.
  18. 条件格式 对话框, 添加2个条件:

    field1 等于 minDate

    minDate 不为空

     

  19. 条件格式对话框, 选择一个颜色用于底纹,然后单击 OK.
  20. 单击 OK 关闭所有打开对话框。

Selecting the minimum date in a column of a repeating table in InfoPath
Figure 2. Selecting the minimum date in a column of a repeating table in InfoPath.

大功告成!当你添加重复表中的新行,最小的值就会被特别显示出来。

 

 本解决方案对于浏览器兼容的表单同样适用 InfoPath 2007 browser forms.

posted @   dosboy  阅读(1501)  评论(1编辑  收藏  举报
编辑推荐:
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
· .NET 适配 HarmonyOS 进展
· .NET 进程 stackoverflow异常后,还可以接收 TCP 连接请求吗?
· SQL Server统计信息更新会被阻塞或引起会话阻塞吗?
阅读排行:
· 传国玉玺易主,ai.com竟然跳转到国产AI
· 本地部署 DeepSeek:小白也能轻松搞定!
· 自己如何在本地电脑从零搭建DeepSeek!手把手教学,快来看看! (建议收藏)
· 我们是如何解决abp身上的几个痛点
· 普通人也能轻松掌握的20个DeepSeek高频提示词(2025版)
点击右上角即可分享
微信分享提示