रिपोर्ट अनुभाग

हमने प्रारंभ हो रहे अध्याय में एक साधारण रिपोर्ट टेम्पलेट की संरचना पर चर्चा की । इसी तरह की तर्ज पर, जैस्पररीपोर्ट्स रिपोर्ट टेम्पलेट को कई वर्गों में विभाजित करता है। अनुभाग उस रिपोर्ट के भाग होते हैं, जिसमें एक निर्दिष्ट ऊँचाई होती है और इसमें रेखाएँ, आयत, चित्र या पाठ फ़ील्ड जैसी रिपोर्ट ऑब्जेक्ट हो सकते हैं।

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

जैस्परपोर्ट में, शब्दावली और रिपोर्ट अनुभाग भी कहे जाते हैं report bands। अनुभाग एक या अधिक बैंड से बने होते हैं। ये अनुभाग रिपोर्ट-जनरेटिंग समय पर बार-बार भरे जाते हैं और अंतिम दस्तावेज तैयार करते हैं।

मुख्य खंड

जैस्परपरपोर्ट्स में एक रिपोर्ट टेम्पलेट में निम्नलिखित मुख्य भाग हैं -

<title></title>

<pageheader></pageheader>

<columnheader></columnheader>

<groupheader></groupheader>

<detail></detail>

<groupfooter></groupfooter>

<columnfooter></columnfooter>

<pagefooter></pagefooter>

<lastpagefooter></lastpagefooter>

<summary></summary>

<nodata></nodata>

<background></background>

निम्न तालिका प्रत्येक अनुभाग को सारांशित करती है -

S.NO अनुभाग और विवरण
1

Title

यह खंड रिपोर्ट की शुरुआत में केवल एक बार दिखाई देता है।

2

Page Header

यह खंड उत्पन्न दस्तावेज़ में प्रत्येक पृष्ठ की शुरुआत में दिखाई देता है।

3

Column Header

यह खंड उत्पन्न दस्तावेज़ में प्रत्येक कॉलम की शुरुआत में दिखाई देता है। यदि रिपोर्ट में केवल एक स्तंभ परिभाषित है, तो स्तंभ शीर्ष लेख और पाद लेख अनुभागों को अनदेखा कर दिया जाता है।

4

Group Header

यह खंड एक रिपोर्ट समूह (अध्याय समूह ) द्वारा पेश किया गया है । हर बार जब समूह की अभिव्यक्ति अपना मान बदलती है, तो समूह शीर्ष लेख अनुभाग विवरण अनुभाग के ऊपर मुद्रित होता है। मामले में, यदि एक से अधिक समूह को परिभाषित किया गया है, तो समूह हेडर को समूह परिभाषा के क्रम में मुद्रित किया जाता है।

5

Detail

यह खंड रिपोर्ट के डेटा स्रोत द्वारा आपूर्ति किए गए डेटा की प्रत्येक पंक्ति के लिए दोहराया जाता है। डिटेल सेक्शन कई बैंड से बना हो सकता है।

6

Group Footer

यह खंड एक रिपोर्ट समूह (अध्याय समूह ) द्वारा पेश किया गया है । समूहीकरण अभिव्यक्ति के मूल्य में परिवर्तन से पहले समूह पाद लेख खंड विस्तार खंड के नीचे मुद्रित होता है। समूह पाद लेख हमेशा डेटा स्रोत में डेटा की अंतिम पंक्ति के लिए मुद्रित किया जाता है। यदि एक से अधिक समूह को परिभाषित किया जाता है तो, समूह पाद लेख समूह की परिभाषा के विपरीत क्रम में मुद्रित होता है।

7

Column Footer

यह अनुभाग प्रत्येक कॉलम के नीचे दिखाई देता है। यदि रिपोर्ट का कॉलम काउंट 1 है, तो कॉलम हेडर और फूटर सेक्शन को नजरअंदाज कर दिया जाता है।

8

Page Footer

यह अनुभाग प्रत्येक पृष्ठ के निचले भाग में दिखाई देता है।

9

Last Page Footer

यह अनुभाग रिपोर्ट के अंतिम पृष्ठ पर नियमित पृष्ठ पाद लेख को प्रतिस्थापित करता है। मामले में, सारांश अनुभाग भी मौजूद है, तो यह दस्तावेज़ का अंतिम पृष्ठ नहीं हो सकता है। जब कभी सारांश जानकारी अंतिम पृष्ठ के नीचे प्रदर्शित करनी होती है तो यह खंड कभी-कभी उपयोगी होता है।

