रिपोर्ट चर

रिपोर्ट चर रिपोर्ट अभिव्यक्ति के शीर्ष पर निर्मित विशेष वस्तुएं हैं।

रिपोर्ट चर निम्नलिखित कार्यों को सरल बनाते हैं -

  • रिपोर्ट अभिव्यक्तियाँ, जो पूरे रिपोर्ट टेम्पलेट में भारी उपयोग की जाती हैं। इन अभिव्यक्तियों को केवल एक बार रिपोर्ट चर का उपयोग करके घोषित किया जा सकता है।

  • रिपोर्ट चर, गणना, योग, औसत, सबसे कम, उच्चतम, भिन्नता आदि जैसे संबंधित भाव मूल्यों के आधार पर विभिन्न गणना कर सकते हैं।

यदि चर को एक रिपोर्ट डिज़ाइन में परिभाषित किया जाता है, तो इन्हें अभिव्यक्तियों में नए चर द्वारा संदर्भित किया जा सकता है। इसलिए, जिस क्रम में रिपोर्ट डिज़ाइन में चर घोषित किए जाते हैं वह महत्वपूर्ण है।

परिवर्तनीय घोषणा

एक चर घोषणा इस प्रकार है -

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

जैसा कि ऊपर देखा गया है, <परिवर्तनीय> तत्व में कई विशेषताएं हैं। इन विशेषताओं को नीचे संक्षेप में प्रस्तुत किया गया है -

नाम का गुण

मापदंडों और क्षेत्रों के समान , </ चर> तत्व का नाम विशेषता अनिवार्य है। यह रिपोर्ट अभिव्यक्तियों में इसके घोषित नाम से चर को संदर्भित करने की अनुमति देता है।

कक्षा की विशेषता

वर्ग विशेषता चर मान के लिए वर्ग के नाम निर्दिष्ट करता है कि यह भी अनिवार्य है। इसका डिफ़ॉल्ट मान java.lang.String है । इसे रिपोर्ट-संकलन समय और रिपोर्ट भरने के समय, दोनों क्लासपाथ में उपलब्ध किसी भी वर्ग में बदला जा सकता है। इंजन रिपोर्ट अभिव्यक्तियों में टाइप-कास्टिंग का ख्याल रखता है जो $ V {} टोकन का उपयोग किया जाता है, इसलिए मैनुअल टाइप-कास्टिंग की आवश्यकता नहीं होती है।

गणना

यह विशेषता निर्धारित करती है - रिपोर्ट भरते समय चर पर क्या गणना करें। निम्नलिखित उपधारा <चर> तत्व की गणना विशेषता के लिए सभी संभावित मानों का वर्णन करती है।

  • औसत - चर मान, चर अभिव्यक्ति के प्रत्येक गैर-शून्य मान का औसत है। केवल संख्यात्मक चर के लिए मान्य।

  • गणना - चर मान, चर अभिव्यक्ति के गैर-शून्य उदाहरणों की गिनती है।

  • पहला - वेरिएबल वैल्यू वेरिएबल एक्सप्रेशन के पहले उदाहरण का वैल्यू है। इसके बाद के मूल्यों की अनदेखी की जाती है।

  • उच्चतम - चर का मान चर अभिव्यक्ति के लिए उच्चतम मूल्य है।

  • निम्नतम - चर मान रिपोर्ट में चर अभिव्यक्ति के लिए सबसे कम मूल्य है।

  • कुछ भी नहीं - चर पर कोई गणना नहीं की जाती है।

  • StandardDeviation - चर मान रिपोर्ट अभिव्यक्ति से मेल खाते सभी गैर-शून्य मानों का मानक विचलन है। केवल संख्यात्मक चर के लिए मान्य।

  • Sum - चर मान रिपोर्ट अभिव्यक्ति द्वारा लौटाए गए सभी गैर-शून्य मानों का योग है।

  • सिस्टम - चर मूल्य एक कस्टम गणना है (उस चर के लिए मूल्य की गणना, जैस्पररीपोर्ट्स की स्क्रिप्ट की कार्यक्षमता का उपयोग करके)।

  • विचरण - चर मूल्य रिपोर्ट चर की अभिव्यक्ति के मूल्यांकन द्वारा लौटाए गए सभी गैर-शून्य मान के विचरण है।

