热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用VS2010ReportViewer实现生产良率报表中的行列分组累乘

在过去两周中,我们利用ReportViewer开发了与生产良率相关的报表,其中每个制程的直通率是所有测试项良率的乘积。由于ReportViewer没有内置的累乘函数,因此需要借助自定义代码来实现这一功能。本文将详细介绍实现步骤和相关代码。

在过去两周中,我们使用 ReportViewer 制作了与生产良率相关的报表,其中一个关键指标是每个制程的直通率,它由该制程内所有测试项的良率乘积计算得出。


然而,ReportViewer 并未提供累乘的内置函数。为了实现这一功能,我们参考了 Excel 和网上的技术博客(如 此篇博客),并总结了以下实现步骤和 VB.NET 代码:


步骤一:为报表添加自定义代码


在报表中定义两个公共变量和一个公共函数,用于实现分组累乘:



1     ' 分组乘积
2 Public ProductValue As Double = 1.0
3 ' 分组条件
4 Public CurrentGroupName As String
5
6 ' 根据分组条件,统计组内数据乘积
7 Public Function Product(ByVal ItemValue As Double, ByVal ItemGroupName As String) As Double
8
9 If (String.IsNullOrWhiteSpace(CurrentGroupName)) Then
10 CurrentGroupName = ItemGroupName
11 End If
12 ' 只有该项数值大于零,才有必要统计
13 If (ItemValue > 0) Then
14 ' 同组的数值,进行累乘
15 If (CurrentGroupName = ItemGroupName) Then
16 ProductValue = ProductValue * ItemValue
17
18 Else
19 ' 不同组,重置所有成员变量
20 CurrentGroupName = ItemGroupName
21 ProductValue = ItemValue
22
23 End If
24
25 End If
26 ' 返回数据项的值
27 Return ItemValue
28
29 End Function


步骤二:设置报表字段表达式



  • 编辑良率数据字段表达式,设置为 Code.Product(Fields!YourColumnName.Value, Fields!YourGroupName.Value)

  • 编辑统计结果字段表达式,设置为 Code.ProductValue


保存、编译并通过发布测试后,报表成功实现了所需的累乘功能。


推荐阅读
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • dotnet 通过 Elmish.WPF 使用 F# 编写 WPF 应用
    本文来安利大家一个有趣而且强大的库,通过F#和C#混合编程编写WPF应用,可以在WPF中使用到F#强大的数据处理能力在GitHub上完全开源Elmis ... [详细]
  • 本文介绍如何通过 JavaScript 实现一个基于鼠标坐标的 Tooltip 弹出层,详细解释了如何获取窗口和文档的尺寸及滚动位置,并优化了代码结构。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 自 Node.js 6.3 版本起,调试功能已内置在核心模块中,无需额外安装 node-inspector 等工具。通过简单的命令即可启动调试模式,并利用 Chrome 浏览器进行高效的代码调试。 ... [详细]
  • 本文详细介绍了 org.apache.commons.io.IOCase 类中的 checkCompareTo() 方法,通过多个代码示例展示其在不同场景下的使用方法。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 主板IO用W83627THG,用VC如何取得CPU温度,系统温度,CPU风扇转速,VBat的电压. ... [详细]
  • 简化报表生成:EasyReport工具的全面解析
    本文详细介绍了EasyReport,一个易于使用的开源Web报表工具。该工具支持Hadoop、HBase及多种关系型数据库,能够将SQL查询结果转换为HTML表格,并提供Excel导出、图表显示和表头冻结等功能。 ... [详细]
  • 本文探讨了如何在Classic ASP中实现与PHP的hash_hmac('SHA256', $message, pack('H*', $secret))函数等效的哈希生成方法。通过分析不同实现方式及其产生的差异,提供了一种使用Microsoft .NET Framework的解决方案。 ... [详细]
  • 本文介绍了一个基于 Java SpringMVC 和 SSM 框架的综合系统,涵盖了操作日志记录、文件管理、头像编辑、权限控制、以及多种技术集成如 Shiro、Redis 等,旨在提供一个高效且功能丰富的开发平台。 ... [详细]
  • 本文详细介绍了 Android 开发中 layout_gravity 属性的使用方法及其在不同布局下的效果,旨在帮助开发者更好地理解和利用这一属性来精确控制视图的布局。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 在Oracle数据库中,使用Dbms_Output.Put_Line进行输出调试时,若单行字符超过255个,则会遇到ORA-20000错误。本文介绍了一种有效的方法来处理这种情况,通过创建自定义包和视图,实现对长字符串的分割和正确输出。 ... [详细]
  • 本文介绍了如何通过设置背景形状来轻松地为 Android 的 TextView 添加圆形边框。我们将详细讲解 XML 代码的配置,包括圆角、描边和填充等属性。 ... [详细]
author-avatar
_戒咗微博地_100
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有