📜  报告字段

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


报告字段是元素,代表数据源和报告模板之间的数据映射。可以在报表表达式中组合字段以获得所需的输出。报告模板可以包含零个或多个元素。声明报告字段时,数据源应提供与报告模板中定义的所有字段相对应的数据。

现场申报

字段声明如下所示-


名称属性

元素的name属性是必需的。它按名称引用报表表达式中的字段。

类属性

class属性指定字段值的类名称。其默认值为java.lang.String 。可以将其更改为运行时可用的任何类。不管报告字段的类型如何,引擎都会在使用$ F {}标记的报告表达式中进行转换,因此无需进行手工转换。

栏位说明

元素是可选元素。在实现自定义数据源时,这非常有用。例如,我们可以存储一个键或一些信息,通过它们我们可以在运行时从自定义数据源中检索字段的值。通过使用元素而不是字段名称,可以从数据源中检索字段值时轻松克服字段命名约定的限制。

以下是我们现有的JRXML文件(章报告设计)中的一段代码。在这里,我们可以看到nameclassfieldDescription元素的用法。


   



   

排序字段

在需要数据排序且数据源实现不支持它的时候(例如CSV数据源),JasperReports支持基于内存字段的基于数据的数据源排序。可以使用报告模板中的一个或多个元素进行排序。

如果指定了至少一个排序字段,则在报表填充过程中,数据源将传递到JRSortableDataSource实例。反过来,这将从数据源中获取所有记录,根据指定的字段在内存中执行排序,并替换原始数据源。

排序字段名称应与报告字段名称相同。用于排序的字段应具有实现java.util.Comparable的类型。除java.lang.String类型的字段外,所有字段均进行自然顺序排序(对于String类型,使用与报表填充区域设置相对应的排序规则)。指定多个排序字段时,将使用这些字段作为排序键,并按照它们在报表模板中出现的顺序进行排序。以下示例演示了排序功能。

排序报告示例

让我们将< sortField >元素添加到我们现有的报告模板中(“章”报告设计)。让我们按降序对字段国家/地区进行排序。修改后的报告模板(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报告字段排序示例

在这里,我们可以看到国家名称按字母降序排列。