10

Summary

यह अनुभाग रिपोर्ट के अंत में केवल एक बार दिखाई देता है।

1 1

No Data

यह अनुभाग तब मुद्रित किया जाता है, जब कोई डेटा प्रिंट रिपोर्ट संपत्ति नहीं डेटा अनुभाग पर सेट की जाती है । यदि रिपोर्ट टेम्पलेट में <noData> अनुभाग को परिभाषित किया गया है, और यदि डेटा स्रोत खाली है, तो <noData> अनुभाग को भरने के समय केवल एक ही लिया जाएगा, और इसकी सामग्री रिपोर्ट आउटपुट का उत्पादन करेगी।

12

Background

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

अनुभाग, तत्व और गुण संबंध

निम्नलिखित आरेख एक रिपोर्ट के अनुभाग में तत्वों और विशेषताओं के संबंध को दर्शाता है।

अनुभाग तत्व

उपर्युक्त सभी रिपोर्ट अनुभाग वैकल्पिक हैं। लेकिन किसी भी रिपोर्ट टेम्पलेट में कम से कम एक ऐसा अनुभाग होगा। इनमें से प्रत्येक खंड में एक एकल <शामिल हैband> तत्व इसके एकमात्र उप-तत्व के रूप में। अ <band> शून्य या अधिक निम्नलिखित उप-तत्व शामिल हो सकते हैं -

<line>, <rectangle>, <ellipse>, <image>, <staticText>, <textField>, <subReport>, या <elementGroup>

इनमें से प्रत्येक तत्व में एक एकल <होना चाहिएreportElement> इसके पहले तत्व के रूप में (एलिमेंटग्रुप को छोड़कर)। अ <reportElement> यह निर्धारित करता है कि उस विशेष तत्व के लिए डेटा कैसे रखा गया है। चर और मापदंडों के विपरीत, रिपोर्ट तत्वों को एक नाम रखने की आवश्यकता नहीं है, क्योंकि आम तौर पर आपको रिपोर्ट टेम्पलेट के अंदर किसी भी व्यक्तिगत तत्व को प्राप्त करने की आवश्यकता नहीं होती है।

नीचे दी गई तालिका <की विशेषताओं का सार प्रस्तुत करती हैreportElement> -

गुण विवरण वैध मान
एक्स बैंड तत्व के x निर्देशांक को निर्दिष्ट करता है। पिक्सेल में तत्व के x निर्देशांक को दर्शाने वाला पूर्णांक मान। यह विशेषता आवश्यक है।
y बैंड तत्व के y समन्वय को निर्दिष्ट करता है। पिक्सेल में तत्व के y निर्देशांक को दर्शाता एक पूर्णांक मान। यह विशेषता आवश्यक है।
चौड़ाई बैंड तत्व की चौड़ाई निर्दिष्ट करता है। पिक्सेल में तत्व की चौड़ाई को दर्शाता एक पूर्णांक मान। यह विशेषता आवश्यक है।
ऊंचाई बैंड तत्व की ऊंचाई निर्दिष्ट करता है। पिक्सेल में तत्व की ऊँचाई को दर्शाता एक पूर्णांक मान। यह विशेषता आवश्यक है।
चाभी बैंड तत्व की विशिष्ट पहचानकर्ता। एक अद्वितीय स्ट्रिंग मान।
stretchType निर्दिष्ट करता है कि जब बैंड खिंचाव करता है तो तत्व कैसे फैलता है

NoStretch (default) - तत्व खिंचाव नहीं होगा।

RelativeToTallestObject - तत्व अपने समूह में सबसे ऊंची वस्तु को समायोजित करने के लिए खिंचाव करेगा।

RelativeToBand - तत्व बैंड की ऊंचाई को फिट करने के लिए खिंचाव करेगा।

स्थान के प्रकार जब बैंड फैलता है तो तत्व की स्थिति को निर्दिष्ट करता है।

Float - तत्व आसपास के तत्वों के आकार के आधार पर आगे बढ़ेगा।

FixRelativeToTop (default) - तत्व बैंड के शीर्ष के सापेक्ष एक निश्चित स्थिति बनाए रखेगा।

FixRelativeToBottom - तत्व बैंड के तल के सापेक्ष एक निश्चित स्थिति बनाए रखेगा।

