보고서 변수

보고서 변수는 보고서 표현식 위에 구축 된 특수 개체입니다.

보고서 변수는 다음 작업을 단순화합니다-

  • 보고서 템플릿 전체에서 많이 사용되는 보고서 식입니다. 이러한 식은 보고서 변수를 사용하여 한 번만 선언 할 수 있습니다.

  • 보고서 변수는 개수, 합계, 평균, 최저값, 최고 값, 분산 등과 같은 해당 표현식 값을 기반으로 다양한 계산을 수행 할 수 있습니다.

보고서 디자인에 변수가 정의되어 있으면 식의 새 변수에서 이러한 변수를 참조 할 수 있습니다. 따라서 보고서 디자인에서 변수가 선언되는 순서가 중요합니다.

변수 선언

변수 선언은 다음과 같습니다-

<variable name = "CityNumber" class = "java.lang.Integer" incrementType = "Group"
   incrementGroup = "CityGroup" calculation = "Count">
   <variableExpression>
      <![CDATA[Boolean.TRUE]]>
   </variableExpression>
</variable>

위에서 볼 수 있듯이 <variable> 요소에는 여러 속성이 포함됩니다. 이러한 속성은 아래에 요약되어 있습니다.

이름 속성

parametersfields 와 마찬가지로 </ variable> 요소 의 이름 속성은 필수입니다. 보고서 식에서 선언 된 이름으로 변수를 참조 할 수 있습니다.

클래스 속성

클래스 속성은 변수 값에 대한 클래스 이름을 지정도 필수입니다. 기본값은 java.lang.String 입니다. 이는 보고서 컴파일 시간과 보고서 작성 시간 모두에서 클래스 경로에서 사용 가능한 모든 클래스로 변경할 수 있습니다. 엔진은 $ V {} 토큰이 사용되는 보고서 표현식에서 유형 캐스팅을 처리하므로 수동 유형 캐스팅이 필요하지 않습니다.

계산

이 속성은 보고서를 채울 때 변수에 대해 수행 할 계산을 결정합니다. 다음 하위 섹션에서는 <variable> 요소의 계산 속성에 대해 가능한 모든 값을 설명합니다.

  • 평균 -변수 값은 변수 표현식의 모든 널이 아닌 값의 평균입니다. 숫자 변수에만 유효합니다.

  • 개수 -변수 값은 변수 표현식의 null이 아닌 인스턴스의 개수입니다.

  • 첫 번째 -변수 값은 변수 식의 첫 번째 인스턴스 값입니다. 후속 값은 무시됩니다.

  • 최고 -변수 값은 변수 표현식에 대한 가장 높은 값입니다.

  • 최저 -변수 값은 보고서의 변수 표현식에 대한 최저 값입니다.

  • Nothing- 변수에 대해 계산이 수행 되지 않습니다 .

  • StandardDeviation- 변수 값은 보고서 표현식과 일치하는 모든 null이 아닌 값의 표준 편차입니다. 숫자 변수에만 유효합니다.

  • 합계 -변수 값은 보고서 식에 의해 반환 된 모든 비 null 값의 합계입니다.

  • 시스템 -변수 값은 사용자 정의 계산입니다 (JasperReports의 스크립틀릿 기능을 사용하여 해당 변수의 값을 직접 계산).

  • Variance- 변수 값은 보고서 변수의 식의 평가에 의해 반환 된 모든 null이 아닌 값의 분산입니다.

Incrementer FactoryClass

이 속성은 보고서에서 현재 레코드를 채울 때 변수 값을 계산하는 데 사용되는 클래스를 결정합니다. 기본값은 구현하는 모든 클래스입니다.net.sf.jasperreports.engine.fill.JRIncrementerFactory. 팩토리 클래스는 엔진 에서 변수에 설정된 계산 속성 에 따라 런타임에 증분 개체를 인스턴스화하는 데 사용됩니다 .

IncrementType