इंक्रीमेंटर फैक्ट्रीक्लास

यह विशेषता रिपोर्ट पर वर्तमान रिकॉर्ड भरते समय चर के मूल्य की गणना करने के लिए उपयोग किए जाने वाले वर्ग को निर्धारित करती है। डिफ़ॉल्ट मूल्य किसी भी वर्ग को लागू करना होगाnet.sf.jasperreports.engine.fill.JRIncrementerFactory। फैक्ट्री क्लास का उपयोग इंजन द्वारा रनवे पर गणना की विशेषता के आधार पर रनटाइम पर इंक्रीमेंटर ऑब्जेक्ट्स को त्वरित करने के लिए किया जाएगा।

IncrementType

यह निर्धारित करता है कि कब चर के मूल्य को पुनर्गणना करना है। यह विशेषता नीचे दिए गए मानों का उपयोग करती है -

  • कॉलम - चर मान प्रत्येक कॉलम के अंत में पुनर्गणना किया जाता है।

  • समूह - परिवर्ती समूह द्वारा निर्दिष्ट समूह में परिवर्तन होने पर परिवर्तनशील मान पुन: परिकलित होता है।

  • कोई नहीं - चर मान हर रिकॉर्ड के साथ पुनर्गणना है।

  • पृष्ठ - चर मूल्य हर पृष्ठ के अंत में पुनर्गणना है।

  • रिपोर्ट - रिपोर्ट के अंत में परिवर्तनीय मूल्य को एक बार पुनर्गणना किया जाता है।

IncrementGroup

इस समूह में, जिस पर चर मूल्य पुनर्गणना की जाती है, जब के नाम निर्धारित करता है incrementType है समूह । यह JRXML रिपोर्ट टेम्पलेट में घोषित किसी भी समूह का नाम लेता है।

ResetType

यह निर्धारित करता है कि एक चर का मान रीसेट कब होता है। यह विशेषता नीचे दिए गए मानों का उपयोग करती है -

  • कॉलम - चर मूल्य प्रत्येक कॉलम की शुरुआत में रीसेट किया जाता है।

  • समूह - चर मान को रीसेट किया जाता है जब incrementGroup द्वारा निर्दिष्ट समूह बदलता है।

  • कोई नहीं - चर मान कभी भी रीसेट नहीं होता है।

  • पृष्ठ - चर मूल्य हर पृष्ठ की शुरुआत में रीसेट किया जाता है।

  • रिपोर्ट - चर मूल्य केवल एक बार रिपोर्ट की शुरुआत में रीसेट किया जाता है।

ResetGroup

इस समूह में, जिस पर चर मूल्य, रीसेट किया जाता है जब के नाम निर्धारित करता है resetType है समूह । इस विशेषता के मान JRXML रिपोर्ट टेम्पलेट में घोषित किसी भी समूह का नाम होगा।

बिल्ट-इन रिपोर्ट वेरिएबल्स

कुछ अंतर्निहित सिस्टम चर हैं, जो अभिव्यक्तियों में उपयोग करने के लिए तैयार हैं, निम्नानुसार हैं -

S.NO परिवर्तनीय नाम और विवरण
1

PAGE_NUMBER

इस चर का मान इसकी वर्तमान पृष्ठ संख्या है। इसका उपयोग वर्तमान पृष्ठ संख्या और पृष्ठों की कुल संख्या को प्रदर्शित करने के लिए किया जा सकता है, जो जैस्पररिपोर्ट्स पाठ क्षेत्र तत्वों की एक विशेष विशेषता का उपयोग कर मूल्यांकन करता है।

2

COLUMN_NUMBER

इस चर में वर्तमान कॉलम संख्या है।

3

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>

रिपोर्ट भरने के लिए जावा कोड अपरिवर्तित रहता है। फ़ाइल की सामग्री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

उपरोक्त संकलन के परिणामस्वरूप, नीचे स्क्रीन के रूप में एक जैस्पर व्यूअर विंडो खुलती है -

यहाँ, हम देखते हैं कि गिनती प्रत्येक रिकॉर्ड के लिए उपसर्ग है।