📜  报告变量

📅  最后修改于: 2020-11-16 07:58:12             🧑  作者: Mango


报表变量是建立在报表表达式之上的特殊对象。

报告变量简化了以下任务-

  • 报告表达式,在整个报告模板中大量使用。这些表达式只能使用报表变量声明一次。

  • 报告变量可以基于相应的表达式值(例如计数,总和,平均值,最低,最高,方差等)执行各种计算。

如果在报表设计中定义了变量,则表达式中的新变量可以引用这些变量。因此,在报表设计中声明变量的顺序很重要。

变量声明

变量声明如下-


   
      
   

如上所示,元素包含许多属性。这些属性总结如下-

名称属性

类似于参数字段元素的name属性是必需的。它允许在报表表达式中通过声明的名称引用变量。

类属性

class属性也是必需的,它指定变量值的类名称。其默认值为java.lang.String 。可以在报告编译时和报告填充时将其更改为类路径中可用的任何类。引擎负责使用$ V {}标记的报表表达式中的类型转换,因此不需要手动类型转换。

计算方式

此属性确定-填充报告时对变量执行哪种计算。以下小节描述了元素的计算属性的所有可能值。

  • 平均值-变量值是变量表达式的每个非空值的平均值。仅对数字变量有效。

  • 计数-变量值是变量表达式的非空实例的计数。

  • First-变量值是变量表达式的第一个实例的值。后续值将被忽略。

  • 最高-变量值是变量表达式的最大值。

  • 最低-变量值是报表中变量表达式的最低值。

  • -没有对该变量执行任何计算。

  • StandardDeviation-变量值是与报表表达式匹配的所有非空值的标准偏差。仅对数字变量有效。

  • 总和-变量值是报表表达式返回的所有非空值的总和。

  • 系统-变量值是一个自定义计算(使用JasperReports的scriptlets功能自己计算该变量的值)。

  • 方差-变量值是通过评估报告变量的表达式返回的所有非空值的方差。

增量器工厂类

此属性确定在报表上填充当前记录时用于计算变量值的类。默认值是实现net.sf.jasperreports.engine.fill.JRIncrementerFactory的任何类。引擎将使用工厂类在运行时实例化增量对象,具体取决于为变量设置的计算属性。

增量类型

这确定了何时重新计算变量的值。此属性使用值,如下所示-

  • -在每一列的末尾重新计算变量值。

  • -由增量组指定的组更改时,将重新计算变量值。

  • -每条记录都会重新计算变量值。

  • 页面-每页末尾都会重新计算变量值。

  • 报告-在报告末尾,变量值将重新计算一次。

增量组

crementTypeGroup时,这确定了在其上重新计算变量值的组的名称。这采用在JRXML报告模板中声明的任何组的名称。

重置类型

这确定何时重置变量的值。此属性使用值,如下所示-

  • -在每列的开头重置变量值。

  • -由增量组指定的组更改时,将重置变量值。

  • -变量值永远不会重置。

  • 页面-变量值在每个页面的开头重置。

  • 报告-变量值仅在报告开头重置一次。

重置组

resetTypeGroup时,它确定要在其上重置变量值的组的名称。该属性的值将是JRXML报告模板中声明的任何组的名称。

内置报告变量

有一些内置的系统变量,可以在表达式中使用,如下所示:

S.NO Variable Name and Description
1

PAGE_NUMBER

This variable’s value is its current page number. It can be used to display both the current page number and the total number of pages using a special feature of JasperReports text field elements, the evaluationTime attribute.

2

COLUMN_NUMBER

This variable contains the current column number.

3

REPORT_COUNT

This report variable contains the total number of records processed.

4

PAGE_COUNT

This variable contains the number of records that were processed when generating the current page.

5

COLUMN_COUNT

This variable contains the number of records that were processed when generating the current column.

6

GroupName_COUNT

The name of this variable is derived from the name of the group it corresponds to, suffixed with the _COUNT sequence. This variable contains the number of records in the current group.

让我们向现有的报告模板(章报告设计)中添加一个变量( countNumber )。我们将计数加到每个记录的前面。修改后的报告模板(jasper_report_template.jrxml)如下。将其保存到C:\ tools \ jasperreports-5.0.1 \ test目录-





    
   
   

   
      
   

   
      
         
      
   

   
      
         
      
   
   
   
      
         
      
   
   
   
      <band height="70">
         
         <line>
            <reportelement x="0" y="0" width="515" height="1"></reportelement>
         </line>
            
         <textfield isblankwhennull="true" bookmarklevel="1">
            <reportelement x="0" y="10" width="515" height="30"></reportelement>
            
            <textelement textalignment="Center">
               <font size="22"></font>
            </textelement>
            
            <textfieldexpression class="java.lang.String">
               
            </textfieldexpression>
            
            <anchornameexpression>
               
            </anchornameexpression>
         </textfield>
         
         <textfield isblankwhennull="true">
            <reportelement x="0" y="40" width="515" height="20"></reportelement>
            
            <textelement textalignment="Center">
               <font size="10"></font>
            </textelement>
            
            <textfieldexpression class="java.lang.String">
               
            </textfieldexpression>
         </textfield>
      
      </band>
   

   
      
         
         
            
            
            
               
            
            
            
                
            
               
            
         
         
         
            
            
            
               
            
            
            
         
         
         
            
            
            
               
            
            
            
         
      
      
   

   
      
         
         
            
            
            
               
            
                
            
                
            
               
            
         
         
         
            
            
            
               
            
            
            
               
            
         
         
         
            
            
            
            
               
            
         
      
      
   