변수 값을 다시 계산할시기를 결정합니다. 이 속성은 아래와 같이 값을 사용합니다.

  • -변수 값은 각 열의 끝에서 다시 계산됩니다.

  • 그룹 - incrementGroup로 지정한 그룹이 변경 될 때 변수 값이 다시 계산됩니다.

  • 없음 -변수 값은 모든 레코드와 함께 다시 계산됩니다.

  • 페이지 -변수 값은 모든 페이지의 끝에서 다시 계산됩니다.

  • 보고서 -변수 값은 보고서 끝에서 한 번 재 계산됩니다.

IncrementGroup

이것은 incrementTypeGroup 일 때 변수 값이 다시 계산되는 그룹의 이름을 결정합니다 . 이것은 JRXML 보고서 템플릿에 선언 된 그룹의 이름을 사용합니다.

재설정 유형

변수 값이 재설정되는시기를 결정합니다. 이 속성은 아래와 같이 값을 사용합니다.

  • -변수 값은 각 열의 시작 부분에서 재설정됩니다.

  • Group -incrementGroup에 지정된 그룹이 변경되면 변수 값이 재설정됩니다.

  • 없음 -변수 값이 재설정되지 않습니다.

  • 페이지 -변수 값은 모든 페이지의 시작 부분에서 재설정됩니다.

  • 보고서 -변수 값은 보고서 시작시 한 번만 재설정됩니다.

ResetGroup

resetTypeGroup 일 때 변수 값이 재설정되는 그룹의 이름을 결정합니다 . 이 속성의 값은 JRXML 보고서 템플릿에 선언 된 그룹의 이름입니다.

기본 제공 보고서 변수

다음과 같이 표현식에서 사용할 준비가 된 내장 시스템 변수가 있습니다.

S.NO 변수 이름 및 설명
1

PAGE_NUMBER

이 변수의 값은 현재 페이지 번호입니다. JasperReports 텍스트 필드 요소의 특수 기능인 evaluationTime 속성을 사용하여 현재 페이지 번호와 총 페이지 수를 모두 표시하는 데 사용할 수 있습니다 .

2

COLUMN_NUMBER

이 변수는 현재 열 번호를 포함합니다.

REPORT_COUNT

이 보고서 변수에는 처리 된 총 레코드 수가 포함됩니다.

4

PAGE_COUNT

이 변수에는 현재 페이지를 생성 할 때 처리 된 레코드 수가 포함됩니다.

5

COLUMN_COUNT

이 변수에는 현재 열을 생성 할 때 처리 된 레코드 수가 포함됩니다.

6

GroupName_COUNT

이 변수의 이름은 해당 그룹의 이름에서 파생되며 _COUNT 시퀀스가 ​​접미사로 붙습니다. 이 변수에는 현재 그룹의 레코드 수가 포함됩니다.

변수 (countNumber)를 기존 보고서 템플릿 ( 보고서 디자인 장 )에 추가합니다. 각 레코드에 개수를 접두사로 지정합니다. 수정 된 보고서 템플릿 (jasper_report_template.jrxml)은 다음과 같습니다. C : \ tools \ jasperreports-5.0.1 \ test 디렉토리에 저장하십시오-

<?xml version = "1.0"?>
<!DOCTYPE jasperReport PUBLIC
   "//JasperReports//DTD Report Design//EN"
   "http://jasperreports.sourceforge.net/dtds/jasperreport.dtd">