isPrintRepeatedValues निर्दिष्ट करता है यदि दोहराया मान मुद्रित किए जाते हैं।

true (default) - बार-बार मान छपेंगे।

false - बार-बार मान नहीं छपेंगे।

मोड तत्व की पृष्ठभूमि मोड निर्दिष्ट करता है अपारदर्शी, पारदर्शी
isRemoveLineWhenBlank निर्दिष्ट करता है कि तत्व खाली होने पर हटाया जाना चाहिए और समान क्षैतिज स्थान में कोई अन्य तत्व नहीं हैं। सही गलत
isPrintInFirstWholeBand निर्दिष्ट करता है कि तत्व को पूरे बैंड में मुद्रित किया जाना चाहिए, अर्थात, वह बैंड जो रिपोर्ट पृष्ठों या स्तंभों के बीच विभाजित नहीं है। सही गलत
isPrintWhenDetailOverFlows निर्दिष्ट करता है कि क्या तत्व तब मुद्रित होगा जब बैंड एक नए पृष्ठ या स्तंभ पर ओवरफ्लो करता है। सही गलत
printWhenGroupChanges निर्दिष्ट समूह बदलने पर तत्व मुद्रित किया जाएगा। एक स्ट्रिंग मान।
फ़ोर कलर तत्व के अग्रभूमि रंग को निर्दिष्ट करता है। या तो एक हेक्साडेसिमल आरजीबी मूल्य # चरित्र से पहले, या निम्न पूर्वनिर्धारित मूल्यों में से एक: काला, नीला, सियान, डार्कग्रे, ग्रे, ग्रीन, लाइटग्रे, मैजेंटा, नारंगी, गुलाबी, लाल, पीला, सफेद।
पीछे का रंग तत्व की पृष्ठभूमि का रंग निर्दिष्ट करता है। फोरकोलर के लिए मान्य मानों के समान

अनुभाग विशेषताएँ

रिपोर्ट अनुभाग की विशेषताएं निम्नलिखित हैं -

ऊंचाई

अनुभाग की ऊँचाई उस विशेष अनुभाग के लिए पिक्सेल में ऊँचाई निर्दिष्ट करती है और समग्र रिपोर्ट डिज़ाइन में बहुत महत्वपूर्ण है।

जब अभिव्यक्ति मुद्रित करें

एक बूलियन अभिव्यक्ति जो यह निर्धारित करती है कि अनुभाग मुद्रित होना चाहिए या नहीं।

विभाजन की अनुमति है

यह दर्शाता है कि क्या खंड को विभाजित करने की अनुमति है जब यह वर्तमान पृष्ठ पर फिट नहीं होता है। यदि सही है, तो अनुभाग अगले पृष्ठ पर स्थानांतरित हो जाएगा। ध्यान दें कि यदि मामला अगले पृष्ठ पर फिट नहीं होता है, तो ध्वज के मूल्य की परवाह किए बिना अनुभाग विभाजित हो जाएगा। स्प्लिट टाइप निम्नलिखित मान ले सकता है -

  • स्प्लिट टाइप = "स्ट्रेच:" स्प्लिट स्ट्रेच कंटेंट। यदि अनुभाग वर्तमान पृष्ठ पर फैला हुआ है (यदि उपलब्ध स्थान घोषित ऊंचाई से कम है), तो मूल ऊंचाई में जोड़ा गया क्षेत्र अगले पृष्ठ पर विभाजित करने की अनुमति है।

  • स्प्लिट टाइप = "रोकें:" पहले प्रयास में विभाजन को रोकें। यदि खंड अगले पृष्ठ पर फिट नहीं होता है, तो विभाजन सामान्य रूप से होता है, क्योंकि बैंड विभाजन रोकथाम केवल पहले विभाजन के प्रयास पर प्रभावी है।

  • स्प्लिट टाइप = "तत्काल:" तुरंत विभाजित करें। बैंड को इसके शीर्ष तत्व को छोड़कर कहीं भी विभाजित करने की अनुमति है।

उदाहरण

प्रत्येक अनुभाग को प्रदर्शित करने के लिए, रिपोर्ट टेम्पलेट (jasper_report_template.jrxml) लिखें। इस फाइल को सेव करेंC:\tools\jasperreports-5.0.1\testनिर्देशिका। इस फ़ाइल में, हम प्रत्येक अनुभाग में एक पाठ प्रदर्शित करेंगे (हमने ऊपर चर्चा की है)। फ़ाइल की सामग्री नीचे दी गई है -