用于报告填充的Java代码保持不变。文件C:\ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint \ JasperReportFill.java的内容如下-

package com.tutorialspoint;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;

import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;

public class JasperReportFill {
   @SuppressWarnings("unchecked")
   public static void main(String[] args) {
      String sourceFileName =
      "C://tools/jasperreports-5.0.1/test/jasper_report_template.jasper";

      DataBeanList DataBeanList = new DataBeanList();
      ArrayList dataList = DataBeanList.getDataBeanList();

      JRBeanCollectionDataSource beanColDataSource =
      new JRBeanCollectionDataSource(dataList);

      Map parameters = new HashMap();
      /**
       * Passing ReportTitle and Author as parameters
       */
      parameters.put("ReportTitle", "List of Contacts");
      parameters.put("Author", "Prepared By Manisha");

      try {
         JasperFillManager.fillReportToFile(
         sourceFileName, parameters, beanColDataSource);
      } catch (JRException e) {
         e.printStackTrace();
      }
   }
}

POJO文件C:\ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint \ DataBean.java的内容如下所示-

package com.tutorialspoint;

public class DataBean {
   private String name;
   private String country;

   public String getName() {
      return name;
   }

   public void setName(String name) {
      this.name = name;
   }

   public String getCountry() {
      return country;
   }

   public void setCountry(String country) {
      this.country = country;
   }
}

文件C:\ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint \ DataBeanList.java的内容如下所示-

package com.tutorialspoint;

import java.util.ArrayList;

public class DataBeanList {
   public ArrayList getDataBeanList() {
      ArrayList dataBeanList = new ArrayList();

      dataBeanList.add(produce("Manisha", "India"));
      dataBeanList.add(produce("Dennis Ritchie", "USA"));
      dataBeanList.add(produce("V.Anand", "India"));
      dataBeanList.add(produce("Shrinath", "California"));

      return dataBeanList;
   }

   /**
    * This method returns a DataBean object,
    * with name and country set in it.
    */
   private DataBean produce(String name, String country) {
      DataBean dataBean = new DataBean();
      dataBean.setName(name);
      dataBean.setCountry(country);
      
      return dataBean;
   }
}

报告生成

我们将使用常规的ANT构建过程来编译并执行上述文件。文件build.xml的内容(保存在目录C:\ tools \ jasperreports-5.0.1 \ test下)如下所示。

导入文件-baseBuild.xml是从“环境设置”一章中选取的,应与build.xml放在同一目录中。



   
   
   
      
      
         
         
      
   
   
   
      
      
         
      
      
      
         
            
               
            
         
         
      
   
   
    

接下来,让我们打开命令行窗口并转到build.xml所在的目录。最后,将命令ant -Dmain-class = com.tutorialspoint.JasperReportFill (viewFullReport是默认目标)执行为-

C:\tools\jasperreports-5.0.1\test>ant -Dmain-class=com.tutorialspoint.JasperReportFill
Buildfile: C:\tools\jasperreports-5.0.1\test\build.xml

clean-sample:
   [delete] Deleting directory C:\tools\jasperreports-5.0.1\test\classes
   [delete] Deleting: C:\tools\jasperreports-5.0.1\test\jasper_report_template.jasper
   [delete] Deleting: C:\tools\jasperreports-5.0.1\test\jasper_report_template.jrprint

compile:
   [mkdir] Created dir: C:\tools\jasperreports-5.0.1\test\classes
   [javac] C:\tools\jasperreports-5.0.1\test\baseBuild.xml:28: warning:
   'includeantruntime' was not set, defaulting to build.sysclasspath=last;
   set to false for repeatable builds
   [javac] Compiling 7 source files to C:\tools\jasperreports-5.0.1\test\classes

compilereportdesing:
   [jrc] Compiling 1 report design files.
   [jrc] log4j:WARN No appenders could be found for logger
   (net.sf.jasperreports.engine.xml.JRXmlDigesterFactory).
   [jrc] log4j:WARN Please initialize the log4j system properly.
   [jrc] log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig
   for more info.
   [jrc] File : C:\tools\jasperreports-5.0.1\test\jasper_report_template.jrxml ... OK.

run:
   [echo] Runnin class : com.tutorialspoint.JasperReportFill
   [java] log4j:WARN No appenders could be found for logger
   (net.sf.jasperreports.extensions.ExtensionsEnvironment).
   [java] log4j:WARN Please initialize the log4j system properly.

viewFillReport:
   [java] log4j:WARN No appenders could be found for logger
   (net.sf.jasperreports.extensions.ExtensionsEnvironment).
   [java] log4j:WARN Please initialize the log4j system properly.

BUILD SUCCESSFUL
Total time: 18 seconds

经过以上编译,JasperViewer窗口打开,如下图所示:

Jasper报告变量示例

在这里,我们看到计数是每个记录的前缀。