<jasperReport xmlns = "http://jasperreports.sourceforge.net/jasperreports"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://jasperreports.sourceforge.net/jasperreports
   http://jasperreports.sourceforge.net/xsd/jasperreport.xsd"
   name = "jasper_report_template" pageWidth = "595"
   pageHeight = "842" columnWidth = "515"
   leftMargin = "40" rightMargin = "40" topMargin = "50" bottomMargin = "50">
	
   <parameter name = "ReportTitle" class = "java.lang.String"/>
   <parameter name = "Author" class = "java.lang.String"/>

   <queryString>
      <![CDATA[]]>
   </queryString>

   <field name = "country" class = "java.lang.String">
      <fieldDescription>
         <![CDATA[country]]>
      </fieldDescription>
   </field>

   <field name = "name" class = "java.lang.String">
      <fieldDescription>
         <![CDATA[name]]>
      </fieldDescription>
   </field>
   
   <variable name = "countNumber" class = "java.lang.Integer" calculation = "Count">
      <variableExpression>
         <![CDATA[Boolean.TRUE]]>
      </variableExpression>
   </variable>
   
   <title>
      <band height = "70">
         
         <line>
            <reportElement x = "0" y = "0" width = "515" height = "1"/>
         </line>
			
         <textField isBlankWhenNull = "true" bookmarkLevel = "1">
            <reportElement x = "0" y = "10" width = "515" height = "30"/>
            
            <textElement textAlignment = "Center">
               <font size = "22"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{ReportTitle}]]>
            </textFieldExpression>
            
            <anchorNameExpression>
               <![CDATA["Title"]]>
            </anchorNameExpression>
         </textField>
         
         <textField isBlankWhenNull = "true">
            <reportElement  x = "0" y = "40" width = "515" height = "20"/>
            
            <textElement textAlignment = "Center">
               <font size = "10"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{Author}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </title>

   <columnHeader>
      <band height = "23">
         
         <staticText>
            <reportElement mode = "Opaque" x = "0" y = "3" width = "535"	height = "15"
               backcolor = "#70A9A9" />
            
            <box>
               <bottomPen lineWidth = "1.0" lineColor = "#CCCCCC" />
            </box>
            
            <textElement />
				
            <text>
               <![CDATA[]]>
            </text>
         </staticText>
         
         <staticText>
            <reportElement x = "414" y = "3" width = "121" height = "15" />
            
            <textElement textAlignment = "Center" verticalAlignment = "Middle">
               <font isBold = "true" />
            </textElement>
            
            <text><![CDATA[Country]]></text>
         </staticText>
         
         <staticText>
            <reportElement x = "0" y = "3" width = "136" height = "15" />
            
            <textElement textAlignment = "Center" verticalAlignment = "Middle">
               <font isBold = "true" />
            </textElement>
            
            <text><![CDATA[Name]]></text>
         </staticText>
      
      </band>
   </columnHeader>

   <detail>
      <band height = "16">
         
         <staticText>
            <reportElement mode = "Opaque" x = "0" y = "0" width = "535" height = "14"
               backcolor = "#E5ECF9" />
            
            <box>
               <bottomPen lineWidth = "0.25" lineColor = "#CCCCCC" />
            </box>
				
            <textElement />
				
            <text>
               <![CDATA[]]>
            </text>
         </staticText>
         
         <textField>
            <reportElement x = "414" y = "0" width = "121" height = "15" />
            
            <textElement textAlignment = "Center" verticalAlignment = "Middle">
               <font size = "9" />
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$F{country}]]>
            </textFieldExpression>
         </textField>
         
         <textField>
            <reportElement x = "0" y = "0" width = "136" height = "15" />
            <textElement textAlignment = "Center" verticalAlignment = "Middle" />
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA["  " + String.valueOf($V{countNumber}) +"."+$F{name}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>

</jasperReport>

보고서 채우기를위한 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<DataBean> 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<DataBean> getDataBeanList() {
      ArrayList<DataBean> dataBeanList = new ArrayList<DataBean>();

      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과 동일한 디렉토리에 있어야합니다.

<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "viewFillReport" basedir = ".">
   
   <import file = "baseBuild.xml" />
   <target name = "viewFillReport" depends = "compile,compilereportdesing,run"
      description = "Launches the report viewer to preview
      the report stored in the .JRprint file.">
      
      <java classname = "net.sf.jasperreports.view.JasperViewer" fork = "true">
         <arg value = "-F${file.name}.JRprint" />
         <classpath refid = "classpath" />
      </java>
   </target>
   
   <target name = "compilereportdesing" description = "Compiles the JXML file and
      produces the .jasper file.">
      
      <taskdef name = "jrc"
         classname = "net.sf.jasperreports.ant.JRAntCompileTask">
         <classpath refid = "classpath" />
      </taskdef>
      
      <jrc destdir = ".">
         <src>
            <fileset dir = ".">
               <include name = "*.jrxml" />
            </fileset>
         </src>
         <classpath refid = "classpath" />
      </jrc>
   
   </target>
	
</project>

다음으로 명령 줄 창을 열고 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 창이 아래 화면과 같이 열립니다.

여기에서 각 레코드에 대해 개수가 접두사로 붙는 것을 볼 수 있습니다.