没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:王香|2018-10-29 09:34:04.000|阅读 340 次
概述:使用FastReport.Net中的Matrix对象中来创建自己的总计。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
相关链接:
FastReport.Net中的Matrix对象执行用于显示汇总表的典型任务。但是,当任务不标准时,只有报表脚本会帮助我们。在脚本本身中,您几乎可以实现任何要求。 如您所知,矩阵具有内置函数,可按字段和列显示总计。通常,汇总表中的总数是金额。如果您想要一个具有您自己的计算公式的总计,该怎么办 如果您想有选择地显示某些列的总计? 要完成所有这些操作,您需要禁用标准总计并创建自己的列,其中将计算总计。但是,如果您仍然使用标准总计,则需要使用AfterTotals矩阵事件使其值也出现在用户总计中。它将在构建具有所有标准结果的矩阵之后发生,以便所有数据都可供我们使用。此事件不允许您向矩阵添加和修改数据,即使用AddValue和SetValue方法。
那么,让我们来看一个例子。 使用简单模板创建矩阵:
要在矩阵中创建维度或指标,您需要将表达式插入相应的单元格中。因为我们从代码填充矩阵,所以我们需要虚拟表达式来创建结构。为此,请从单元格的“Data”面板中放置任何表达式,并使用表达式编辑器清除表达式的文本。 为矩阵创建AfterData事件处理程序。在其中,我们将添加数据:
private void Matrix1_AfterData(object sender, EventArgs e) { Matrix1.AddValue(new Object[] { "January", "Salary" }, new Object[] { "1" }, new Object[] { 1000}); Matrix1.AddValue(new Object[] { "January", "Bonus" }, new Object[] { "1" }, new Object[] { 500}); Matrix1.AddValue(new Object[] { "January", "Penalty" }, new Object[] { "1" }, new Object[] { 200}); Matrix1.AddValue(new Object[] { "February", "Salary" }, new Object[] { "1" }, new Object[] { 1000}); Matrix1.AddValue(new Object[] { "February", "Bonus" }, new Object[] { "1" }, new Object[] { 500}); Matrix1.AddValue(new Object[] { "February", "Penalty" }, new Object[] { "1" }, new Object[] { 200}); Matrix1.AddValue(new Object[] { "February", "Total" }, new Object[] { "1" }, new Object[] { 0}); Matrix1.AddValue(new Object[] { "January", "Salary" }, new Object[] { "2" }, new Object[] { 500}); Matrix1.AddValue(new Object[] { "January", "Bonus" }, new Object[] { "2" }, new Object[] { 300}); Matrix1.AddValue(new Object[] { "January", "Penalty" }, new Object[] { "2" }, new Object[] { 250}); Matrix1.AddValue(new Object[] { "February", "Salary" }, new Object[] { "2" }, new Object[] { 500}); Matrix1.AddValue(new Object[] { "February", "Bonus" }, new Object[] { "2" }, new Object[] { 300}); Matrix1.AddValue(new Object[] { "February", "Penalty" }, new Object[] { "2" }, new Object[] { 250}); Matrix1.AddValue(new Object[] { "February", "Total" }, new Object[] { "2" }, new Object[] { 0});}
在这里,我们为矩阵中的每个单元格添加值。在我们的例子中,这些是两行数据。请注意,我们在2月份仅添加了一项。虽然它的值为零,但很快我们将在AfterTotals事件中计算它。 接下来,我们需要一种获取单元格值的方法:
private float GetValue(int columnIndex) { object value = Matrix1.Data.GetValue(columnIndex, rowIndex, 0); return new Variant(value); }
这很简单 - 我们传递列索引,然后得到值。 我们还需要一个类变量 - rowIndex: private int rowIndex; 现在让我们添加一个为单元格赋值的方法:
private void SetValue(string complexValue, float value) { int columnIndex = Matrix1.Data.Columns.Find(complexValue.Split(';')); Matrix1.Data.SetValue(columnIndex, rowIndex, value); }
现在,让我们继续计算结果。为矩阵添加AfterTotals事件处理程序:
private void Matrix1_AfterTotals(object sender, EventArgs e) { int[] rowIndices = Matrix1.Data.Rows.GetTerminalIndices(); for (int i = 0; i < rowIndices.Length; i++) { rowIndex = rowIndices[i]; int[] columnIndices = Matrix1.Data.Columns.GetTerminalIndices(new Object[] { "February" }); float oplataSum = 0; foreach (int columnIndex in columnIndices) { oplataSum += GetValue(columnIndex); } SetValue("February;Total", oplataSum); } }
在这里,我们得到矩阵行的索引数组。然后,我们循环遍历这些行索引。对于每一行,我们得到一个列索引数组。在列索引的循环中,我们生成了增加的量。最后,我们将收到的金额分配给“二月;总计”单元格。 现在,运行报表:
正如预期的那样,结果是2月组的输出。并且还处理来自“员工”总数的金额。 通过这种方式,我们可以为所需的列和行创建自己的总计。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@wqylolg.cn
DHTMLX 产品支持构建功能丰富的预订系统,从而简化针对不同行业的预约安排。Scheduler 组件丰富的功能(可自定义的日历视图、重复事件等)与 Booking 小部件现成的预订管理 UI 相结合,满足您构建现代化 Web 预订解决方案所需。
在 Excel 中删除重复行对于维护干净、准确和一致的数据集至关重要。在本篇博文中,我们将向您展示如何使用 Python 以编程方式删除 Excel 工作表中的重复行。
无论是零售、物流还是医疗保健,旋转条形码图像的功能都能增强不同应用的灵活性和适应性。使用Aspose.BarCode for Java,您可以轻松旋转条形码图像,确保它们无缝融入应用程序的设计和布局。
借助Aspose.Slides for Java,开发人员可以轻松编辑 PowerPoint 幻灯片(包括表格),以增强演示文稿的效果。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@wqylolg.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