<?xml version = "1.0" encoding = "UTF-8"?>

<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 = "300" pageHeight = "300" 
   columnWidth = "300" leftMargin = "0" rightMargin = "0" 
   topMargin = "0" bottomMargin = "0" >

   <title>
      <band height = "50">
         
         <textField>
            <reportElement x = "100" y = "16" width = "100" height = "20"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Title"]]>
            </textFieldExpression>
        
         </textField>
      
      </band>
   </title>
   
   <pageHeader>
      <band height = "40">
         
         <textField>
            <reportElement  mode = "Opaque" x = "100" y = "10" 
               width = "90" height = "20"/>
            
            <textElement>
               <font isBold = "true"/>
            </textElement>
            
            <textFieldExpression>
               <![CDATA["Page Header"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </pageHeader>
   
   <columnHeader>
      <band height = "40">
            
         <textField>
            <reportElement  x = "100" y = "10" width = "90" height = "20"/>
            
            <textElement>
               <font isItalic = "true"/>
            </textElement>
            
            <textFieldExpression>
               <![CDATA["Column Header"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </columnHeader>
   
   <detail>
      <band height ="40">
         
         <textField>
            <reportElement mode = "Opaque" x = "100" y = "10" 
               width = "90" height = "20" backcolor = "#99CCFF"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Report Details"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>
   
   <columnFooter>
      <band height = "40">
         
         <textField>
            <reportElement  x = "100" y = "10" width = "90" height = "20"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Column Footer"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </columnFooter>
   
   <pageFooter>
      <band height = "40">
         
         <textField>
            <reportElement  x = "100" y = "10" width = "90" height = "20"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Page Footer"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </pageFooter>
   
   <lastPageFooter>
      <band height = "40">
         
         <textField>
            <reportElement  x = "100" y = "10" width = "90" height = "20"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Last Page Footer"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </lastPageFooter>
   
   <summary>
      <band height = "40">
         
         <textField>
            <reportElement  x = "100" y = "10" width = "90" height = "20"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Summary"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </summary>
	
</jasperReport>

रिपोर्ट भरने और उत्पन्न करने के लिए जावा कोड नीचे दिया गया है। आइए इस फाइल को सेव करेंJasperReportFill.java C: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint निर्देशिका।

package com.tutorialspoint;

import net.sf.jasperreports.engine.JREmptyDataSource;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperFillManager;

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

      try {
         JasperFillManager.fillReportToFile(sourceFileName, null,
            new JREmptyDataSource());
      } catch (JRException e) {
         // TODO Auto-generated catch block
         e.printStackTrace();
      }

   }
}

यहाँ, हम JREmptyDataSource के एक उदाहरण का उपयोग करते हैं, जब इसमें एक रिकॉर्ड के साथ एक डेटा स्रोत का अनुकरण करने के लिए रिपोर्ट भरते हैं, लेकिन इस एकल रिकॉर्ड में सभी फ़ील्ड शून्य हैं।

रिपोर्ट पीढ़ी

हम अपनी नियमित ANT बिल्ड प्रक्रिया का उपयोग करके उपरोक्त फ़ाइल को संकलित और निष्पादित करेंगे। फ़ाइल build.xml (निर्देशिका C: \ tools \ jasperreports-5.0.1 \ test के तहत सहेजी गई) की सामग्री नीचे दी गई है।

आयात फ़ाइल - baseBuild.xml को अध्याय पर्यावरण सेटअप से उठाया गया है और इसे बिल्ड .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, defau
   [javac] Compiling 1 source file 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.JRXmlDigesterFac
   [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.ExtensionsEnviro
   [java] log4j:WARN Please initialize the log4j system properly.

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

BUILD SUCCESSFUL
Total time: 18 minutes 22 seconds

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

यहां, हम देख सकते हैं कि प्रत्येक खंड में एक पाठ मुद्रित है। यह ध्यान दिया जाना चाहिए कि जेआरएक्सएमएल में <lastPageFooter> तत्व शामिल है, इसे रिपोर्ट के अंतिम पृष्ठ में प्रदर्शित किया जाएगा <pageFooter> तत्व के बजाय। <ColumnHeader> और <columnFooter> तत्व केवल रिपोर्ट पर प्रदर्शित किए जाएंगे, यदि इसमें एक से अधिक कॉलम हों।