报表生成器FastReport .Net用户指南:脚本示例

FastReport的报表生成器(无论VCL平台还是.NET平台),跨平台的多语言脚本引擎FastScript,桌面OLAP FastCube,如今都被世界各地的开发者所认可,这些名字被等价于“速度”、“可靠”和“品质”,在美国,欧洲和非洲不同国家均设有办事处。FastReports网站有10种不同语言的介绍,FastReports报表拥有40种语言的本地化的信息。

FastReport .Net是一款全功能的Windows Forms、ASP.NET和MVC报表分析解决方案,使用FastReport .NET可以创建独立于应用程序的.NET报表,同时FastReport .Net支持中文、英语等14种语言,可以让你的产品保证真正的国际性。

FastReport.NET官方版下载(qun:585577353)https://www.evget.com/product/1861/download

示例 1.更改对象的外观

在这个示例中,我们将展示如何根据对象中打印的值来更改文本的颜色。我们将使用:

  • BeforePrint 事件;
  • 从脚本中引用数据列。

创建一个具有以下外观的简单报表:

fastreport

选择打印 "UnitPrice "列的对象,并创建 BeforePrint 事件处理程序:

private void Text2_BeforePrint(object sender, EventArgs e) { if (((Decimal)Report.GetColumnValue("Products.UnitPrice")) > 20) Text2.TextColor = Color.Red; }

要在脚本中插入 "Products.UnitPrice "数据列,请从 "Data(数据)"窗口中拖动它。在此过程中,脚本中将添加以下字符串:

((Decimal)Report.GetColumnValue("Products.UnitPrice"))

如果我们运行报告,就会看到所有价格大于 20 的产品都以红色突出显示:

fastreport

利用条件高亮功能也可以达到同样的效果(有关详细信息,请参阅 "创建报告 "一章中的 "条件高亮 "部分)。

示例 2.突出显示条带的偶数行

在本例中,我们将演示如何更改 "Data "带偶数行的填充颜色。我们将使用:

  • BeforePrint 频带事件;
  • 引用脚本中的系统变量 "Row#"。

创建一个具有以下外观的简单报表:

fastreport

为乐队创建 BeforePrint 事件处理程序:

private void Data1_BeforePrint(object sender, EventArgs e) { if (((Int32)Report.GetVariableValue("Row#")) % 2 == 0) Data1.FillColor = Color.Gainsboro; }

Row#"系统变量返回打印条带的行号。要在脚本中插入对该变量的引用,请从 "数据 "窗口中拖动该变量。此时,脚本中将插入一个字符串:

((Int32)Report.GetVariableValue("Row#"))

如果我们运行报告,就会发现偶数行将以浅灰色突出显示:

fastreport

借助 "Data "带的 "EvenStyle "属性也可以达到同样的效果。有关详细信息,请参阅 "创建报表 "一章中的 "突出显示奇数/偶数数据行 "部分。

示例 3.数据过滤

在本例中,我们将展示如何根据给定条件隐藏 "Data "带行。我们将使用:

  • BeforePrint 带事件;
  • 从脚本中引用数据源。

创建一个具有以下外观的简单报表:

fastreport

为band创建 BeforePrint 事件处理程序:

private void Data1_BeforePrint(object sender, EventArgs e) { if (((Decimal)Report.GetColumnValue("Products.UnitPrice")) > 20) Data1.Visible = false; }

在这种情况下,单价大于 20 的波段行将被隐藏:

fastreport

使用 "Data "波段编辑器中设置的数据过滤器也能达到同样的效果。

示例 4.计算总数

在本例中,我们将演示如何使用编程方法计算总和。我们将使用以下方法:

  • BeforePrint 带事件;
  • 引用脚本中的数据列;
  • 局部变量,其值将打印在报表中。

创建以下形式的报告:

fastreport

在脚本中,声明 "sum "变量,并创建属于乐队的 BeforePrint 事件处理程序:

public class ReportScript { private decimal sum; private void Data1_BeforePrint(object sender, EventArgs e) { sum += (Decimal)Report.GetColumnValue("Products.UnitPrice"); } }

可从 "Data "窗口拖动 "Products.UnitPrice "数据列,将其放入脚本中。

运行报告后,您将看到以下内容:

fastreport

使用总数也可以达到同样的效果。

示例 5.移动打印位置

在本例中,我们将演示如何使用引擎对象手动移动印带的位置。我们将使用

  • BeforePrint 打印带事件;
  • 引擎对象。

创建一个外观如下的简单报表:

fastreport

为波段创建 BeforePrint 事件处理程序:

private void Data1_BeforePrint(object sender, EventArgs e) { Engine.CurX = ((Int32)Report.GetVariableValue("Row#")) * 10; }

如果运行该报告,您将看到以下内容:

fastreport

本次关于 FastReport .Net 介绍就讲解到这里了,点击此处查看关于用户指南的更多内容。

上一篇:Python环境下一种改进盲解卷积算法的旋转机械故障诊断模型


下一篇:混合云构建-如何在Azure使用专线连接本地数据中心,使用VPN作为专线的备份线路并自动进行切换