जैस्परपोर्ट - त्वरित गाइड

एक रिपोर्ट क्या है

एक रिपोर्ट सूचना का एक सार्थक, अच्छी तरह से परिभाषित और संक्षेप में प्रस्तुतिकरण है। आमतौर पर, नियमित गतिविधियों को स्वचालित किया जाता है और डेटा को एक निर्णय-समर्थक "रिपोर्ट" में संक्षेपित किया जाता है। रिपोर्ट चार्ट, ग्राफ़ और ग्राफ़िकल प्रतिनिधित्व के अन्य रूपों में सामान्य रूप से गंदे डेटा का प्रतिनिधित्व करती हैं।

रिपोर्ट का खाका

आमतौर पर, अधिकांश वाणिज्यिक रिपोर्ट जनरेटिंग टूल द्वारा रिपोर्ट तैयार करने के लिए निम्न लेआउट को अपनाया जाता है।

शीर्षक
पेज हैडर
COLUMNHEADER
विवरण
COLUMNFOOTER
पेज फ़ुटर
सारांश

आरेख में उल्लिखित प्रत्येक तत्व के विवरण निम्नलिखित हैं -

S.NO तत्व और विवरण
1

title

शीर्षक में रिपोर्ट का 'शीर्षक' होता है। यह रिपोर्ट की बहुत शुरुआत में केवल एक बार दिखाई देता है, उदाहरण के लिए, "ट्यूटोरियल प्वाइंट रिपोर्ट।"

2

pageHeader

PageHeader में दिनांक और समय की जानकारी और / या संगठन का नाम हो सकता है। यह प्रत्येक पृष्ठ के शीर्ष पर दिखाई देता है।

3

columnHeader

ColumnHeader उन विशिष्ट फ़ील्ड्स के नामों को सूचीबद्ध करता है, जिन्हें आप रिपोर्ट में प्रदर्शित करना चाहते हैं, उदाहरण के लिए, "लेखक का नाम," "शुरुआती घंटे," "फिनिशिंग ऑवर," "ऑवर्स वर्केड," "डेट," आदि।

4

detail

विवरण वह हिस्सा है जहां विशिष्ट फ़ील्ड्स (कॉलमहेड में सूचीबद्ध) की प्रविष्टियाँ दिखाई जाती हैं, उदाहरण के लिए "मनीषा", "9:00", "18:00", "9", "10.02.2013।"

5

columnFooter

ColumnFooter किसी भी क्षेत्र का सारांश प्रदर्शित कर सकता है, उदाहरण के लिए, "कुल कार्य का समय:" 180. "

6

pageFooter

PageFooter में पृष्ठ गणना जानकारी हो सकती है। यह प्रत्येक पृष्ठ के नीचे दिखाई देता है, उदाहरण के लिए, "1/23।"

7

summary

सारांश में "विवरण" भाग से अनुमानित जानकारी शामिल है, उदाहरण के लिए, प्रत्येक लेखक द्वारा काम किए गए घंटों की संख्या को सूचीबद्ध करने के बाद, प्रत्येक लेखक द्वारा काम किए गए कुल घंटे को विज़ुअल चार्ट जैसे पाई चार्ट, ग्राफ, आदि में बेहतर तुलना के लिए रखा जा सकता है।

JasperReports

रिपोर्ट के विकास के दौरान आने वाली आम परेशानियाँ निम्नलिखित हैं -

  • Core changes - आमतौर पर, व्यवसाय परिवर्तन या संवर्द्धन को प्रतिबिंबित करते हैं यह रिपोर्ट के मुख्य तर्क को बदलने के लिए आवश्यक है।

  • Results exporting - प्रारूपों की एक विस्तृत श्रृंखला है, जिन्हें आपकी रिपोर्ट को निर्यात किया जा सकता है, जैसे: HTML, पाठ, पीडीएफ, एमएस एक्सेल, आरटीएफ, ओडीटी, कोमा से अलग किए गए मान, एक्सएमएल या छवि।

  • Complicated reports - उप-रिपोर्ट और क्रॉस-टैब्स रिपोर्ट अच्छे उदाहरण हैं।

  • Charts reports - उदाहरण के लिए दृश्य चार्ट, ग्राफ, पाई, एक्सवाई लाइन, बार, मीटर और टाइम सीरीज़।

उपर्युक्त बिंदुओं के ओवरहेड को हटाने और रिपोर्टिंग प्रक्रिया को सुविधाजनक बनाने के लिए, बहुत सारे चौखटे, उपकरण, पुस्तकालय, और 3 पार्टियों के आवेदन पेश किए गए थे। JasperReports उनमें से एक है।

JasperReportsएक खुला स्रोत जावा रिपोर्टिंग इंजन है। यह जावा आधारित है और इसकी अपनी अभिव्यक्ति सिंटैक्स नहीं है। JasperReports में प्रिंटर, या PDF, HTML, XLS, RTF, ODT, CSV, TXT और XML फ़ाइलों में स्क्रीन पर समृद्ध सामग्री देने की क्षमता है। चूंकि यह एक स्टैंडअलोन उपकरण नहीं है, इसलिए इसे अपने आप स्थापित नहीं किया जा सकता है। इसके बजाय, यह एप्लिकेशन के CLASSPATH में अपने पुस्तकालय को शामिल करके जावा अनुप्रयोगों में एम्बेडेड है।

JasperReports एक जावा वर्ग की लाइब्रेरी है, और अंतिम उपयोगकर्ताओं के लिए नहीं है, बल्कि जावा डेवलपर्स के लिए लक्षित है, जिन्हें अपने अनुप्रयोगों में रिपोर्टिंग क्षमताओं को जोड़ने की आवश्यकता है।

जैस्परपरपोर्ट्स की विशेषताएं

JasperReports की कुछ महत्वपूर्ण विशेषताएं हैं -

  • इसमें एक लचीली रिपोर्ट लेआउट है।

  • यह डेटा को टेक्स्ट या ग्राफिकल रूप से प्रस्तुत कर सकता है।

  • डेवलपर्स कई तरीकों से डेटा की आपूर्ति कर सकते हैं।

  • यह कई डेटा स्रोतों से डेटा को स्वीकार कर सकता है।

  • यह वॉटरमार्क उत्पन्न कर सकता है (एक वॉटरमार्क एक माध्यमिक छवि की तरह है जो प्राथमिक छवि पर रखी गई है)।

  • यह उप रिपोर्ट उत्पन्न कर सकता है।

  • यह विभिन्न स्वरूपों में रिपोर्ट निर्यात करने में सक्षम है।

JasperReports एक शुद्ध जावा लाइब्रेरी है और एक स्टैंडअलोन एप्लिकेशन नहीं है। यह अपने आप नहीं चल सकता है, इसलिए इसे किसी अन्य क्लाइंट या सर्वर-साइड जावा एप्लिकेशन में एम्बेड करने की आवश्यकता है। जैसा कि यह जावा आधारित है, इसे जावा (JDK 1.3 और इसके बाद के संस्करण) का समर्थन करने वाले किसी भी मंच पर चलाया जा सकता है। सभी जैस्पररिपोर्ट की कार्यक्षमताएं एक ही JAR फ़ाइल, jasperreports-xxxjar में एकत्रित की जाती हैं। यह JAR आवश्यक और वैकल्पिक पुस्तकालयों (.ZIP फ़ाइल) के साथ साइट से डाउनलोड किया जा सकता है: जैस्पररपोर्ट लाइब्रेरी लिंक । इस लिंक से नवीनतम संस्करण डाउनलोड करें।

ZIP फ़ाइल में JasperReports JAR फ़ाइल के साथ-साथ JasperReports स्रोत कोड, निर्भर JAR और कई प्रकार के उदाहरण शामिल हैं, जिनमें JasperReport की कार्यक्षमताओं का प्रदर्शन किया गया है।

जैस्परपोर्ट पर्यावरण

रिपोर्ट बनाना शुरू करने के लिए, हमें पर्यावरण तैयार करने की आवश्यकता है। किसी भी स्थान पर डाउनलोड की गई JasperReport.ZIP फ़ाइल को निकालें (हमारे मामले में, हमने इसे C: \ tools \ jasperreports-5.0.1 पर निकाला है)। निकाली गई फ़ाइल की निर्देशिका संरचना नीचे दर्शाई गई है -

यहाँ सभी निर्देशिकाओं का विवरण दिया गया है -

  • निर्माण - संकलित JasperReport वर्ग फ़ाइलों में शामिल है।

  • डेमो - जैस्परपरपोर्ट्स कार्यक्षमता के कई पहलुओं को प्रदर्शित करते हुए विभिन्न उदाहरण हैं।

  • Dist - jasperreports-xxxjar फ़ाइल शामिल है। हम जैस्पररीपोर्ट्स का लाभ उठाने के लिए इस JAR फ़ाइल को हमारे CLASSPATH में जोड़ देंगे।

  • डॉक्स - जैस्पररीपोर्ट्स प्रलेखन की एक स्थानीय प्रति शामिल है।

  • lib - इसमें सभी JAR की आवश्यकता है, दोनों जैस्पररीपोर्ट्स का निर्माण करने के लिए और हमारे अनुप्रयोगों में इसका उपयोग करने के लिए।

  • src - जैस्पररीपोर्ट स्रोत कोड शामिल है।

  • build.xml - JasperReports स्रोत कोड बनाने के लिए एक ANT बिल्ड फ़ाइल। यदि हम जैस्पररीपोर्ट्स को संशोधित करने का इरादा नहीं रखते हैं, तो हमें इस फाइल का उपयोग करने की आवश्यकता नहीं है क्योंकि कंपार्टमेंट फॉर्म में जैस्पररीपोर्ट्स वितरित किया गया है।

  • change.txt - जैस्परपरपोर्ट्स क्लास लाइब्रेरी के वर्तमान और पिछले संस्करणों के बीच के अंतर को समझाते हुए एक टेक्स्ट डॉक्यूमेंट।

  • lic.txt - एक टेक्स्ट डॉक्यूमेंट जिसमें LGPL (लेसर जनरल पब्लिक लाइसेंस) लाइसेंस का पूरा टेक्स्ट होता है।

  • readme.txt - एक पाठ दस्तावेज़, जिसमें दिए गए उदाहरणों को बनाने और निष्पादित करने के निर्देश हैं।

असल में, हम केवल JasperReports-xxxjar के तहत का उपयोग जिले और जार के तहत lib निर्देशिका रिपोर्ट पैदा करने के लिए। जैस्परपरपोर्ट्स एक ओपन सोर्स टूल होने के नाते, अगर जैस्परस्पोर्ट्स-एक्सएक्सएक्सएक्स में निष्पादन के दौरान किसी भी दोष या बग को मान्यता दी जाती है, तो हम इसे ठीक कर सकते हैं और बिल्ड.xml फ़ाइल का उपयोग करके JAR को फिर से बना सकते हैं।

CLASSPATH सेट करें

JasperReport का उपयोग करने के लिए, हमें निम्नलिखित फ़ाइलों को हमारे CLASSPATH पर सेट करना होगा -

  • jasperreports-xxxjar, जहाँ xxx JasperReports संस्करण है। यह निर्देशिका C: \ tools \ jasperreports-xxx \ dist) के तहत मिली।

  • सभी JAR की फाइलें लिब उपनिर्देशिका (C: \ tools \ jasperreports-xxx \ lib) के तहत आती हैं।

स्थापना के समय, हमने जैस्परपोर्टपोर्ट संस्करण 5.0.1 का उपयोग किया। 'मेरा कंप्यूटर' पर राइट-क्लिक करें और 'गुण' चुनें, 'उन्नत' टैब के तहत 'पर्यावरण चर' बटन पर क्लिक करें। अब इसके साथ 'पाथ' वेरिएबल को अपडेट करेंC:\tools\jasperreports-5.0.1\dist\jasperreports-5.0.1.jar:C:\tools\jasperreports-5.0.1\lib। अब आप अपनी रिपोर्ट बनाने के लिए तैयार हैं।

इस ट्यूटोरियल में सभी उदाहरणों में, हमने रिपोर्ट बनाने के लिए ANT कार्यों का उपयोग किया है। buildफ़ाइल रिपोर्ट बनाने के लिए सभी आवश्यक JAR आयात करने का ध्यान रखती है। इसलिए, ऊपर बताए अनुसार CLASSPATH की स्थापना केवल उन लोगों की मदद करेगी जो ANT का उपयोग किए बिना रिपोर्ट उत्पन्न करना चाहते हैं।

सेटअप बनाएँ

इस ट्यूटोरियल में सभी उदाहरण -

  • सरल पाठ संपादक का उपयोग करके लिखा गया है।

  • निर्देशिका C: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint के तहत सहेजा गया है।

  • Apache ANT का उपयोग करके कमांड प्रॉम्प्ट से संकलित और निष्पादित किया गया है। हम एक का उपयोग करेंगेbaseBuild.xml फ़ाइल, जिसे हम ANT में आयात करेंगे build.xmlबाद के अध्यायों में फ़ाइल। इस फ़ाइल को C: \ tools \ jasperreports-5.0.1 \ test में सहेजें। आधार की सामग्री निम्नलिखित है

<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportExample" basedir = ".">
   <description>Previews our JasperReport XML Design</description>
   <property name = "file.name" value = "jasper_report_template" />
   
   <!-- Directory where the JasperReports project file was extracted
   needs to be changed to match the local environment -->
   <property name = "jasper.dir" value = "../" />
   <property name = "dist.dir" value = "${jasper.dir}/dist" /> <property name = "lib.dir" value = "${jasper.dir}/lib" />
   <property name = "src.dir" value = "src" />
   <property name = "classes.dir" value = "classes" />
   <property name = "main-class" value = "com.tutorialspoint.HelpMe" />

   <path id = "classpath">
      <pathelement location = "./" />
      <pathelement location = "${classes.dir}" /> <fileset dir = "${lib.dir}">
         <include name = "**/*.jar" />
      </fileset>
	  
      <fileset dir = "${dist.dir}"> <include name = "**/*.jar" /> </fileset> </path> <target name = "compile" depends = "clean-sample"> <mkdir dir = "${classes.dir}"/>
		
      <javac srcdir = "${src.dir}" destdir = "${classes.dir}" 
         classpathref = "classpath" />
   </target>
   
   <target name = "run" depends = "compile">
      <echo message = "Running class : ${main-class}"/> <java fork = "true" classname = "${main-class}">
         <classpath>
            <path refid = "classpath" />
         </classpath>
      </java>
   </target>
   
   <target name = "clean-sample">
      <delete dir = "${classes.dir}" /> <delete file = "./${file.name}.jasper" />
      <delete file = "./${file.name}.jrprint" />
   </target>
   
</project>

इस फ़ाइल में सभी आवश्यक लक्ष्य हैं, जैसे निर्देशिकाओं को साफ करना, जावा फ़ाइलों को संकलित करना, और वर्ग फ़ाइलों को निष्पादित करना।

आधारभूत, xml में विभिन्न निर्देशिकाओं द्वारा उल्लिखित विवरण निम्नलिखित हैं। वर्तमान निर्देशिका मान लिया गया है कि C: \ tools \ jasperreports-5.0.1 \ test) -

  • jasper.dir - C: \ tools \ jasperreports-5.0.1 निर्देशिका है

  • lib.dir - C: \ tools \ jasperreports-5.0.1 \ lib निर्देशिका है

  • src.dir - C: \ tools \ jasperreports-5.0.1 \ test \ src है

  • classes.dir - C: \ tools \ jasperreports-5.0.1 \ test \ classes है

  • मुख्य वर्ग - com.tutorialspoint.HelpMe। यह क्लास एक साधारण क्लास निष्पादित है, जब कमांड लाइन से कोई क्लास फ़ाइल नाम पारित नहीं होता है। इस फ़ाइल को C: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint पर सहेजें।

package com.tutorialspoint;

public class HelpMe {
   public static void main(String[] args) {
      System.out.println("This is the default class executed."
         + "Please pass the fully qualified class" + " name to be executed as command line"
         + " parameter, for example," + " com.tutorialspoint.HelpMe ");
   }
}

जैस्पर मैनेजर्स क्लासेस

ऐसी कई कक्षाएं हैं, जिनका उपयोग JRXML रिपोर्ट डिज़ाइन को संकलित करने, रिपोर्ट भरने, पीडीएफ प्रिंट करने, HTML और XML फ़ाइलों को निर्यात करने, उत्पन्न रिपोर्ट देखने और रिपोर्ट डिज़ाइन करने के लिए किया जाएगा।

इन वर्गों की सूची है -

  • net.sf.jasperreports.engine.JasperCompileManager - JRXML वीडियो टेम्प्लेट को संकलित करने के लिए प्रयुक्त।

  • net.sf.jasperreports.engine.JasperFillManager - डेटा स्रोत से डेटा के साथ एक रिपोर्ट भरने के लिए उपयोग किया जाता है।

  • net.sf.jasperreports.engine.JasperPrintManager - जैस्पररीपोर्ट्स लाइब्रेरी द्वारा उत्पन्न दस्तावेजों को प्रिंट करने के लिए उपयोग किया जाता है।

  • net.sf.jasperreports.engine.JasperExportManager - रिपोर्ट-भरने की प्रक्रिया द्वारा उत्पादित दस्तावेजों के लिए पीडीएफ, एचटीएमएल या एक्सएमएल सामग्री प्राप्त करने के लिए उपयोग किया जाता है।

  • net.sf.jasperreports.view.JasperViewer - यह एक सरल जावा स्विंग एप्लिकेशन का प्रतिनिधित्व करता है, जो रिपोर्ट लोड और प्रदर्शित कर सकता है।

  • net.sf.jasperreports.view.JasperDesignViewer - रिपोर्ट टेम्पलेट्स का पूर्वावलोकन करने के लिए डिज़ाइन समय पर उपयोग किया जाता है।

Apache ANT की स्थापना

हम Apache ANT का उपयोग करके सभी उदाहरणों का निर्माण करने जा रहे हैं। इसलिए, कृपया अपने सिस्टम पर Apache ANT सेटअप करने के लिए ANT - पर्यावरण सेटअप अध्याय की जाँच करें ।

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

जैसा कि चित्र में दिखाया गया है, जीवन चक्र के अलग-अलग चरण हैं -

  • रिपोर्ट को डिज़ाइन करना - इस चरण में हम JRXML फ़ाइल बनाते हैं, जो एक XML दस्तावेज़ है जिसमें रिपोर्ट लेआउट की परिभाषा समाहित है। हम मैन्युअल रूप से इसे बनाने के लिए किसी भी टेक्स्ट एडिटर या iReportDesigner का उपयोग कर सकते हैं । यदि iReportDesigner का उपयोग किया जाता है, तो लेआउट को एक दृश्य तरीके से डिज़ाइन किया गया है, इसलिए JRXML की वास्तविक संरचना को अनदेखा किया जा सकता है।

  • रिपोर्ट संकलित करना - इस चरण में, जेआरएक्सएमएल को एक बाइनरी ऑब्जेक्ट में संकलित किया जाता है जिसे जैस्पर फ़ाइल (* .jper) कहा जाता है। यह संकलन प्रदर्शन कारणों से किया जाता है। रिपोर्ट्स को चलाने के लिए आपके आवेदन के साथ जैस्पर फाइलें होती हैं।

  • रिपोर्ट को निष्पादित करना (रिपोर्ट में डेटा भरना) - इस चरण में, आवेदन से डेटा संकलित रिपोर्ट में भरा जाता है। वर्ग net.sf.jasperreports.engine.JasperFillManager रिपोर्ट में डेटा भरने के लिए आवश्यक कार्य प्रदान करता है। एक जैस्पर प्रिंट फ़ाइल (* .प्रिंट) बनाई गई है, जिसका उपयोग रिपोर्ट को प्रिंट या निर्यात करने के लिए किया जा सकता है।

  • रिपोर्ट को वांछित प्रारूप में निर्यात करना - इस चरण में, हम पिछले चरण में बनाई गई जैस्पर प्रिंट फाइल को किसी भी प्रारूप में निर्यात कर सकते हैं जिसका उपयोग जैस्परएक्सपोर्टमैन का उपयोग करके किया जा सकता है। जैसा कि जैस्पर निर्यात के विभिन्न रूपों को प्रदान करता है, इसलिए उसी इनपुट के साथ, हम डेटा के कई प्रतिनिधित्व बना सकते हैं।

उपरोक्त चरणों में से प्रत्येक का एक विस्तृत अवलोकन बाद के अध्यायों में दिया जाएगा।

जेस्परएक्सपोर्ट में JRXML टेम्प्लेट (या JRXML फाइल) मानक XML फाइलें हैं, जिनमें .jrxml का विस्तार है। सभी JRXML फ़ाइलों में रूट तत्व के रूप में टैग <jasperReport> होता है। बदले में इसमें कई उप-तत्व शामिल हैं (ये सभी वैकल्पिक हैं)। JasperReport ढांचा विभिन्न प्रकार के डेटा स्रोतों को संभाल सकता है। इस ट्यूटोरियल में, हम जैस्परपरपोर्ट इंजन को जावा डेटा ऑब्जेक्ट (जावा बीन्स का उपयोग करके) का एक संग्रह पास करके एक मूल रिपोर्ट बनाने का तरीका बताएंगे। अंतिम रिपोर्ट में उनके नाम और देशों सहित श्रेणियों वाले लोगों की सूची प्रदर्शित होगी।

निम्नलिखित चरणों का वर्णन करने के लिए इस अध्याय में शामिल किया गया है - कैसे एक जैस्परपोर्ट को डिजाइन करने के लिए -

  • JRXML रिपोर्ट टेम्प्लेट बनाना और।
  • XML रिपोर्ट टेम्पलेट का पूर्वावलोकन करना।

JRXML रिपोर्ट टेम्पलेट बनाना

JRXML फ़ाइल बनाएँ, जो है jasper_report_template.jrxmlपाठ संपादक का उपयोग करना और इस फाइल को हमारे पर्यावरण सेटअप के अनुसार C: \ tools \ jasperreports-5.0.1 \ test में सहेजें ।

<?xml version = "1.0" encoding = "UTF-8"?>
<!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" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20">
  
   <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>
	
   <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[$F{name}]]>
            </textFieldExpression>
         </textField>

      </band>
   </detail>
	
</jasperReport>

यहाँ उपरोक्त रिपोर्ट टेम्पलेट में मुख्य क्षेत्रों का विवरण दिया गया है -

  • <queryString> - यह खाली है (जैसा कि हम जावा बीन्स के माध्यम से डेटा पास कर रहे हैं)। आमतौर पर एसक्यूएल स्टेटमेंट होता है, जो रिपोर्ट परिणाम को पुनः प्राप्त करता है।

  • <फ़ील्ड का नाम> - यह तत्व डेटा स्रोतों या प्रश्नों के डेटा को रिपोर्ट टेम्पलेट्स में मैप करने के लिए उपयोग किया जाता है। name रिपोर्ट निकाय में पुन: उपयोग किया जाता है और केस-संवेदी होता है।

  • <fieldDescription> - यह तत्व XML फ़ाइल में उपयुक्त तत्व के साथ फ़ील्ड नाम को मैप करता है।

  • <staticText> - यह स्थैतिक पाठ को परिभाषित करता है जो किसी भी डेटा स्रोत, चर, पैरामीटर या रिपोर्ट अभिव्यक्तियों पर निर्भर नहीं करता है।

  • <textFieldExpression> - यह परिणाम फ़ील्ड की उपस्थिति को परिभाषित करता है।

  • $ F {देश} - यह एक चर है जिसमें परिणाम का मान होता है, टैग <फ़ील्ड नाम> में पूर्वनिर्धारित फ़ील्ड।

  • <बैंड> - बैंड में डेटा होता है, जो रिपोर्ट में प्रदर्शित होता है।

रिपोर्ट डिज़ाइन तैयार हो जाने के बाद, इसे C: \ Directory में सहेजें।

XML रिपोर्ट टेम्पलेट का पूर्वावलोकन करना

एक उपयोगिता net.sf.jasperreports.view.JasperDesignViewer जैस्पररपोर्ट्स JAR फ़ाइल में उपलब्ध है, जो रिपोर्ट डिज़ाइन को बिना संकलित या भरने के लिए पूर्वावलोकन करने में मदद करता है। यह उपयोगिता एक स्वसंपूर्ण जावा अनुप्रयोग है, इसलिए ANT का उपयोग करके निष्पादित किया जा सकता है।

एक ANT लक्ष्य लिखें viewDesignXMLJRXML देखने के लिए। तो, चलो बनाने और बचाने के लिएbuild.xmlC: \ tools \ jasperreports-5.0.1 \ test निर्देशिका के तहत (उसी निर्देशिका में रखा जाना चाहिए जहां JRXML रखा गया है)। यहाँ build.xml फ़ाइल है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "viewDesignXML" basedir = ".">

   <import file = "baseBuild.xml" />
   <target name = "viewDesignXML" description = "Design viewer is 
      launched to preview the JXML report design.">
      
      <java classname = "net.sf.jasperreports.view.JasperDesignViewer" fork = "true">
         <arg value = "-XML" />
         <arg value = "-F${file.name}.jrxml" />
         <classpath refid = "classpath" />
      </java>
   </target>

</project>

अगला, चलो कमांड प्रॉम्प्ट खोलें और उस निर्देशिका पर जाएं जहां build.xml रखा गया है। आदेश निष्पादित करेंant(जैसा कि viewDesignXML डिफ़ॉल्ट लक्ष्य है)। आउटपुट इस प्रकार है -

C:\tools\jasperreports-5.0.1\test>ant
Buildfile: C:\tools\jasperreports-5.0.1\test\build.xml

viewDesignXML:
[java] log4j:WARN No appenders could be found for logger
(net.sf.jasperreports.engine.xml.JRXmlDigesterFactory).
[java] log4j:WARN Please initialize the log4j system properly.

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

जैसा कि हम देखते हैं, डेटा प्राप्त करने के लिए केवल रिपोर्ट अभिव्यक्ति प्रदर्शित होती है, क्योंकि जैस्परडिजाइन व्यूअर के पास वास्तविक डेटा स्रोत या रिपोर्ट मापदंडों तक पहुंच नहीं है। विंडो बंद करके या कमांड-लाइन विंडो में Ctrl-c मारकर JasperDesignViewer को समाप्त करें।

हमने पिछले अध्याय में जैस्पररपोर्ट टेम्पलेट (JRXML फ़ाइल) तैयार की है। इस फ़ाइल का उपयोग रिपोर्ट बनाने के लिए सीधे नहीं किया जा सकता। इसे जैस्पररपोर्ट के मूल द्विआधारी प्रारूप में संकलित किया जाना है, जिसे कहा जाता हैJasperफ़ाइल। संकलित करने पर, हम जैस्परड्रैस ऑब्जेक्ट को जैस्परपरपोर्ट ऑब्जेक्ट में बदल देते हैं -

इंटरफ़ेस net.sf.jasperreports.engine.design.JRCompiler संकलन के दौरान एक केंद्रीय भूमिका निभाता है। इस इंटरफ़ेस में रिपोर्ट अभिव्यक्तियों के लिए उपयोग की जाने वाली भाषा के आधार पर कई कार्यान्वयन हैं, जिन्हें जावा, ग्रूवी, जावास्क्रिप्ट या किसी अन्य स्क्रिप्टिंग भाषा में लिखा जा सकता है जब तक कि संकलक कार्यान्वयन रनटाइम पर इसका मूल्यांकन कर सकता है।

हम JRXML फ़ाइल को निम्नलिखित दो तरीकों से संकलित कर सकते हैं -

  • प्रोग्रामेटिक संकलन।
  • ANT कार्य के माध्यम से संकलन।

JRXML का प्रोग्रामेटिक संकलन

JasperReports एपीआई एक जैस्पररपोर्ट को संकलित करने के लिए एक मुखौटा वर्ग net.sf.jasperreports.engine.JasperCompileManager प्रदान करता है । इस वर्ग में रिपोर्ट टेम्पलेट्स को संकलित करने के लिए कई सार्वजनिक स्थैतिक विधियाँ हैं। टेम्प्लेट का स्रोत फ़ाइलें, इनपुट स्ट्रीम और / या मेमोरी ऑब्जेक्ट हो सकते हैं।

JRXML फ़ाइल (jasper_report_template.jrxml) की सामग्री इस प्रकार है। इसे डायरेक्टरी में सेव किया जाता हैC:\tools\jasperreports-5.0.1\test -

<?xml version = "1.0" encoding = "UTF-8"?>
<!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" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20">

   <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>
   
   <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[$F{name}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>
	
</jasperReport>

निम्न कोड उपरोक्त jasper_report_template.jrxml फ़ाइल का संकलन प्रदर्शित करता है।

package com.tutorialspoint;

import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperCompileManager;

public class JasperReportCompile {

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

      System.out.println("Compiling Report Design ...");
      try {
          /**
          * Compile the report to a file name same as
          * the JRXML file name
          */
         JasperCompileManager.compileReportToFile(sourceFileName);
      } catch (JRException e) {
         e.printStackTrace();
      }
      System.out.println("Done compiling!!! ...");
   }
}

टेम्पलेट संकलन

अगले चरण के रूप में, ऊपर दी गई सामग्री को फाइल में सहेजें C:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\JasperReportCompile.javaऔर नीचे के रूप में build.xml फ़ाइल में baseBuild.xml आयात करें। BaseBuild.xml में पहले से ही हैcompile तथा run लक्ष्य -

<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "run" basedir = ".">

   <import file = "baseBuild.xml"/>

</project>

अगला, चलो कमांड लाइन विंडो खोलें और उस निर्देशिका पर जाएं जहां build.xml रखा गया है। अंत में, कमांड निष्पादित करेंant -Dmain-class = com.tutorialspoint.JasperReportCompile के रूप में -

C:\tools\jasperreports-5.0.1\test>ant -Dmain-class = com.tutorialspoint.JasperReportCompile
Buildfile: C:\tools\jasperreports-5.0.1\test\build.xml
compile:
   [javac] C:\tools\jasperreports-5.0.1\test\baseBuild.xml:27:
   warning: 'includeantruntime' was not set, defaulting to
   build.sysclasspath=last;set to false for repeatable builds
   [javac] Compiling 1 source file to C:\tools\jasperreports-5.0.1\test\classes

run:
   [echo] Runnin class : com.tutorialspoint.JasperReportCompile
   [java] Compiling Report Design ...
   [java] log4j:WARN No appenders could be found for logger
   (net.sf.jasperreports.engine.xml.JRXmlDigesterFactory).
   [java] log4j:WARN Please initialize the log4j system properly.
   [java] Done compiling!!! ...

BUILD SUCCESSFUL
Total time: 8 seconds

उपरोक्त संकलन के परिणामस्वरूप, आप देखेंगे कि टेम्पलेट फ़ाइल jasper_report_template.jasper C: \ tools \ jasperreports-5.0.1 \ test निर्देशिका में उत्पन्न हुई।

संकलित रिपोर्ट टेम्पलेट का पूर्वावलोकन करें

Net.sf.jasperreports.view.JasperDesignViewer पूर्वावलोकन संकलित रिपोर्ट टेम्पलेट और JRXML टेम्पलेट्स के लिए इस्तेमाल किया जा सकता है।

आगे बढ़ने के लिए, आइए एक नया लक्ष्य जोड़ें viewDesignउपरोक्त बिल्ड.xml फ़ाइल में, जो हमें संकलित रिपोर्ट का पूर्वावलोकन करने की अनुमति देगा। नीचे संशोधित build.xml है -

आयात फ़ाइल - baseBuild.xml को अध्याय पर्यावरण सेटअप से चुना गया है और इसे build.xml के समान निर्देशिका में रखा जाना चाहिए।

<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "viewDesign" basedir = ".">

   <import file = "baseBuild.xml" />
   <target name = "viewDesign" description="Design viewer is launched 
      to preview the compiled report design.">
      
      <java classname = "net.sf.jasperreports.view.JasperDesignViewer" fork = "true">
         <arg value = "-F${file.name}.jasper" />
         <classpath refid = "classpath" />
      </java>
   </target>

</project>

आइए आज्ञा का पालन करें - ant(ViewDesign कमांड प्रॉम्प्ट पर डिफ़ॉल्ट लक्ष्य है)। JasperDesignViewer विंडो नीचे की तरह जैस्पर फ़ाइल प्रदर्शित करती है -

ANT टास्क के माध्यम से संकलन

जैसा कि रिपोर्ट टेम्पलेट संकलन एक रनटाइम जॉब की तुलना में डिज़ाइन टाइम जॉब की तरह है, जैस्परपरपोर्ट लाइब्रेरी में एक कस्टम एएनटी कार्य है। कुछ स्थितियों के लिए, जब JRXML फ़ाइल रनटाइम पर बनाई जाती है, तो हम इस ANT कार्य का उपयोग नहीं कर सकते हैं। कस्टम ANT कार्य को JRC कहा जाता है और इसे वर्ग द्वारा कार्यान्वित किया जाता है: net.sf.jasperreports.ant.JRAntCompileTask । इसका सिंटैक्स और व्यवहार बिल्ट-इन के समान है<javac> ANT कार्य।

टेम्पलेट संकलन

नया लक्ष्य जोड़ते हैं compilereportdesingहमारे मौजूदा build.xml के लिए। यहां, स्रोत फ़ोल्डर फ़ाइलों के साथ नेस्टेड <src> टैग का उपयोग करके निर्दिष्ट किया गया है। नेस्टेड स्रोत टैग रिपोर्ट टेम्प्लेट को संकलित करने की अनुमति देता है जो कई अलग-अलग स्थानों से बिखरे हुए हैं और एक रूट रिपोर्ट स्रोत फ़ोल्डर के तहत समूहीकृत नहीं हैं। नीचे संशोधित build.xml है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "compilereportdesing" basedir = ".">
   
   <import file = "baseBuild.xml" />
   <target name = "viewDesign" description = "Design viewer is 
      launched to preview the compiled report design.">
      
      <java classname = "net.sf.jasperreports.view.JasperDesignViewer" fork = "true">
         <arg value = "-F${file.name}.jasper" />
         <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(compilereportdesing डिफ़ॉल्ट लक्ष्य है); आउटपुट इस प्रकार है -

C:\tools\jasperreports-5.0.1\test>ant
Buildfile: C:\tools\jasperreports-5.0.1\test\build.xml

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.

BUILD SUCCESSFUL
Total time: 5 seconds

फ़ाइल jasper_report_template.jasper फ़ाइल सिस्टम में उत्पन्न होती है (हमारे मामले में C: \ tools \ jasperreports-5.0.1 \ test directory)। यह फ़ाइल net.sf.jasperreports.engine.JasperCompileManager.compileReportToFile () पर कॉल करके प्रोग्राम जनरेट की गई फ़ाइल के समान है। हम इस jasper फ़ाइल का पूर्वावलोकन कर सकते हैं, निष्पादित कर रहे हैंant viewDesign

किसी भी रिपोर्टिंग टूल का मुख्य उद्देश्य उच्च गुणवत्ता वाले दस्तावेजों का उत्पादन करना है। रिपोर्ट भरने की प्रक्रिया डेटा के सेट में हेरफेर करके इसे प्राप्त करने के लिए रिपोर्टिंग टूल की मदद करती है।

रिपोर्ट भरने की प्रक्रिया के लिए आवश्यक मुख्य इनपुट हैं -

  • Report Template - यह वास्तविक जैस्पररपोर्ट फ़ाइल है।

  • Report Parameters- ये मूल रूप से नामित मान हैं जो इंजन को भरने वाले समय पर रिपोर्ट में पारित किए जाते हैं। हम उन्हें रिपोर्ट पैरामीटर अध्याय में चर्चा करेंगे ।

  • Data Source- हम एक SQL क्वेरी, XML फ़ाइल, एक सीएसवी फ़ाइल, एक HQL (हाइबरनेट क्वेरी भाषा) क्वेरी, जावा बीन्स का एक संग्रह, आदि जैसे डेटा स्रोतों की एक जैस्पर फ़ाइल भर सकते हैं। इस पर रिपोर्ट में विस्तार से चर्चा की जाएगी। डेटा स्रोत अध्याय।

इस प्रक्रिया से उत्पन्न आउटपुट ए है .jrprint दस्तावेज़ जो अन्य स्वरूपों में देखा, मुद्रित या निर्यात करने के लिए तैयार है। मुखौटा वर्ग net.sf.jasperreports.engine.JasperFillManager का उपयोग आमतौर पर डेटा के साथ रिपोर्ट टेम्पलेट भरने के लिए किया जाता है। इस वर्ग में विभिन्न fillReportXXX () तरीके हैं जो रिपोर्ट टेम्पलेट भरते हैं (टेम्पलेट डिस्क पर स्थित हो सकते हैं, इनपुट धाराओं से उठाए जा सकते हैं, या सीधे इन-मेमोरी के रूप में आपूर्ति की जाती है)।

इस मुखौटा श्रेणी में fillReportXXX () विधियों की दो श्रेणियां हैं -

  • पहला प्रकार, तीसरे पैरामीटर के रूप में एक java.sql.Connection ऑब्जेक्ट प्राप्त करें। ज्यादातर बार, रिपोर्ट एक रिलेशनल डेटाबेस के डेटा से भरे होते हैं। इसके द्वारा प्राप्त किया जाता है -

    • JDBC के माध्यम से डेटाबेस से कनेक्ट करें।

    • रिपोर्ट टेम्पलेट के अंदर SQL क्वेरी शामिल करें।

    • JasperReports इंजन SQL क्वेरी में पास किए गए कनेक्शन का उपयोग करता है और निष्पादित करता है।

    • एक रिपोर्ट डेटा स्रोत इस प्रकार रिपोर्ट भरने के लिए निर्मित होता है।

  • दूसरा प्रकार, एक net.sf.jasperreports.engine.JRDataSource ऑब्जेक्ट प्राप्त करता है, जब डेटा को भरने की आवश्यकता होती है जो अन्य रूपों में उपलब्ध है।

रिपोर्ट टेम्पलेट भरना

चलिए रिपोर्ट टेम्पलेट लिखते हैं। JRXML फ़ाइल की सामग्री (C: \ tools \ jasperreports-5.0.1 \ test \ jasper_report_template.jrxml) निम्नानुसार हैं -

<?xml version = "1.0" encoding = "UTF-8"?>
<!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" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20">

   <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>

   <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[$F{name}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>
	
</jasperReport>

इसके बाद, इस संकलित रिपोर्ट को भरने के लिए, जैस्पररीपोर्ट इंजन के लिए जावा डेटा ऑब्जेक्ट्स (जावा बीन्स) का एक संग्रह पास करें।

एक POJO DataBean.java लिखें, जो डेटा ऑब्जेक्ट (जावा बीन) का प्रतिनिधित्व करता है। यह वर्ग दो स्ट्रिंग ऑब्जेक्ट्स को परिभाषित करता है अर्थात 'नाम' और 'देश'। इसे निर्देशिका में सहेजेंC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint

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;
   }
}

एक वर्ग DataBeanList.java लिखें, जिसमें जावा बीन ऑब्जेक्ट्स का एक संग्रह उत्पन्न करने के लिए व्यावसायिक तर्क है। रिपोर्ट को जनरेट करने के लिए इसे आगे जैस्पररपोर्ट्स इंजन को दिया गया। यहाँ हम सूची में 4 DataBean ऑब्जेक्ट जोड़ रहे हैं। इसे निर्देशिका में सहेजेंC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint

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;
   }
}

एक मुख्य वर्ग फ़ाइल लिखें JasperReportFill.java, जो क्लास (DataBeanList) से जावा बीन संग्रह प्राप्त करता है और रिपोर्ट टेम्पलेट को भरने के लिए इसे जैस्पररीपोर्ट्स इंजन में भेजता है। इसे निर्देशिका में सहेजेंC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint

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();
      try {
         JasperFillManager.fillReportToFile( 
            sourceFileName, parameters, beanColDataSource);
      } catch (JRException e) {
         e.printStackTrace();
      }
   }
}

रिपोर्ट तैयार करना

अब हम अपनी नियमित ANT बिल्ड प्रक्रिया का उपयोग करके इन फ़ाइलों को संकलित और निष्पादित करेंगे। बिल्ड.xml फ़ाइल नीचे दी गई है -

आयात फ़ाइल - baseBuild.xml को अध्याय पर्यावरण सेटअप से चुना गया है और इसे build.xml के समान निर्देशिका में रखा जाना चाहिए।

<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "executereport" basedir = ".">
   <import file = "baseBuild.xml"/>

   <target name = "executereport" depends = "compile,compilereportdesing,run">
      <echo message = "Im here"/>
   </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 (executereport डिफ़ॉल्ट लक्ष्य है) निम्नानुसार है -

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

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

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.

BUILD SUCCESSFUL
Total time: 8 seconds

इसके बाद के संस्करण निष्पादन का एक परिणाम के रूप में, एक फ़ाइल jasper_report_template.jrprint रूप में एक ही निर्देशिका में उत्पन्न होता है .jasper फ़ाइल (इस मामले में, यह सेल्सियस पर उत्पन्न होता है: \ उपकरण \ JasperReports-5.0.1 \ परीक्षण)।

रिपोर्ट भरने की प्रक्रिया जैस्परप्रिंट ऑब्जेक्ट्स का आउटपुट एक अंतर्निहित दर्शक घटक का उपयोग करके देखा जा सकता है, या पीडीएफ, एचटीएमएल, आरटीएफ, एक्सएलएस, ओडीटी, सीएसवी, या एक्सएमएल जैसे अधिक लोकप्रिय दस्तावेज़ प्रारूपों को निर्यात किया जा सकता है। इस अध्याय में जैस्पर दस्तावेजों को देखने और छापने पर चर्चा की जाएगी और अगले अध्याय यानी 'एक्सपोर्ट रिपोर्ट्स' में निर्यात पर चर्चा की जाएगी ।

रिपोर्ट देखना

जैस्पररपोर्ट अपने मूल प्रारूप में उत्पन्न रिपोर्टों को देखने के लिए एक अंतर्निहित दर्शक प्रदान करता है। यह एक स्विंग आधारित घटक है और अन्य जावा अनुप्रयोग इस घटक को दस्तावेजों को अन्य प्रारूपों में निर्यात करने के लिए एकीकृत कर सकते हैं ताकि उन्हें देखा या मुद्रित किया जा सके। Net.sf.jasperreports.view.JRViewer वर्ग इस दृश्य घटक का प्रतिनिधित्व करता। इस वर्ग को आवेदन की जरूरत के अनुसार, उप-वर्ग द्वारा भी अनुकूलित किया जा सकता है।

JasperReports में एक स्विंग एप्लिकेशन भी है, जो रिपोर्टों को देखने के लिए दृश्य घटक का उपयोग करता है। इस एप्लिकेशन को * .jrprint के रूप में एक ही प्रारूप में रिपोर्ट देखने में मदद करता है। यह स्विंग एप्लिकेशन नेट में लागू होता है । sf.jasperreports.view.JasperViewer । इस वर्ग का उपयोग करके रिपोर्ट देखने के लिए, हमें इसे ANT लक्ष्य में लपेटने की आवश्यकता है।

उत्पन्न रिपोर्ट देखना

निम्न उदाहरण प्रदर्शित करता है - जैस्पर व्यूअर वर्ग का उपयोग करके रिपोर्ट कैसे देखें -

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

<?xml version = "1.0" encoding = "UTF-8"?>
<!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" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20">

   <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>
   
   <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[$F{name}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>
	
</jasperReport>

इसके बाद, इस संकलित रिपोर्ट को भरने के लिए, जैस्पररीपोर्ट इंजन के लिए जावा डेटा ऑब्जेक्ट्स (जावा बीन्स) का एक संग्रह पास करें।

एक POJO DataBean.java लिखें, जो डेटा ऑब्जेक्ट (जावा बीन) का प्रतिनिधित्व करता है। यह वर्ग दो स्ट्रिंग वस्तुओं को परिभाषित करता है जैसे 'नाम' और 'देश।' इसे निर्देशिका में सहेजेंC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint

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;
   }
}

एक वर्ग DataBeanList.java लिखें, जिसमें जावा बीन ऑब्जेक्ट्स का एक संग्रह उत्पन्न करने के लिए व्यावसायिक तर्क है। रिपोर्ट को जनरेट करने के लिए इसे आगे जैस्पररपोर्ट्स इंजन को दिया गया। यहां, हम सूची में 4 DataBean ऑब्जेक्ट जोड़ रहे हैं। इसे निर्देशिका में सहेजेंC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint

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;
   }
}

एक मुख्य वर्ग फ़ाइल लिखें JasperReportFill.java, जो क्लास (DataBeanList) से जावा बीन संग्रह प्राप्त करता है और रिपोर्ट टेम्पलेट को भरने के लिए इसे जैस्पररीपोर्ट्स इंजन में भेजता है। इसे निर्देशिका में सहेजेंC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint

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();
      try {
         JasperFillManager.fillReportToFile( 
            sourceFileName, parameters, beanColDataSource);
      } catch (JRException e) {
         e.printStackTrace();
      }
   }
}

चलो एक लक्ष्य लिखें viewFillReportto build.xml फ़ाइल। Build.xml फ़ाइल निम्नानुसार है -

आयात फ़ाइल - 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(viewFillReport डिफ़ॉल्ट लक्ष्य है)। परिणामस्वरूप, हम एक जैस्पर व्यूअर विंडो देखते हैं जैसा कि नीचे दी गई स्क्रीन में दिखाया गया है -

मुद्रण रिपोर्ट

हम (उनके मालिकाना प्रारूप में यानी JasperReports पुस्तकालय द्वारा उत्पन्न दस्तावेजों मुद्रित कर सकते हैं JasperPrint वस्तुओं) का उपयोग कर net.sf.jasperreports.engine.JasperPrintManager वर्ग। यह एक मुखौटा वर्ग है जो जावा 2 प्रिंटिंग एपीआई पर निर्भर करता है। जेस्परपरपोर्ट के दस्तावेज़ों को HTML या PDF जैसे अन्य प्रारूपों में निर्यात करने के बाद हम दस्तावेज़ों को प्रिंट भी कर सकते हैं।

जनरेट रिपोर्ट छापना

निम्न कोड एक रिपोर्ट के मुद्रण को प्रदर्शित करता है। आइए हमारी मौजूदा कक्षा जैस्पररपोर्टफिल को अपडेट करें। हम JasperPrintManager.printReport () विधि का उपयोग करेंगे । यह विधि स्रोत फ़ाइल नाम लेती है (यहाँ हम .jrprint फ़ाइल पास करते हैं , जिसे हम पहले पैरामीटर के रूप में JasperFillManager.fillReportToFile ()) विधि का उपयोग करके पिछले चरण में उत्पन्न करते हैं। दूसरा पैरामीटर मानक प्रिंट संवाद प्रदर्शित करने के लिए बूलियन है (हमने इसे सेट किया हैtrue यहाँ)।

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.JasperPrintManager;
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";
      String printFileName = null;
      DataBeanList DataBeanList = new DataBeanList();
      ArrayList<DataBean> dataList = DataBeanList.getDataBeanList();

      JRBeanCollectionDataSource beanColDataSource = new 
         JRBeanCollectionDataSource(dataList);

      Map parameters = new HashMap();
      try {
    	   printFileName = JasperFillManager.fillReportToFile( 
            sourceFileName, parameters, beanColDataSource);
         if(printFileName != null){
            JasperPrintManager.printReport( printFileName, true);
         }
      } catch (JRException e) {
         e.printStackTrace();
      }
   }
}

अब, इस फाइल को डायरेक्टरी में सेव करते हैं C:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint। हम एएनटी का उपयोग करके इस फ़ाइल को संकलित और निष्पादित करेंगे। बिल्ड.xml की सामग्री नीचे दी गई है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "executereport" basedir = ".">
   <import file = "baseBuild.xml"/>

   <target name = "executereport" depends = "compile,compilereportdesing,run">
      <echo message = "Im here"/>
   </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.JasperReportPrint। परिणामस्वरूप, एक प्रिंट संवाद बॉक्स प्रकट होता है। दस्तावेज़ मुद्रित करने के लिए ठीक क्लिक करें।

हमने पिछले अध्याय में देखा है कि एक जैस्पररपोर्ट जनरेट किए गए दस्तावेज़ को कैसे प्रिंट करें और देखें। यहां, हम देखेंगे कि इन रिपोर्ट्स को PDF, HTML और XLS जैसे अन्य प्रारूपों में कैसे रूपांतरित या निर्यात किया जाए। इस कार्यक्षमता को प्राप्त करने के लिए मुखौटा वर्ग net.sf.jasperreports.engine.JasperExportManager प्रदान किया जाता है। निर्यात का अर्थ है, जैस्परप्रिंट ऑब्जेक्ट ( .jrprint फ़ाइल) को विभिन्न प्रारूप में बदलना ।

निम्न कोड (JasperReportExport.java) जैस्परपोर्टपोर्ट दस्तावेज़ की निर्यात प्रक्रिया को प्रदर्शित करता है। JasperExportManager केवल PDF, HTML और XML में एक रिपोर्ट निर्यात करने के लिए तरीके प्रदान करता है। XLS प्रारूप में निर्यात करने के लिए, हमने net.sf.jasperreports.engine.export.JRXlsExporter वर्ग का उपयोग किया है । यह कोड तीन फ़ाइलों के बाद उत्पन्न होता है -

  • sample_report.pdf
  • sample_report.html
  • sample_report.xls

अन्य स्वरूपों को निर्यात करना

चलिए रिपोर्ट टेम्पलेट लिखते हैं। JRXML फ़ाइल की सामग्री (C: \ tools \ jasperreports-5.0.1 \ test \ jasper_report_template.jrxml) निम्नानुसार हैं -

<?xml version = "1.0" encoding = "UTF-8"?>
<!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" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20">

   <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>
   
   <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[$F{name}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>
	
</jasperReport>

अगला, 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;
   }
}

एक मुख्य वर्ग फ़ाइल लिखें JasperReportFill.java, जो क्लास (DataBeanList) से जावा बीन संग्रह प्राप्त करता है और रिपोर्ट टेम्पलेट को भरने के लिए इसे जैस्पररीपोर्ट्स इंजन में भेजता है। इसे निर्देशिका में सहेजेंC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint

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.JRExporterParameter;
import net.sf.jasperreports.engine.JasperExportManager;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
import net.sf.jasperreports.engine.export.JRXlsExporter;

public class JasperReportFill {
   @SuppressWarnings("unchecked")
   public static void main(String[] args) {
      String sourceFileName = "c://tools/jasperreports-5.0.1/"
         + "test/jasper_report_template.jasper";
      String printFileName = null;
      DataBeanList DataBeanList = new DataBeanList();
      ArrayList<DataBean> dataList = DataBeanList.getDataBeanList();
      JRBeanCollectionDataSource beanColDataSource =
         new JRBeanCollectionDataSource(dataList);

      Map parameters = new HashMap();
      try {
         printFileName = JasperFillManager.fillReportToFile(sourceFileName,
            parameters, beanColDataSource);
         if (printFileName != null) {
            /**
             * 1- export to PDF
             */
            JasperExportManager.exportReportToPdfFile(printFileName,
               "C://sample_report.pdf");

            /**
             * 2- export to HTML
             */
            JasperExportManager.exportReportToHtmlFile(printFileName,
               "C://sample_report.html");

            /**
             * 3- export to Excel sheet
             */
            JRXlsExporter exporter = new JRXlsExporter();

            exporter.setParameter(JRExporterParameter.INPUT_FILE_NAME,
               printFileName);
            exporter.setParameter(JRExporterParameter.OUTPUT_FILE_NAME,
               "C://sample_report.xls");

            exporter.exportReport();
         }
      } catch (JRException e) {
         e.printStackTrace();
      }
   }
}

यहाँ, हमने jasper प्रिंट फ़ाइल को pdf, html और xls प्रारूप में निर्यात करने के लिए तर्क को शामिल किया है।

रिपोर्ट तैयार करना

आइए हमारी नियमित ANT निर्माण प्रक्रिया का उपयोग करके फ़ाइलों के ऊपर संकलित और निष्पादित करें। बिल्ड.xml फ़ाइल नीचे दी गई है -

<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "executereport" basedir = ".">
   <import file = "baseBuild.xml"/>

   <target name = "executereport" depends = "compile,compilereportdesing,run">
      <echo message = "Im here"/>
   </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>

कमांड प्रॉम्प्ट पर जाएं और फिर डायरेक्टरी C: \ tools \ jasperreports-5.0.1 \ test पर जाएं, जहां build.xml रखा गया है। अंत में, कमांड निष्पादित करेंant -Dmain-class=com.tutorialspoint.JasperReportFill। आउटपुट इस प्रकार है -

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 t
   [javac] Compiling 4 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.

executereport:
   [echo] Im here

BUILD SUCCESSFUL
Total time: 32 seconds

उपरोक्त निष्पादन के परिणामस्वरूप, आपको C: \ निर्देशिका में उत्पन्न तीन फाइलें sample_report.pdf, sample_report.html, sample_report.xls मिलेंगी।

एक रिपोर्ट भरने के लिए मुख्य इनपुट हैं - रिपोर्ट टेम्पलेट, पैरामीटर और डेटा स्रोत। यह अध्याय मापदंडों का वर्णन करेगा और अगले अध्याय में हम डेटा स्रोतों पर चर्चा करेंगे।

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

पैरामीटर घोषणा

पैरामीटर घोषणा निम्नानुसार है -

<parameter name = "exampleParameter" class = "java.lang.String" />

नाम का गुण

नाम <पैरामीटर> तत्व की विशेषता अनिवार्य है। यह नाम से रिपोर्ट अभिव्यक्तियों में पैरामीटर का संदर्भ देता है। पैरामीटर नाम एक एकल शब्द होना चाहिए। इसमें कोई विशेष वर्ण नहीं होना चाहिए जैसे डॉट या अल्पविराम।

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

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

रिपोर्ट पैरामीटर मान हमेशा java.util.Map ऑब्जेक्ट में पैक किए जाते हैं, जिसका पैरामीटर नाम इसकी कुंजी के रूप में होता है। रिपोर्ट के क्वेरी स्ट्रिंग में रिपोर्ट पैरामीटर का उपयोग किया जा सकता है, ताकि डेटाबेस से पुनर्प्राप्त डेटा सेट को और अधिक अनुकूलित किया जा सके। ये क्वेरी में डायनामिक फ़िल्टर की तरह काम करते हैं जो रिपोर्ट के लिए डेटा की आपूर्ति करते हैं।

बिल्ट-इन पैरामीटर्स

निम्नलिखित पूर्व निर्धारित रिपोर्ट पैरामीटर हैं, जो अभिव्यक्तियों में उपयोग करने के लिए तैयार हैं -

S.NO पैरामीटर नाम और विवरण
1

REPORT_PARAMETERS_MAP

सभी उपयोगकर्ता परिभाषित और अंतर्निहित मापदंडों के साथ एक नक्शा शामिल है।

2

REPORT_CONNECTION

यह उपयोगकर्ता को वर्ग java.sql.Connection, JDBC डेटा स्रोत के लिए उपयोग किया जाता है।

3

REPORT_DATA_SOURCE

यह JRDataSource का एक उपयोगकर्ता द्वारा दिया गया उदाहरण है जो अंतर्निहित डेटा स्रोत प्रकारों में से किसी एक का प्रतिनिधित्व करता है या उपयोगकर्ता द्वारा परिभाषित एक है।

4

REPORT_MAX_COUNT

यह एक java.lang.Integer मान है, जिससे उपयोगकर्ता डेटा स्रोत से रिकॉर्ड सीमित कर सकते हैं।

5

REPORT_SCRIPTLET

यह net.sf.jasperreports.engine.JRAbstractScriptlet को इंगित करता है और इसमें उपयोगकर्ता द्वारा दी गई रिपोर्ट स्क्रिप्टलेट का एक उदाहरण होता है।

6

REPORT_LOCALE

यह एक java.util.Locale उदाहरण है, जिसमें संसाधन बंडल वांछित लोकेल है।

7

REPORT_RESOURCE_BUNDLE

यह java.util.ResourceBundle ऑब्जेक्ट को इंगित करता है और इसमें स्थानीय संदेश होते हैं।

8

REPORT_TIME_ZONE

यह एक java.util.TimeZone उदाहरण है, जिसका उपयोग दिनांक स्वरूपण के लिए किया जाता है।

9

REPORT_VIRTUALIZER

यह net.sf.jasperreports.engine.JRVirtualizer ऑब्जेक्ट का एक उदाहरण है , और पृष्ठ वर्चुअलाइजेशन (मेमोरी खपत का अनुकूलन) के लिए उपयोग किया जाता है।

10

REPORT_CLASS_LOADER

यह एक java.lang.ClassLoader उदाहरण है जिसका उपयोग रिपोर्ट भरने की प्रक्रिया के दौरान संसाधनों को लोड करने के लिए किया जाता है जैसे कि चित्र, फ़ॉन्ट, और सब -पोर्ट टेम्पलेट

1 1

IS_IGNORE_PAGINATION

यदि java.lang.Boolean.TRUE पर सेट किया गया है तो रिपोर्ट एक लंबे पृष्ठ पर उत्पन्न हो जाएगी और पृष्ठ विराम नहीं होगा।

उदाहरण

आइए रिपोर्ट के लेखक और लेखक को रिपोर्ट ( जैस्पररपोर्टफिल.जवा द्वारा जनरेट) पास करते हैं। संशोधित फाइल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;
   }
}

मापदंडों को जोड़ते हैं <ReportTitle> और <Author> हमारे मौजूदा रिपोर्ट टेम्पलेट (अध्याय रिपोर्ट डिजाइन ) के लिए। रिपोर्ट शीर्षक और लेखक को रिपोर्ट की शुरुआत में प्रदर्शित किया जाएगा। संशोधित रिपोर्ट टेम्पलेट (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>

   <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[$F{name}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>
	
</jasperReport>

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

हम अपनी नियमित 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

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

यहां, हम देखते हैं कि, रिपोर्ट की शुरुआत में रिपोर्टटाइटल "लिस्ट ऑफ कॉन्टेक्ट्स" और लेखक "रेडी बाय बाय मनीषा" प्रदर्शित होते हैं।

डेटा स्रोत संरचित डेटा कंटेनर हैं। रिपोर्ट तैयार करते समय, जैस्पररीपोर्ट इंजन डेटा स्रोत से डेटा प्राप्त करता है। डेटा डेटाबेस, एक्सएमएल फाइलें, वस्तुओं के सरणियों, और वस्तुओं के संग्रह से प्राप्त किया जा सकता है। हमने अध्याय भरने की रिपोर्ट में देखा , fillReportXXX () विधि रिपोर्ट के डेटा स्रोत को प्राप्त करने की अपेक्षा करती है, जिसे फॉर्म के रूप में भरना होता हैnet.sf.jasperreports.engine.JRDataSource वस्तु या ए java.sql.Connection (जब एक रिलेशनल डेटाबेस में रिपोर्ट डेटा पाया जाता है)।

JRDataSource इंटरफ़ेस में केवल दो विधियाँ हैं, जिन्हें लागू किया जाना चाहिए -

  • सार्वजनिक बूलियन अगले () JRException फेंकता है;

    • रिपोर्ट भरने के समय, डेटा के माध्यम से पुनरावृत्ति करते समय रिपोर्टिंग विधि द्वारा डेटा स्रोत ऑब्जेक्ट पर इस पद्धति को कॉल किया जाता है।

  • सार्वजनिक वस्तु getFieldValue (JRField jrField) JRException को फेंकता है;

    • यह विधि वर्तमान डेटा स्रोत रिकॉर्ड में प्रत्येक रिपोर्ट फ़ील्ड के लिए मान प्रदान करती है।

डेटा स्रोत से डेटा पुनर्प्राप्त करने का एकमात्र तरीका रिपोर्ट फ़ील्ड का उपयोग करके है। JRDataSource इंटरफ़ेस के कई डिफ़ॉल्ट कार्यान्वयन हैं, जिस तरह से, डेटा स्रोत में रिकॉर्ड्स का अधिग्रहण किया जाता है।

डेटास्रोस कार्यान्वयन

नीचे दी गई तालिका डेटा स्रोत और उनके कार्यान्वयन वर्गों को सारांशित करती है -

डेटा स्रोत कार्यान्वयन वर्ग
JDBC net.sf.jasperreports.engine.JRResultSetDataSource
JavaBean net.sf.jasperreports.engine.data.JRBeanCollectionDataSource, net.sf.jasperreports.engine.data.JRBeanArrayDataSource
मानचित्र के आधार पर net.sf.jasperreports.engine.data.JRMapArrayDataSource, net.sf.jasperreports.engine.data.JRMapCollectionDataSource
TableModel net.sf.jasperreports.engine.data.JRTableModelDataSource
एक्सएमएल net.sf.jasperreports.engine.data.JRXmlDataSource
सीएसवी net.sf.jasperreports.engine.data.JRCsvDataSource
XLS net.sf.jasperreports.engine.data.JRXlsDataSource
खाली net.sf.jasperreports.engine.JREmptyDataSource

JDBC डेटा स्रोत

कक्षा JRResultSetDataSourceक्रेप्स a java.sql.ResultSet ऑब्जेक्ट। जब किसी रिलेशनल डेटाबेस से रिपोर्ट डेटा निकाला जाता है तो यह सबसे अधिक उपयोग किया जाने वाला डेटा स्रोत कार्यान्वयन है। यदि java.sql.Connection को इंजन के बजाय पास किया जाता है, तो यह पहले संबंधित क्वेरी को निष्पादित करता है और JRResultSetDataSource उदाहरण में java.sql.ResultSet ऑब्जेक्ट को संग्रहीत करता है ।

जावाबीन डेटा स्रोत

कक्षाओं JRBeanArrayDataSource तथा JRBeanCollectionDataSourceउन कार्यान्वयनों का प्रतिनिधित्व करते हैं जो JavaBean वस्तुओं के सरणियों और संग्रहों को लपेट सकते हैं। सरणी या संग्रह के अंदर प्रत्येक ऑब्जेक्ट को इस प्रकार के डेटा स्रोत में एक रिकॉर्ड के रूप में देखा जाएगा। एक विशेष JavaBean संपत्ति और संबंधित रिपोर्ट क्षेत्र के बीच मानचित्रण नामकरण सम्मेलनों द्वारा किया जाता है। रिपोर्ट फ़ील्ड का नाम JavaBean संपत्ति के नाम के समान होना चाहिए जैसा कि JavaBeans विनिर्देशों द्वारा निर्दिष्ट किया गया है।

इस ट्यूटोरियल के सभी उदाहरणों में, हमने JRBeanCollectionDataSource का उपयोग किया है।

मानचित्र-आधारित डेटा स्रोत

कार्यान्वयन कक्षाएं JRMapArrayDataSource तथा JRMapCollectionDataSourceयदि माता-पिता एप्लिकेशन पहले से ही रिपोर्टिंग डेटा को java.util.Map ऑब्जेक्ट के रूप में उपलब्ध मेमोरी में स्टोर करते हैं । लिपटे हुए सरणी या संग्रह में प्रत्येक मैप ऑब्जेक्ट को डेटा स्रोत में एक वर्चुअल रिकॉर्ड माना जाता है, और प्रत्येक रिपोर्ट फ़ील्ड का मान मैप से रिपोर्ट फ़ील्ड का उपयोग करके निकाला जाता है जिसका नाम कुंजी है।

TableModel डेटा स्रोत

कई क्लाइंट-साइड एप्लिकेशन में, डेटा सारणीबद्ध प्रारूप में प्रदर्शित होता है। कई अनुप्रयोगों में एक सामान्य आवश्यकता उपयोगकर्ता को रिपोर्ट के रूप में इस सारणीबद्ध प्रारूप को मुद्रित करने की अनुमति देती है। कार्यान्वयन वर्गJRTableModelDataSourceस्विंग अनुप्रयोगों के लिए सारणीबद्ध प्रारूप से रिपोर्ट बनाने का कार्य करता है। यह वर्ग एक javax.swing.table.TableModel ऑब्जेक्ट लपेटता है। लिपटे TableModel ऑब्जेक्ट में कॉलम या तो उनके नाम या उनके 0-आधारित अनुक्रमित द्वारा पहुँचा जा सकता है।

XML डेटा स्रोत

कक्षा JRXmlDataSourceDOM पर आधारित एक डेटा स्रोत कार्यान्वयन है, जो XML दस्तावेज़ से डेटा का चयन करने के लिए XPath अभिव्यक्तियों का उपयोग करता है। XML डेटा स्रोत में रिकॉर्ड XPath अभिव्यक्ति के माध्यम से चुने गए नोड तत्वों द्वारा दर्शाए जाते हैं। फ़ील्ड विवरण प्रत्येक विवरण से क्षेत्र विवरण (JRXML में <fieldDescription> तत्व) द्वारा प्रदान की गई XPath अभिव्यक्ति का उपयोग करके प्राप्त किया जाता है।

XPath एक भाषा है जिसका उपयोग XML दस्तावेज़ की विशेषताओं और तत्वों के माध्यम से नेविगेट करने के लिए किया जाता है। XPath के बारे में अधिक जानकारी पर पाया जा सकता हैhttp://www.w3.org/TR/xpath.

सीएसवी डेटा स्रोत

JRCsvDataSourceडेटा स्रोतों के लिए एक कार्यान्वयन का प्रतिनिधित्व करता है, जो संरचित पाठ फ़ाइलों से उनके डेटा को पुनर्प्राप्त करता है; आमतौर पर सी.एस.वी. फ़ील्ड मानों को उनके स्तंभ अनुक्रमणिका का उपयोग करके पुनर्प्राप्त किया जाता है।

XLS डेटा स्रोत

JRXlsDataSourceडेटा स्रोतों के लिए एक कार्यान्वयन का प्रतिनिधित्व करता है, जो एक्सेल दस्तावेजों से उनके डेटा को पुनर्प्राप्त करता है। इस डेटा स्रोत के कार्यान्वयन के लिए रिपोर्ट-फ़ील्ड मैपिंग फ़ील्ड कॉलम इंडेक्स पर भी आधारित है।

खाली डेटा स्रोत

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

प्रतिशोधी डेटा स्रोत

net.sf.jasperreports.engine.JRRewindableDataSourceमूल JRDataSource इंटरफ़ेस का विस्तार करता है। यह केवल एक विधि जोड़ता है, जिसे MoveFirst () कहा जाता है, इंटरफ़ेस में। इस विधि का उद्देश्य कर्सर को डेटा स्रोत में पहले तत्व पर ले जाना है।

रिवाइंड करने योग्य डेटा स्रोत तब उपयोगी होते हैं जब एक बैंड के अंदर रखी सब-रिपोर्ट के साथ काम किया जाता है जिसे isSplitAllowed = "गलत" सेटिंग के कारण विभाजित करने की अनुमति नहीं होती है और उप-रिपोर्ट प्रस्तुत करने के लिए वर्तमान पृष्ठ पर पर्याप्त स्थान नहीं है।

उपर्युक्त सभी डेटा स्रोत कार्यान्वयन केवल को छोड़कर, इसके विपरीत हैं JRResultSetDataSource, क्योंकि यह रिकॉर्ड पॉइंटर को पीछे ले जाने का समर्थन नहीं करता है। यह समस्या तभी उत्पन्न होती है जब यह डेटा स्रोत मैन्युअल रूप से java.sql.ResultSet को लपेटने के लिए उपयोग किया जाता है, इसे उप-रिपोर्ट में भेजने से पहले। कोई समस्या नहीं है, यदि SQL क्वेरी उप-रिपोर्ट टेम्पलेट में रहती है, क्योंकि इंजन अगले पृष्ठ पर उप-रिपोर्ट को पुनरारंभ करते समय इसे फिर से निष्पादित करेगा।

डेटा स्रोत प्रदाता

JasperReports लाइब्रेरी में एक इंटरफ़ेस है net.sf.jasperreports.engine.JRDataSourceProvider। यह डेटा स्रोत ऑब्जेक्ट बनाने और निपटाने में मदद करता है। GUI टूल का उपयोग करके रिपोर्ट टेम्पलेट बनाते समय, रिपोर्ट के डेटा स्रोत को कस्टमाइज़ करने के लिए एक विशेष टूल की आवश्यकता होती है। JRDataSourceProvider कस्टम डेटा स्रोतों को डिज़ाइन टूल में प्लग करने का मानक तरीका है। इस इंटरफ़ेस का एक कस्टम कार्यान्वयन निम्नलिखित विधियों को लागू करना चाहिए जो डेटा स्रोत ऑब्जेक्ट्स बनाने और निपटाने की अनुमति देते हैं और यदि संभव हो तो डेटा स्रोत के अंदर उपलब्ध रिपोर्ट फ़ील्ड को सूचीबद्ध करने के तरीके भी -

public boolean supportsGetFieldsOperation();

public JRField[] getFields(JasperReport report)
   throws JRException, UnsupportedOperationException;

public JRDataSource create(JasperReport report) throws JRException;

public void dispose(JRDataSource dataSource) throws JRException;

रिपोर्ट फ़ील्ड वे तत्व हैं, जो डेटा स्रोत और रिपोर्ट टेम्पलेट के बीच डेटा की मैपिंग का प्रतिनिधित्व करते हैं। वांछित अभिव्यक्ति प्राप्त करने के लिए फ़ील्ड्स को रिपोर्ट अभिव्यक्तियों में जोड़ा जा सकता है। एक रिपोर्ट टेम्पलेट में शून्य या अधिक <फ़ील्ड> तत्व हो सकते हैं। रिपोर्ट फ़ील्ड घोषित करते समय, डेटा स्रोत को रिपोर्ट टेम्पलेट में परिभाषित सभी फ़ील्डों के अनुरूप डेटा की आपूर्ति करनी चाहिए।

क्षेत्र घोषणा

क्षेत्र की घोषणा नीचे दी गई है -

<field name = "FieldName" class = "java.lang.String"/>

नाम का गुण

नाम <क्षेत्र> तत्व की विशेषता अनिवार्य है। यह नाम से रिपोर्ट के भावों में क्षेत्र का संदर्भ देता है।

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

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

फ़ील्ड विवरण

<FieldDesciption> तत्व एक वैकल्पिक तत्व है। कस्टम डेटा स्रोत को लागू करते समय यह बहुत उपयोगी है। उदाहरण के लिए, हम एक कुंजी या कुछ जानकारी संग्रहीत कर सकते हैं, जिसके द्वारा हम रनटाइम पर कस्टम डेटा स्रोत से फ़ील्ड का मान पुनः प्राप्त कर सकते हैं। फ़ील्ड नाम के बजाय <fieldDesciption> तत्व का उपयोग करके, आप डेटा स्रोत से फ़ील्ड मान प्राप्त करते समय फ़ील्ड-नामकरण सम्मेलनों के प्रतिबंध को आसानी से दूर कर सकते हैं।

निम्नलिखित हमारे मौजूदा JRXML फ़ाइल (अध्याय रिपोर्ट डिजाइन ) से कोड का एक टुकड़ा है । यहां, हम इसका उपयोग देख सकते हैंname, class, तथा fieldDescription तत्वों।

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

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

क्रमबद्ध फ़ील्ड

उस समय जब डेटा छँटाई की आवश्यकता होती है और डेटा स्रोत कार्यान्वयन इसका समर्थन नहीं करता है (उदाहरण के लिए CSV डेटा स्रोत), JasperReports इन-मेमोरी फ़ील्ड-आधारित डेटा स्रोत सॉर्टिंग का समर्थन करता है। रिपोर्ट टेम्पलेट में एक या अधिक <SortField> तत्वों का उपयोग करके छँटाई की जा सकती है।

यदि कम से कम एक प्रकार का फ़ील्ड निर्दिष्ट किया जाता है, तो रिपोर्ट भरने की प्रक्रिया के दौरान, डेटा स्रोत JRSortableDataSource उदाहरण के लिए पारित किया जाता है । यह बदले में, डेटा स्रोत से सभी रिकॉर्ड प्राप्त करता है, निर्दिष्ट फ़ील्ड के अनुसार मेमोरी सॉर्ट करता है, और मूल डेटा स्रोत को बदलता है।

सॉर्ट फ़ील्ड नाम रिपोर्ट फ़ील्ड नाम के समान होना चाहिए। छँटाई के लिए उपयोग की जाने वाली फ़ील्ड्स में java.util.Comparable को लागू करने वाले प्रकार होने चाहिए। सभी प्रकार के क्षेत्रों के लिए प्राकृतिक क्रमबद्ध छँटाई की जाती है, जैसे कि java.lang.String को छोड़कर (स्ट्रिंग प्रकार के लिए, रिपोर्ट भरने वाले स्थान के अनुरूप कोलेटर का उपयोग किया जाता है)। जब कई प्रकार के फ़ील्ड निर्दिष्ट किए जाते हैं, तो फ़ील्ड को उस क्रम में कुंजी कुंजियों के रूप में फ़ील्ड का उपयोग करके प्रदर्शन किया जाएगा जिसमें वे रिपोर्ट टेम्पलेट में दिखाई देते हैं। निम्नलिखित उदाहरण छँटाई सुविधा प्रदर्शित करता है।

क्रमबद्ध रिपोर्ट उदाहरण

आइए जोड़ते हैं <sortField> हमारे मौजूदा रिपोर्ट टेम्पलेट (अध्याय रिपोर्ट डिजाइन ) के लिए तत्व । आइए क्षेत्र के देश को अवरोही क्रम में क्रमबद्ध करें। संशोधित रिपोर्ट टेम्पलेट (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>
  
   <sortField name = "country" order = "Descending"/>
   <sortField name = "name"/>
   
   <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[$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

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

यहाँ, हम देख सकते हैं कि देश के नाम वर्णानुक्रम में अवरोही क्रम में व्यवस्थित हैं।

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

यह अध्याय आपको समझाएगा - रिपोर्ट अभिव्यक्ति कैसे काम करती है, यह मानते हुए कि उन्हें केवल जावा भाषा का उपयोग करके लिखा गया है। JRXML रिपोर्ट टेम्प्लेट में, कई तत्व हैं जो अभिव्यक्तियों को परिभाषित करते हैं -

  • <variableExpression>
  • <initialValueExpression>
  • <groupExpression>
  • <printWhenExpression>
  • <imageExpression>
  • <textFieldExpression>

अभिव्यक्ति की घोषणा

मूल रूप से, सभी रिपोर्ट एक्सप्रेशन जावा एक्सप्रेशन होते हैं, जो रिपोर्ट फ़ील्ड्स, रिपोर्ट वेरिएबल्स और रिपोर्ट मापदंडों का संदर्भ दे सकते हैं।

अभिव्यक्ति में क्षेत्र संदर्भ

एक अभिव्यक्ति में एक रिपोर्ट फ़ील्ड संदर्भ का उपयोग करने के लिए, फ़ील्ड का नाम बीच में रखा जाना चाहिए $F{तथा} चरित्र अनुक्रम, जैसा कि नीचे दिखाया गया है -

<textfieldexpression>
   $F{Name}
</textfieldexpression>

निम्नलिखित हमारे मौजूदा JRXML फ़ाइल (अध्याय रिपोर्ट डिजाइन) से कोड का एक टुकड़ा है -

<textFieldExpression class = "java.lang.String">
   <![CDATA[$F{country}]]>
</textFieldExpression>

अभिव्यक्ति में चर संदर्भ

एक अभिव्यक्ति में एक चर का संदर्भ देने के लिए, हमें चर का नाम बीच में रखना चाहिए $V{तथा} जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है -

<textfieldexpression>
   "Total height : " + $V{SumOfHeight} + " ft."
</textfieldexpression>

अभिव्यक्ति में पैरामीटर संदर्भ

एक अभिव्यक्ति में एक पैरामीटर को संदर्भित करने के लिए, पैरामीटर का नाम बीच में रखा जाना चाहिए $P{तथा} जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है -

<textfieldexpression>
   "ReportTitle : " + $P{Title}
</textfieldexpression>

निम्नलिखित हमारी मौजूदा JRXML फ़ाइल से कोड का एक टुकड़ा है, जो एक अभिव्यक्ति में पैरामीटर के संदर्भ को दर्शाता है। (अध्याय रिपोर्ट डिजाइन से JRXML ) -

<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>

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

निम्न उदाहरण दिखाता है - java.lang.String रिपोर्ट फ़ील्ड "नाम" से पहला अक्षर कैसे निकालना और प्रदर्शित करना है -

<textFieldExpression>
   $F{Name}.substring(0, 1)
</textFieldExpression>

अभिव्यक्ति में संसाधन बंडल संदर्भ

एक अभिव्यक्ति में एक संसाधन का संदर्भ देने के लिए, कुंजी को बीच में रखा जाना चाहिए$R{तथा} जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है -

<textfieldexpression>
   $R{report.title}
</textfieldexpression>

रनटाइम-सप्लाई किए गए लोकेल और रिपोर्ट.टाइट कुंजी के आधार पर , रिपोर्ट टेम्पलेट से जुड़े संसाधन बंडल को लोड किया जाता है। इसलिए, संसाधन बंडल से स्ट्रिंग मान निकालकर रिपोर्ट का शीर्षक प्रदर्शित किया जाता है। अंतर्राष्ट्रीयकरण पर अधिक अध्याय अंतर्राष्ट्रीयकरण में पाया जा सकता है ।

कैलकुलेटर

कैलक्यूलेटर जैस्पररीपोर्ट्स में एक इकाई है, जो रिपोर्ट-भरने के समय में अभिव्यक्तियों और वेतन वृद्धि चर या डेटासेट का मूल्यांकन करती है। संकलन प्रक्रिया के दौरान, संकलक द्वारा संकलित रिपोर्ट में सूचना का उत्पादन और संग्रहित किया जाता है। इस जानकारी का उपयोग रिपोर्ट भरने के समय के दौरान net.sf.jasperreports.engine.fill.JRCalculator वर्ग का एक उदाहरण बनाने के लिए किया जाता है।

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

सशर्त अभिव्यक्तियाँ

यदि जप-चर कथन को परिभाषित करते समय JasperReports समर्थन नहीं करता है। इसके बजाय, आप टर्नरी ऑपरेटरों का उपयोग कर सकते हैं{cond} ? {statement 1} : {statement 2}। यह ऑपरेटर कई स्थितियों के आधार पर वांछित आउटपुट प्राप्त करने के लिए एक जावा एक्सप्रेशन के अंदर नेस्टेड किया जा सकता है।

रिपोर्ट में सशर्त अभिव्यक्ति का उदाहरण

आइए मौजूदा रिपोर्ट टेम्पलेट (अध्याय रिपोर्ट डिजाइन ) को संशोधित करें और क्षेत्र देश के लिए एक सशर्त अभिव्यक्ति जोड़ें। संशोधित रिपोर्ट टेम्पलेट (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>
   
   <sortField name = "country" order = "Descending"/>
   <sortField name = "name"/>
   
   <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}.isEmpty() ? "NO COUNTRY" : $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[$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")); dataBeanList.add(produce("Tanmay", ""));
      
      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 3 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: 5 minutes 5 seconds

C:\tools\jasperreports-5.0.1\test>

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

यहां, हम देख सकते हैं, पिछले रिकॉर्ड के लिए, हमने फ़ील्ड देश के लिए कोई डेटा पास नहीं किया था, "NO COUNTRY" मुद्रित किया जा रहा है।

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

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

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

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

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

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

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

<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

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

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

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

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

जैस्परपोर्ट में, शब्दावली और रिपोर्ट अनुभाग भी कहे जाते हैं 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> तत्व केवल रिपोर्ट पर प्रदर्शित किए जाएंगे, यदि इसमें एक से अधिक कॉलम हों।

JasperReports में समूह तार्किक तरीके से रिपोर्ट पर डेटा को व्यवस्थित करने में मदद करते हैं। एक रिपोर्ट समूह डेटा स्रोत में लगातार रिकॉर्ड के एक अनुक्रम का प्रतिनिधित्व करता है, जिसमें आम कुछ होता है, जैसे कि एक निश्चित रिपोर्ट फ़ील्ड का मान। एक रिपोर्ट समूह को <समूह> तत्व द्वारा परिभाषित किया गया है। एक रिपोर्ट में कितने भी समूह हो सकते हैं। एक बार घोषित होने के बाद, समूहों को पूरी रिपोर्ट में संदर्भित किया जा सकता है।

एक रिपोर्ट समूह में तीन तत्व होते हैं -

  • समूह अभिव्यक्ति - यह उस डेटा को इंगित करता है जिसे नया डेटा समूह शुरू करने के लिए बदलना होगा।

  • समूह हेडर अनुभाग - समूहित डेटा की शुरुआत में जगह लेबल में मदद करता है।

  • समूह पाद लेख अनुभाग - समूहित डेटा के अंत में जगह लेबल में मदद करता है।

रिपोर्ट-भरने के समय डेटा स्रोत के माध्यम से पुनरावृत्ति के दौरान यदि समूह अभिव्यक्ति का मूल्य बदल जाता है, तो एक समूह टूटना होता है और परिणामस्वरूप समूह में संबंधित <GroupFooter> और <groupHeader> अनुभाग सम्मिलित होते हैं।

रिपोर्ट समूह तंत्र डेटा स्रोत द्वारा आपूर्ति किए गए डेटा पर कोई छँटाई नहीं करता है। डेटा ग्रुपिंग उम्मीद के मुताबिक ही काम करता है जब रिपोर्ट में इस्तेमाल किए गए ग्रुप एक्सप्रेशन के अनुसार डेटा सोर्स में रिकॉर्ड पहले से ही ऑर्डर किए गए हों।

समूह गुण

<समूह> तत्व में ऐसी विशेषताएं हैं जो हमें यह नियंत्रित करने की अनुमति देती हैं कि समूहीकृत डेटा कैसे रखी गई है। विशेषताएँ नीचे दी गई तालिका में संक्षेपित हैं -

S.NO विशेषता और विवरण
1

name

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

2

isStartNewColumn

जब सही पर सेट किया जाता है , तो प्रत्येक डेटा समूह एक नए कॉलम पर शुरू होगा। डिफ़ॉल्ट मान गलत है

3

isStartNewPage

जब सही पर सेट किया जाता है , तो प्रत्येक डेटा समूह एक नए पृष्ठ पर शुरू होगा। डिफ़ॉल्ट मान गलत है

4

isResetPageNumber

जब सही पर सेट किया जाता है , तो एक नया समूह शुरू होने पर हर बार रिपोर्ट पेज नंबर रीसेट हो जाएगा। डिफ़ॉल्ट मान गलत है।

5

isReprintHeaderOnEachPage

जब सही पर सेट किया जाता है , तो समूह हेडर को हर पेज पर पुन: प्रिंट किया जाएगा। डिफ़ॉल्ट मान गलत है
6

minHeightToStartNewPage

समूह शीर्ष लेख को वर्तमान स्तंभ पर रखने के लिए स्तंभ के निचले भाग में आवश्यक लंबवत स्थान को परिभाषित करता है। रिपोर्ट इकाइयों में राशि निर्दिष्ट की गई है।

7

footerPosition

पृष्ठ पर समूह पाद लेख की स्थिति, साथ ही साथ इसका पालन करने वाले रिपोर्ट अनुभागों के संबंध में इसका व्यवहार। यह मान हो सकता है: सामान्य , StackAtBottom , ForceAtBottom और CollateAtBottom । डिफ़ॉल्ट मान सामान्य है

8

keepTogether

जब सही पर सेट किया जाता है , तो समूह को अपने पहले ब्रेक प्रयास पर विभाजित होने से रोकता है।

उदाहरण

आइए एक समूह जोड़ें (CountryGroup) मौजूदा रिपोर्ट टेम्पलेट (अध्याय रिपोर्ट डिजाइन ) के लिए। प्रत्येक देश की घटना को गिना जाता है और गिनती को समूह पाद लेख के रूप में प्रदर्शित किया जाता है। समूह हेडर में, प्रत्येक रिकॉर्ड की गिनती उपसर्ग है। संशोधित रिपोर्ट टेम्पलेट (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>
   
   <sortField name = "country" order = "Descending"/>
   <sortField name = "name"/>
   
   <variable name = "CountryNumber" class = "java.lang.Integer"
      incrementType = "Group" incrementGroup = "CountryGroup"
      calculation = "Count">
      <variableExpression><![CDATA[Boolean.TRUE]]></variableExpression>
   </variable>
   
   <group name = "CountryGroup" minHeightToStartNewPage = "60">
      <groupExpression><![CDATA[$F{country}]]></groupExpression> <groupHeader> <band height = "20"> <textField evaluationTime = "Group" evaluationGroup = "CountryGroup" bookmarkLevel = "1"> <reportElement mode = "Opaque" x = "0" y = "5" width = "515" height = "15" backcolor = "#C0C0C0"/> <box leftPadding = "10"> <bottomPen lineWidth = "1.0"/> </box> <textElement/> <textFieldExpression class = "java.lang.String"> <![CDATA[" " + String.valueOf($V{CountryNumber}) + ". "
                  + String.valueOf($F{country})]]> </textFieldExpression> <anchorNameExpression> <![CDATA[String.valueOf($F{country})]]>
               </anchorNameExpression>
            </textField>
         
         </band>
      </groupHeader>
      
      <groupFooter>
         <band height = "20">
            
            <staticText>
               <reportElement x = "400" y = "1" width = "60" height = "15"/>
               <textElement textAlignment = "Right"/>
               <text><![CDATA[Count :]]></text>
            </staticText>
            
            <textField>
               <reportElement x = "460" y = "1" width = "30" height = "15"/>
               <textElement textAlignment = "Right"/>
               
               <textFieldExpression class = "java.lang.Integer">
                  <![CDATA[$V{CountryGroup_COUNT}]]> </textFieldExpression> </textField> </band> </groupFooter> </group> <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[$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

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

यहां, हम देखते हैं कि प्रत्येक देश को समूहीकृत किया गया है और प्रत्येक समूह के पाद लेख पर प्रत्येक देश की घटना की गणना प्रदर्शित की गई है।

एक रिपोर्ट में पाठ तत्व शामिल हैं और इनमें से प्रत्येक की अपनी फ़ॉन्ट सेटिंग्स हो सकती हैं। इन सेटिंग्स को <का उपयोग करके निर्दिष्ट किया जा सकता हैfont> टैग <textElement> टैग में उपलब्ध है। एक रिपोर्ट कई फोंट को परिभाषित कर सकती है। एक बार परिभाषित करने के बाद, उन्हें संपूर्ण रिपोर्ट में अन्य फ़ॉन्ट परिभाषाओं के लिए डिफ़ॉल्ट या आधार फ़ॉन्ट सेटिंग्स के रूप में उपयोग किया जा सकता है।

रिपोर्ट फ़ॉन्ट्स

एक रिपोर्ट फ़ॉन्ट फ़ॉन्ट सेटिंग्स का एक संग्रह है, रिपोर्ट स्तर पर घोषित किया जाता है। पाठ तत्वों के फ़ॉन्ट गुण सेट करते समय पूरे रिपोर्ट टेम्पलेट में एक रिपोर्ट फ़ॉन्ट का पुन: उपयोग किया जा सकता है।

रिपोर्ट फोंट अब पदावनत हो गए हैं। दस्तावेज़ के भीतर ही घोषित किए गए <reportFont /> तत्वों का उपयोग न करें। इसके बजाय <शैली /> तत्व का उपयोग करें।

फ़ॉन्ट विशेषताएँ

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

S.NO विशेषता और विवरण
1

fontName

फ़ॉन्ट नाम, जो एक भौतिक फ़ॉन्ट का नाम हो सकता है, एक तार्किक एक, या पंजीकृत जैस्पररीपोर्ट्स फ़ॉन्ट एक्सटेंशन से एक फ़ॉन्ट परिवार का नाम।

2

size

फ़ॉन्ट का आकार बिंदुओं में मापा जाता है। यह 10 तक डिफॉल्ट करता है।

3

isBold

बोल्ड फ़ॉन्ट की आवश्यकता होने पर ध्वज निर्दिष्ट करना। यह असत्य की रक्षा करता है।

4

isItalic

यदि इटैलिक फ़ॉन्ट आवश्यक है तो ध्वज निर्दिष्ट करता है। यह असत्य की रक्षा करता है।

5

isUnderline

यदि टेक्स्ट की सजावट को रेखांकित करना आवश्यक है तो ध्वज निर्दिष्ट करना। यह असत्य की रक्षा करता है।

6

isStrikeThrough

यदि स्ट्राइकथ्रू पाठ सजावट की आवश्यकता है, तो ध्वज निर्दिष्ट करता है। यह असत्य की रक्षा करता है।

7

pdfFontName

दस्तावेज़ों को पीडीएफ प्रारूप में निर्यात करते समय iText लाइब्रेरी द्वारा आवश्यक समकक्ष पीडीएफ फ़ॉन्ट का नाम।

8

pdfEncoding

समतुल्य पीडीएफ चरित्र एन्कोडिंग, iText पुस्तकालय द्वारा भी आवश्यक है।

9

isPdfEmbedded

वह ध्वज जो निर्दिष्ट करता है कि क्या फ़ॉन्ट को दस्तावेज़ में ही एम्बेड किया जाना चाहिए। यह असत्य की रक्षा करता है। यदि यह सच है, तो बिना किसी समस्या के पीडीएफ दस्तावेज़ देखने में मदद करता है।

फ़ॉन्ट प्रकार

JasperReports फोंट में वर्गीकृत किया जा सकता है -

  • Logical Fonts- पांच प्रकार के प्रकार, जिन्हें 1.0 संस्करण के बाद से जावा प्लेटफॉर्म द्वारा मान्यता दी गई है, उन्हें तार्किक फोंट कहा जाता है। ये हैं -Serif, SansSerif, Monospaced, Dialog, and DialogInput। ये तार्किक फ़ॉन्ट वास्तविक फ़ॉन्ट लाइब्रेरी नहीं हैं जो सिस्टम पर कहीं भी स्थापित हैं। वे जावा रनटाइम द्वारा पहचाने जाने वाले फ़ॉन्ट प्रकार के नाम हैं। सिस्टम पर स्थापित कुछ भौतिक फ़ॉन्ट के लिए मैप किया जाना चाहिए।

  • Physical Fonts- ये फोंट वास्तविक फ़ॉन्ट लाइब्रेरी हैं, उदाहरण के लिए, ट्रू टाइप या पोस्टस्क्रिप्ट टाइप 1 फोंट। भौतिक फोंट एरियल, टाइम, हेल्वेटिका, कूरियर, या किसी भी संख्या में अन्य फोंट हो सकते हैं, जिनमें अंतर्राष्ट्रीय फोंट शामिल हैं।

  • Font Extensions- JasperReports पुस्तकालय रन-टाइम पर पंजीकृत फोंट के उपयोग को फॉन्ट एक्सटेंशन के लिए अपने अंतर्निहित समर्थन के माध्यम से कर सकता है। फॉन्ट परिवारों की एक सूची को फॉन्ट एक्सटेंशन का उपयोग करके जैस्पररीपोर्ट्स को उपलब्ध कराया जा सकता है। ये समान दिखने वाले फ़ॉन्ट चेहरों और विशिष्ट स्थानों का समर्थन करने से बने हैं।

तालिका में वर्णित जैसा कि ऊपर हम विशेषता में निर्दिष्ट करने की आवश्यकता fontName एक शारीरिक फ़ॉन्ट का नाम, एक तार्किक फ़ॉन्ट का नाम, या पंजीकृत JasperReports से एक फ़ॉन्ट परिवार का नाम एक्सटेंशन फ़ॉन्ट।

पीडीएफ फ़ॉन्ट नाम

JasperReports पुस्तकालय पीडीएफ, (पोर्टेबल दस्तावेज़ प्रारूप) को रिपोर्ट निर्यात करते समय iText पुस्तकालय का उपयोग करता है। पीडीएफ फाइलों को विभिन्न प्लेटफार्मों पर देखा जा सकता है और हमेशा समान दिखेंगे। यह आंशिक रूप से है क्योंकि इस प्रारूप में, फोंट से निपटने का एक विशेष तरीका है। PDF में निर्यात करते समय fontName विशेषता का कोई फायदा नहीं है। गुण pdfFontName मौजूद है जहाँ हम फ़ॉन्ट सेटिंग्स निर्दिष्ट करने के लिए की जरूरत है।

IText लाइब्रेरी बिल्ट-इन फोंट और टीटीएफ फ़ाइलों से निपटने का तरीका जानती है और निम्न निर्मित फॉन्ट नामों को पहचानती है -

  • Courier
  • Courier-Bold
  • Courier-BoldOblique
  • Courier-Oblique
  • Helvetica
  • Helvetica-Bold
  • Helvetica-BoldOblique
  • Helvetica-Oblique
  • Symbol
  • Times-Roman
  • Times-Bold
  • Times-BoldItalic
  • Times-Italic
  • ZapfDingbats

फोंट के साथ काम करने के लिए iText पुस्तकालय के अनुसार, हमें फोंट नाम के रूप में निम्नलिखित में से एक को निर्दिष्ट करने की आवश्यकता है -

  • उपरोक्त सूची से एक निर्मित फ़ॉन्ट नाम।

  • एक टीटीएफ (ट्रू टाइप फॉन्ट) फ़ाइल का नाम, जिसे वह डिस्क पर खोज सकता है।

  • फ़ॉन्ट का वास्तविक नाम, बशर्ते कि फ़ॉन्ट से युक्त TTF फ़ाइल को पहले iText के साथ पंजीकृत किया गया हो या जब फ़ॉन्ट पंजीकृत होने पर एक उपनाम परिभाषित किया गया हो।

उपरोक्त पूर्व-आवश्यकताओं के आधार पर, pdfFontName विशेषता में निम्न मान हो सकते हैं -

  • उपरोक्त सूची से एक अंतर्निहित पीडीएफ फ़ॉन्ट का नाम।

  • एक टीटीएफ फ़ाइल का नाम जो पीडीएफ को निर्यात करते समय डिस्क पर रनटाइम पर स्थित हो सकता है।

  • एक पंजीकृत फ़ॉन्ट का वास्तविक नाम।

  • कुंजी का प्रत्यय ( फ़ॉन्ट net.sf.jasperreports.export.pdf.font के बाद का हिस्सा ) फॉन्ट फाइल के रूप में iText के साथ पंजीकृत फॉन्ट के लिए।

डिफ़ॉल्ट फ़ॉन्ट्स और वंशानुक्रम

प्रत्येक पाठ तत्व को अपने मूल तत्व से फ़ॉन्ट और शैली विशेषताएँ विरासत में मिलती हैं, जो बदले में अपने माता-पिता से इन विशेषताओं को प्राप्त करती हैं। यदि तत्वों के लिए कोई शैली और / या फ़ॉन्ट परिभाषित नहीं किए गए हैं, तो डिफ़ॉल्ट रूप (<और / या फ़ॉन्ट - लेकिन अब इसे हटा दिया गया है) <jasperReport /> रूट तत्व में घोषित किया जाएगा।

जैस्परपरपोर्ट्स में डिफॉल्ट स्टाइल या फोंट को परिभाषित करना अनिवार्य नहीं है। यदि किसी दिए गए तत्व के लिए कोई फ़ॉन्ट परिभाषित नहीं किया गया है, तो इंजन या तो विरासत में मिली फ़ॉन्ट विशेषताओं के लिए दिखता है, या, यदि कोई विशेषता इस तरह से नहीं मिलती है, तो यह net.sf.jasperreports.default.font.name संपत्ति / में दिखता है। src / default.jasperreports.properties फ़ाइल। इसका मान फ़ॉन्ट परिवार के नाम को परिभाषित करने के लिए उपयोग किया जाता है जब फ़ॉन्ट गुण स्पष्ट रूप से एक पाठ तत्व के लिए परिभाषित नहीं होते हैं या अपने माता-पिता से विरासत में मिलते हैं।

मुख्य डिफ़ॉल्ट फ़ॉन्ट गुण और उनके मान परिभाषित /src/default.jasperreports.properties फ़ाइल नीचे दी गई तालिका में हैं -

संपत्ति विवरण
net.sf.jasperreports.default.font.name = SansSerif डिफ़ॉल्ट फ़ॉन्ट नाम।
net.sf.jasperreports.default.font.size = 10 डिफ़ॉल्ट फ़ॉन्ट आकार।
net.sf.jasperreports.default.pdf.font.name = Helvetica डिफ़ॉल्ट पीडीएफ फ़ॉन्ट।
net.sf.jasperreports.default.pdf.encoding = Cp1252 डिफ़ॉल्ट पीडीएफ चरित्र एन्कोडिंग।
net.sf.jasperreports.default.pdf.embedded = false डिफ़ॉल्ट रूप से पीडीएफ फोंट एम्बेडेड नहीं हैं।

उदाहरण

किसी विशेष पाठ की उपस्थिति पाने के लिए फ़ॉन्ट और फ़ॉन्ट विशेषताओं का उपयोग करने के लिए, आइए नई रिपोर्ट टेम्पलेट (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 = "595" pageHeight = "842"
   columnWidth = "555" leftMargin = "20" rightMargin = "20" topMargin = "30"
   bottomMargin = "30">

   <title>
      <band height = "682">
      
      <staticText>
         <reportElement x = "0" y = "50" width = "150" height = "40"/>
         <textElement/>
         
         <text>
            <![CDATA[Welcome to TutorialsPoint!]]>
         </text>
      </staticText>
      
      <staticText>
         <reportElement x = "160" y = "50" width = "390" height = "40"/>
         <textElement/>
         
         <text>
           <![CDATA[<staticText>
           <reportElement x = "0" y = "50" width = "150" height = "40"/>
           <text>Welcome to TutorialsPoint!</text></staticText>]]>
         </text>
      </staticText>
      
      <staticText>
         <reportElement x = "0" y = "100" width = "150" height = "40"/>
         
         <textElement>
            <font size = "12"/>
         </textElement>
         
         <text><![CDATA[Welcome to TutorialsPoint!]]></text>
      </staticText>
      
      <staticText>
         <reportElement x = "160" y = "100" width = "390" height = "40"/>
         <textElement/>
         
         <text>
            <![CDATA[<staticText>
            <reportElement x = "0" y = "100" width = "150" height = "40"/>
            
            <textElement>
               <font size = "14"/>
            </textElement>
				
            <text> Welcome to TutorialsPoint!</text></staticText>]]>
         </text>
      </staticText>
      
      <staticText>
         <reportElement x = "0" y = "150" width = "150" height = "40"/>
         
         <textElement>
            <font fontName = "DejaVu Serif" size = "12" isBold = "false"/>
         </textElement>
			
         <text><![CDATA[Welcome to TutorialsPoint!]]></text>
      </staticText>
      
      <staticText>
         <reportElement x = "160" y = "150" width = "390" height = "40"/>
         <textElement/>
         
         <text>
            <![CDATA[<staticText>
            <reportElement x = "0" y = "250" width = "150" height = "40"/>
            
            <textElement>
               <font fontName = "DejaVu Serif" size = "12" isBold = "false"/>
            </textElement>
				
            <text>Welcome to TutorialsPoint!</text></staticText>]]>
         </text>
      </staticText>
      
      <staticText>
         <reportElement x = "0" y = "200" width = "150" height = "40"/>
         
         <textElement>
            <font fontName = "DejaVu Serif" size = "12" isBold = "true"/>
         </textElement>
			
         <text><![CDATA[Welcome to TutorialsPoint!]]></text>
      </staticText>
      
      <staticText>
         <reportElement x = "160" y = "200" width = "390" height = "40"/>
         <textElement/>
         
         <text>
            <![CDATA[<staticText>
            <reportElement x = "0" y = "300" width = "150" height = "40"/>
            
            <textElement>
               <font fontName = "DejaVu Serif" size = "12" isBold = "true"/>
            </textElement>
				
            <text>Welcome to TutorialsPoint!</text></staticText>]]>
         </text>
      </staticText>
      
      <staticText>
         <reportElement x = "0" y = "250" width = "150" height = "40"/>
         
         <textElement>
            <font fontName = "Monospaced" size = "12" isItalic = "true" 
               isUnderline = "true" pdfFontName = "Courier-Oblique"/>
         </textElement>
         
         <text><![CDATA[Welcome to TutorialsPoint!]]></text>
      </staticText>
      
      <staticText>
         <reportElement x = "160" y = "250" width = "390" height = "40"/>
         <textElement/>
         
         <text>
            <![CDATA[<staticText>
            <reportElement x = "0" y = "350" width = "150" height = "40"/>
            
            <textElement>
               <font fontName = "Monospaced" size = "12" isItalic = "true"
                  isUnderline = "true" pdfFontName = "Courier-Oblique"/>
            </textElement>
            
            <text>Welcome to TutorialsPoint!</text></staticText>]]>
         </text>
      </staticText>
      
      <staticText>
         <reportElement x = "0" y = "300" width = "150" height = "40"/>
         
         <textElement>
            <font fontName = "Monospaced" size = "12" isBold = "true"
               isStrikeThrough = "true" pdfFontName = "Courier-Bold"/>
         </textElement>
         <text><![CDATA[Welcome to TutorialsPoint!]]></text>
      </staticText>
      
      <staticText>
         <reportElement x = "160" y = "300" width = "390" height = "40"/>
         <textElement/>
         
         <text>
            <![CDATA[<staticText>
            <reportElement x = "0" y = "400" width = "150" height = "40"/>
            
            <textElement>
               <font fontName = "Monospaced" size = "12" isBold = "true"
                  isStrikeThrough = "true" pdfFontName = "Courier-Bold"/>
            </textElement>
				
            <text>Welcome to TutorialsPoint!</text></staticText>]]>
         </text>
      </staticText>
      
      <staticText>
         <reportElement x = "0" y = "350" width = "150" height = "40" 
            forecolor = "#FF0000"/>
         
         <textElement>
            <font size = "14"/>
         </textElement>
			
         <text><![CDATA[Welcome to TutorialsPoint!]]></text>
      </staticText>
      
      <staticText>
         <reportElement x = "160" y = "350" width = "390" height = "40"/>
         <textElement/>
         
         <text>
            <![CDATA[<staticText>
            <reportElement x = "0" y = "450" width = "150" height = "40"
               forecolor = "red"/>
            
            <textElement><font size = "14"/></textElement>
            <text>Welcome to TutorialsPoint!</text></staticText>]]>
         </text>
      </staticText>
      
      <staticText>
         <reportElement x = "0" y = "400" width = "150" height = "40" mode = "Opaque"
            forecolor = "#00FF00" backcolor = "#FFFF00"/>
         
         <textElement>
            <font fontName = "Serif" size = "12" isBold = "true" 
               pdfFontName = "Times-Bold"/>
         </textElement>
			
         <text><![CDATA[Welcome to TutorialsPoint!]]></text>
      </staticText>
      
      <staticText>
         <reportElement x = "160" y = "400" width = "390" height = "40"/>
         <textElement/>
         
         <text>
            <![CDATA[<staticText>
            <reportElement x = "0" y = "500" width = "150" height = "40"
               forecolor = "green" backcolor = "#FFFF00" mode = "Opaque"/>
            
            <textElement>
               <font fontName = "Serif" size = "12" isBold = "true"
                  pdfFontName = "Times-Bold"/>
            </textElement>
				
            <text>Welcome to TutorialsPoint!</text></staticText>]]>
         </text>
      </staticText>
      
      <staticText>
         <reportElement x = "0" y = "450" width = "150" height = "40" mode = "Opaque"
            forecolor = "#0000FF" backcolor = "#FFDD99"/>
         
         <textElement textAlignment = "Center" verticalAlignment = "Middle">
            <font fontName = "SansSerif" size = "12" isBold = "false"
            isItalic = "true" pdfFontName = "Sans.Slanted" isPdfEmbedded = "true"/>
         </textElement>
			
         <text><![CDATA[Welcome to TutorialsPoint!]]></text>
      </staticText>
      
      <staticText>
         <reportElement x = "160" y = "450" width = "390" height = "40"/>
         <textElement/>
         
         <text>
            <![CDATA[<staticText>
            <reportElement x = "0" y = "550" width = "150" height = "90"
               forecolor = "blue" backcolor = "#FFDD99" mode = "Opaque"/>
            
            <textElement textAlignment = "Center" verticalAlignment = "Middle">
               <font fontName = "SansSerif" size = "12" isBold = "false"
                  pdfFontName = "Sans.Slanted" isPdfEmbedded = "true"/>
            </textElement>
				
            <text>Welcome to TutorialsPoint!</text></staticText>]]>
         </text>
      </staticText>
      
      <staticText>
         <reportElement mode = "Opaque" x = "0" y = "500" width = "150" height = "40"
            forecolor = "#FF0000" backcolor = "#99DDFF"/>
         
         <textElement textAlignment = "Right" verticalAlignment = "Bottom">
            <font fontName = "SansSerif" size = "12" isBold = "true"
               pdfFontName = "DejaVu Sans Bold" isPdfEmbedded = "true"/>
         </textElement>
			
         <text><![CDATA[Welcome to TutorialsPoint!]]></text>
      </staticText>
      
      <staticText>
         <reportElement x = "160" y = "500" width = "390" height = "40"/>
         <textElement/>
         
         <text>
            <![CDATA[<staticText>
            <reportElement x = "0" y = "650" width = "150" height = "90"    forecolor = "red"
               backcolor = "#99DDFF" mode = "Opaque"/>
            
            <textElement textAlignment = "Right" verticalAlignment = "Bottom">
               <font fontName = "SansSerif" size = "12" isBold = "true"
                  pdfFontName = "DejaVu Sans Bold" isPdfEmbedded = "true"/>
            </textElement>
				
            <text>Welcome to TutorialsPoint!</text></staticText>]]>
         </text>
      
      </staticText>
   
   </band>
</title>

</jasperReport>

रिपोर्ट भरने और उत्पन्न करने के लिए जावा कोड नीचे दिया गया है। आइए इस फाइल को सेव करेंJasperFontsReportFill.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 JasperFontsReportFill {
   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 को अध्याय पर्यावरण सेटअप से चुना गया है और इसे 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.JasperFontsReportFill (viewFullReport डिफ़ॉल्ट लक्ष्य है) -

C:\tools\jasperreports-5.0.1\test>ant -Dmain-class=com.tutorialspoint.JasperFontsReportFill
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.
   [javac] Compiling 5 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.JasperFontsReportFill
   [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: 45 minutes 3 seconds

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

यहां, हम देख सकते हैं कि टेक्स्ट "वेलकम टू ट्युटोरप्सप्वाइंट" अलग-अलग फॉन्ट फॉर्मेट में प्रदर्शित है।

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

हम जानते हैं कि अलग-अलग भाषाओं को विशिष्ट वर्ण प्रतिनिधित्व के संबंध में अलग-अलग चरित्र सेट की आवश्यकता होती है। इसलिए, ग्रंथों के साथ काम करने का मतलब है फोंट के साथ काम करना। हालांकि, जैस्परपरपोर्ट्स में फोंट का उपयोग करने के बारे में एक विस्तृत चर्चा अध्याय रिपोर्ट फ़ॉन्ट्स में उपलब्ध है ।

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

अक्षरों को सांकेतिक अक्षरों में बदलना

एक वर्ण लेखन की सबसे छोटी इकाई है जो एक सार्थक जानकारी देती है। यह एक अमूर्त अवधारणा है, एक चरित्र में एक दृश्य उपस्थिति नहीं है। "अपरकेस लैटिन ए" "लोअरकेस लैटिन" और "अपरकेस सिरिलिक ए" और "अपरकेस ग्रीक अल्फा" से एक अलग चरित्र है।

एक चरित्र का एक दृश्य प्रतिनिधित्व एक के रूप में जाना जाता है glyph। ग्लिफ़ के एक निश्चित समूह को कहा जाता हैfont। "अपरकेस लैटिन ए", "अपरकेस सिरिलिक ए" और "अपरकेस ग्रीक अल्फा" में समान ग्लिफ़ हो सकते हैं, लेकिन वे अलग-अलग वर्ण हैं। उसी समय, "अपरकेस लैटिन ए" के लिए ग्लिफ़ टाइम्स न्यू रोमन, गिल संस और पोइटिका चांसरी इटैलिक में बहुत अलग दिख सकते हैं, लेकिन वे अभी भी उसी चरित्र का प्रतिनिधित्व करते हैं।

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

एनकोडिंग सामान्य रूप से ओकटेट्स के संदर्भ में व्यक्त की जाती है। एक ऑक्टेट आठ बाइनरी अंकों का एक समूह है, अर्थात, आठ वाले और शून्य। एक ओकटेट 0 और 255 के बीच या 0x00 और 0xFF के बीच एक संख्यात्मक सीमा व्यक्त कर सकता है, हेक्साडेसिमल नोटेशन का उपयोग करने के लिए।

यूनिकोड

एक यूनिकोड एक चरित्र प्रदर्शनों की सूची है जिसमें दुनिया की भाषाओं में प्रयुक्त अधिकांश वर्ण शामिल हैं। यह लाखों पात्रों को समायोजित कर सकता है, और पहले से ही हजारों की संख्या में शामिल हैं। यूनिकोड को 64K वर्णों के "विमानों" में विभाजित किया गया है। अधिकांश परिस्थितियों में उपयोग किया जाने वाला एकमात्र विमान पहला विमान है, जिसे मूल बहुभाषी विमान या बीएमपी के रूप में जाना जाता है।

UTF-8 अनुशंसित एन्कोडिंग है। यह विभिन्न वर्णों का प्रतिनिधित्व करने के लिए ऑक्टेट की एक चर संख्या का उपयोग करता है।

JRXML फ़ाइल में, एन्कोडिंग विशेषता हैडर में निर्दिष्ट होती है। XML सामग्री को डीकोड करने के लिए रिपोर्ट संकलन समय पर इसका उपयोग किया जाता है। उदाहरण के लिए, यदि रिपोर्ट में केवल फ्रेंच शब्द और ç, é, â जैसे अक्षर हैं, तो ISO-8859-1 (उर्फ लैटिन -1) एन्कोडिंग पर्याप्त है -

<?xml version = "1.0" encoding = "ISO-8859-1"?>

जैसा कि ऊपर देखा गया है, आदर्श रूप से हम एन्कोडिंग को न्यूनतम वर्ण सेट में फिट कर सकते हैं, जो दस्तावेज़ में सभी वर्णों का सही प्रतिनिधित्व कर सकता है। लेकिन बहुभाषी दस्तावेजों (यानी कई भाषाओं में लिखे गए शब्दों वाले दस्तावेज़) के मामले में, किसी को न्यूनतम वर्ण सेट के लिए अनुकूलित एन्कोडिंग का चयन करना चाहिए, दस्तावेज़ में सभी वर्णों का सही ढंग से प्रतिनिधित्व करने में सक्षम, भले ही वे विभिन्न भाषाओं के हों। बहुभाषी दस्तावेजों को संभालने में सक्षम चरित्र एन्कोडिंग में से एक हैUTF-8, जैस्पररिपोर्ट द्वारा डिफ़ॉल्ट एन्कोडिंग मान के रूप में उपयोग किया जाता है।

ग्रंथों को आमतौर पर अंतर्राष्ट्रीयकरण के दौरान दस्तावेज़ के बजाय संसाधन बंडल फ़ाइलों में रखा जाता है। तो, ऐसे मामले हैं जहां जेआरएक्सएमएल स्वयं पूरी तरह से एएससीआईआई-संगत दिखता है, लेकिन रनटाइम पर उत्पन्न रिपोर्ट में एएससीआईआई के साथ अपठनीय ग्रंथ होते हैं। परिणामस्वरूप, एक निश्चित प्रकार के दस्तावेज़ निर्यात प्रारूप (जैसे CSV, HTML, XHTML, XML और पाठ) के लिए, जनरेट किए गए दस्तावेज़ के लिए एन्कोडिंग को भी जानना होगा। विभिन्न भाषाओं को विभिन्न चरित्र एन्कोडिंग द्वारा समर्थित किया जाता है। इसलिए हर बार, हमें एक स्थानीय वातावरण में एक रिपोर्ट चलाने की आवश्यकता है। इसके अलावा, हमें यह जानना होगा कि उत्पन्न दस्तावेज़ भाषा के लिए सबसे उपयुक्त वर्ण एन्कोडिंग है। इस स्थिति में, JRXML फ़ाइल में परिभाषित एन्कोडिंग गुण स्वयं अधिक उपयोगी नहीं हो सकता है।

इस तरह के मुद्दों को हल करने के लिए हम net.sf.jasperreports.export.character.encoding नामक एक्सपोर्ट कस्टमर प्रॉपर्टी का उपयोग कर सकते हैं । यह निर्यात कस्टम संपत्ति UTF-8 के लिए डिफ़ॉल्ट है और यह जैस्पररपोर्ट में मौजूद है।

यह डिफ़ॉल्ट मान default.jasperreports.properties फ़ाइल में सेट है । निर्यात समय पर अधिक विशिष्ट विकल्पों के लिए, CHARACTER_ENCODING निर्यात पैरामीटर भी उपलब्ध है।

उदाहरण

जैस्परस्पोर्ट्स में यूनिकोड समर्थन का उपयोग करने के लिए, आइए नई रिपोर्ट टेम्पलेट (jasper_report_template.jrxml) लिखें। Save it to C:\tools\jasperreports-5.0.1\testनिर्देशिका। यहां, हम यूनिकोड वर्णों (\ uXXXX) का उपयोग करके विभिन्न भाषाओं में एक पाठ प्रदर्शित करेंगे। UTF-8 के साथ एन्कोड किए गए किसी भी वर्ण को केवल 4 अंकों के हेक्साडेसिमल कोड का उपयोग करके दर्शाया जा सकता है। उदाहरण के लिए, ग्रीक अक्षर letter को \ u0393 लिखा जा सकता है। जब इस तरह के अंकन का सामना किया जाता है, तो इंजन चरित्र सेट में उचित चरित्र प्रतिनिधित्व के लिए कहता है, और केवल उस विशेष चरित्र को प्रिंट किया जाएगा। जेआरएक्सएमएल की सामग्री इस प्रकार है -

<?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" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20">

   <parameter name = "GreekText" class = "java.lang.String" isForPrompting = "false">
      <defaultValueExpression><![CDATA["\u0394\u03B5\u03BD "+
         "\u03BA\u03B1\u03C4\u03B1\u03BB\u03B1\u03B2\u03B1\u03AF"+
         "\u03BD\u03C9 \u0395\u03BB\u03BB\u03B7\u03BD\u03B9\u03BA\u03AC"]]>
      </defaultValueExpression>
   </parameter>
   
   <parameter name = "CyrillicText" class = "java.lang.String" isForPrompting = "false">
      <defaultValueExpression><![CDATA["\u042F \u043D\u0435 "+
         "\u043C\u043E\u0433\u0443 \u043F\u043E\u043D\u044F\u0442\u044C "+
         "\u0433\u0440\u0435\u0447\u0435\u0441\u043A\u0438\u0439"]]>
      </defaultValueExpression>
   </parameter>

   <parameter name = "ArabicText" class = "java.lang.String" isForPrompting = "false">
      <defaultValueExpression><![CDATA["\u0627\u0646\u0646\u0649 \u0644\u0627 "+
         "\u0627\u0641\u0647\u0645 \u0627\u0644\u0644\u063A\u0629 "+
         "\u0627\u0644\u0639\u0631\u0628\u064A\u0629"]]>
      </defaultValueExpression>
   </parameter>
   
   <parameter name = "HebrewText" class = "java.lang.String" isForPrompting = "false">
      <defaultValueExpression><![CDATA["\u05D0\u05E0\u05D9 \u05DC\u05D0 "+
         "\u05DE\u05D1\u05D9\u05DF \u05E2\u05D1\u05E8\u05D9\u05EA"]]>
      </defaultValueExpression>
   </parameter>
   
   <title>
      <band height = "782">
         
         <textField>
            <reportElement x = "0" y = "50" width = "200" height = "60"/>
            
            <textElement>
               <font fontName = "DejaVu Sans" size = "14"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]> </textFieldExpression> </textField> <staticText> <reportElement x = "210" y = "50" width = "340" height = "60"/> <textElement/> <text> <![CDATA["GreekText and CyrillicText"]]> </text> </staticText> <textField> <reportElement x = "0" y = "120" width = "200" height = "60"/> <textElement> <font fontName = "DejaVu Sans" size = "14" isBold = "true"/> </textElement> <textFieldExpression class = "java.lang.String"> <![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]> </textFieldExpression> </textField> <staticText> <reportElement x = "210" y = "120" width = "340" height = "60"/> <textElement/> <text><![CDATA["GreekText and CyrillicText"]]></text> </staticText> <textField> <reportElement x = "0" y = "190" width = "200" height = "60"/> <textElement> <font fontName = "DejaVu Sans" size = "14" isItalic = "true" isUnderline = "true"/> </textElement> <textFieldExpression class = "java.lang.String"> <![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]> </textFieldExpression> </textField> <staticText> <reportElement x = "210" y = "190" width = "340" height = "60"/> <textElement/> <text><![CDATA["GreekText and CyrillicText"]]></text> </staticText> <textField> <reportElement x = "0" y = "260" width = "200" height = "60"/> <textElement> <font fontName = "DejaVu Sans" size = "14" isBold = "true" isItalic = "true" isUnderline = "true"/> </textElement> <textFieldExpression class = "java.lang.String"> <![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]> </textFieldExpression> </textField> <staticText> <reportElement x = "210" y = "260" width = "340" height = "60"/> <textElement/> <text><![CDATA["GreekText and CyrillicText"]]></text> </staticText> <textField> <reportElement x = "0" y = "330" width = "200" height = "60"/> <textElement textAlignment = "Right"> <font fontName="DejaVu Sans" size = "22"/> </textElement> <textFieldExpression class = "java.lang.String"> <![CDATA[$P{ArabicText}]]>
            </textFieldExpression>
				
         </textField>
         
         <textField>
            <reportElement x = "210" y = "330" width = "340" height = "60"/>
            
            <textElement textAlignment = "Right">
               <font fontName = "DejaVu Sans" size = "22"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{HebrewText}]]>
            </textFieldExpression>
				
         </textField>
      
      </band>
   </title>
	
</jasperReport>

उपरोक्त फ़ाइल में, हम UTF-8 एन्कोडिंग की उपस्थिति देख सकते हैं। साथ ही पाठ के स्थानीयकृत यूनिकोड के टुकड़े दस्तावेज़ मापदंडों में संग्रहीत हैं।

रिपोर्ट भरने और उत्पन्न करने के लिए जावा कोड नीचे दिया गया है। आइए इस फाइल को सेव करेंJasperUnicodeReportFill.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 JasperUnicodeReportFill {
   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 को अध्याय पर्यावरण सेटअप से चुना गया है और इसे 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.JasperUnicodeReportFill (viewFullReport डिफ़ॉल्ट लक्ष्य है) निम्नानुसार है -

C:\tools\jasperreports-5.0.1\test>ant  -Dmain-class=com.tutorialspoint.JasperUnicodeReportFill
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 t
   [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.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.JasperUnicodeReportFill
   [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: 4 minutes 1 second

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

यहां, हम देख सकते हैं कि प्रदर्शित किया जा रहा पाठ विभिन्न भाषाओं में है। इसके अलावा, हम देखते हैं कि भाषाओं को एक ही पृष्ठ पर एक साथ वर्गीकृत किया गया है और एक ही पाठ तत्व में मिलाया गया है।

JasperReports में एक फीचर <style> है जो रिपोर्ट टेम्पलेट में पाठ गुणों को नियंत्रित करने में मदद करता है। यह तत्व रिपोर्ट स्तर पर घोषित शैली सेटिंग्स का एक संग्रह है। अग्रभूमि रंग, पृष्ठभूमि रंग, चाहे फ़ॉन्ट बोल्ड, इटैलिक, या सामान्य, फ़ॉन्ट आकार, फ़ॉन्ट के लिए सीमा और कई अन्य विशेषताओं जैसे गुण <शैली> तत्व द्वारा नियंत्रित होते हैं। शैलियाँ अन्य शैलियों का विस्तार कर सकती हैं, और साथ ही मूल शैली के गुणों को ओवरराइड या ओवरराइड कर सकती हैं।

शैली के गुण

एक <शैली> तत्व में कई विशेषताएं हैं। सबसे अधिक इस्तेमाल किए जाने वाले कुछ नीचे दी गई तालिका में सूचीबद्ध हैं -

S.NO विशेषता और विवरण
1

name

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

2

isDefault

इंगित करता है कि क्या यह शैली दस्तावेज़ की डिफ़ॉल्ट शैली है।

3

style

जनक शैली का संदर्भ है।

4

mode

तत्व की पारदर्शिता को निर्दिष्ट करता है। संभावित मूल्य अपारदर्शी और पारदर्शी हैं

5

forecolor

वस्तु का अग्रभूमि रंग है।

6

backcolor

वस्तु का पृष्ठभूमि रंग है।

7

fill

ऑब्जेक्ट को भरने के लिए उपयोग किए जाने वाले भरण पैटर्न को निर्धारित करता है। फिलहाल, एकल मूल्य की अनुमति ठोस है

6

radius

आयत के कोने चाप के त्रिज्या को निर्दिष्ट करता है।

7

scaleImage

केवल छवियों के लिए पैमाने निर्दिष्ट करता है। संभावित मान: क्लिप, फिलफ़्रेम, रिटेनशेप, रियलहाइट, और रियलसाइज़

8

hAlign

क्षैतिज संरेखण निर्दिष्ट करता है। संभावित मूल्य: वाम, केंद्र, अधिकार और औचित्य

9

vAlign

ऊर्ध्वाधर संरेखण निर्दिष्ट करता है। संभावित मूल्य: शीर्ष, मध्य और निचला भाग

10

rotation

तत्व के रोटेशन को निर्दिष्ट करता है। संभावित मूल्य: कोई नहीं, वाम, अधिकार और अपसाइडडाउन

1 1

lineSpacing

पाठ की पंक्तियों के बीच की दूरी को निर्दिष्ट करता है। संभावित मान: एकल, 1_1_2, डबल

12

markup

शैली ग्रंथों के लिए मार्कअप शैली को निर्दिष्ट करता है।

13

fontName

फ़ॉन्ट नाम निर्दिष्ट करता है।

14

fontSize

फ़ॉन्ट आकार निर्दिष्ट करता है।

15

isBold

यदि फ़ॉन्ट शैली बोल्ड है, तो यह इंगित करता है।

16

isItalic

इंगित करता है कि फ़ॉन्ट शैली इटैलिक है।

17

isUnderline

इंगित करता है कि फ़ॉन्ट शैली को रेखांकित किया गया है।

18

isStrikeThrough

इंगित करता है कि फ़ॉन्ट शैली स्ट्राइकथ्रू है।

19

pdfFontName

संबंधित पीडीएफ फ़ॉन्ट नाम निर्दिष्ट करता है।

20

pdfEncoding

पीडीएफ आउटपुट प्रारूप के लिए वर्ण एन्कोडिंग निर्दिष्ट करता है।

22

isPdfEmbedded

इंगित करता है कि पीडीएफ फ़ॉन्ट एम्बेडेड है या नहीं।

23

pattern

स्वरूपित पाठ के लिए प्रारूप पैटर्न निर्दिष्ट करता है।

24

isBlankWhenNull

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

सशर्त शैलियाँ

कुछ स्थितियों में, एक शैली को केवल तभी लागू किया जाना चाहिए जब कुछ शर्त पूरी होती है (उदाहरण के लिए, एक रिपोर्ट विस्तार से आसन्न पंक्ति के रंगों को वैकल्पिक करने के लिए)। यह सशर्त शैलियों का उपयोग करके प्राप्त किया जा सकता है।

एक सशर्त शैली के दो तत्व हैं -

  • एक बूलियन स्थिति अभिव्यक्ति
  • एक शैली

शैली का उपयोग केवल तभी किया जाता है जब स्थिति सही का मूल्यांकन करती है

तत्वों की रिपोर्ट करने के लिए शैलियाँ लागू करना

किसी भी प्रकार के रिपोर्ट तत्व शैली विशेषता का उपयोग करके रिपोर्ट शैली परिभाषा को संदर्भित कर सकते हैं। इसलिए, वर्तमान परिभाषा पर लागू शैली परिभाषा द्वारा घोषित सभी शैली गुण विरासत में मिलेंगे। विरासत में मिले मूल्यों को ओवरराइड करने के लिए, रिपोर्ट तत्व स्तर पर निर्दिष्ट शैली गुणों का उपयोग किया जा सकता है।

स्टाइल टेम्प्लेट

हम एक सामान्य स्थान पर शैली को परिभाषित करके एक सामान्य नज़र के साथ रिपोर्ट का एक सेट बना सकते हैं। यह सामान्य शैली टेम्पलेट रिपोर्ट टेम्पलेट द्वारा संदर्भित किया जा सकता है। एक स्टाइल टेम्प्लेट एक XML फ़ाइल है जिसमें एक या अधिक शैली परिभाषाएँ होती हैं। कन्वेंशन द्वारा उपयोग की जाने वाली स्टाइल टेम्पलेट फाइलें*.jrtx विस्तार, लेकिन यह अनिवार्य नहीं है।

एक शैली टेम्पलेट में निम्नलिखित तत्व शामिल हैं -

  • <jasperTemplate> - यह एक शैली टेम्पलेट फ़ाइल का मूल तत्व है।

  • <टेम्पलेट> - इस तत्व का उपयोग अन्य टेम्पलेट फ़ाइलों के संदर्भों को शामिल करने के लिए किया जाता है। इस तत्व की सामग्री को संदर्भित टेम्पलेट फ़ाइल के स्थान के रूप में व्याख्या की गई है।

  • <style> - यह तत्व रिपोर्ट डिज़ाइन टेम्प्लेट (JRXML फ़ाइलों) से समान नाम वाले तत्व के समान है, इस अपवाद के साथ कि स्टाइल टेम्प्लेट में शैली में सशर्त शैलियाँ नहीं हो सकती हैं। यह सीमा इस तथ्य के कारण होती है कि सशर्त शैलियों में रिपोर्ट अभिव्यक्तियाँ शामिल होती हैं, और अभिव्यक्तियों की व्याख्या केवल एक रिपोर्ट की परिभाषा के संदर्भ में की जा सकती है।

स्टाइल टेम्प्लेट के संदर्भ JRXML रिपोर्ट में <टेम्पलेट> तत्वों के रूप में शामिल हैं। शैली टेम्पलेट रिपोर्ट भरण समय पर लोड किए जाते हैं, और सभी टेम्पलेट लोड किए जाने के बाद शैली नाम संदर्भ हल हो जाते हैं। स्टाइल टेम्प्लेट को लोड करने और स्टाइल के नाम को स्टाइल में सेट करने के दौरान, ट्री / स्टाइल टेम्प्लेट का ग्राफ बनाया जाता है, ट्री का टॉप रिपोर्ट में परिभाषित शैलियों का सेट है। इस पेड़ पर, शैली का नाम संदर्भ अंतिम शैली के लिए हल किया जाता है जो गहराई-पहले ट्रैवर्सल में नाम से मेल खाता है।

उदाहरण

चलो सशर्त शैलियों और शैली टेम्पलेट्स की कोशिश करते हैं। आइए जोड़ते हैं <style> तत्व alternateStyleहमारे मौजूदा रिपोर्ट टेम्पलेट (अध्याय रिपोर्ट डिजाइन ) के लिए। शर्त के आधार पर, फ़ॉन्ट रंग भी गणना के लिए नीले रंग में बदल जाता है। हमने एक शैली टेम्पलेट भी शामिल किया है"styles.jrtx"। संशोधित रिपोर्ट टेम्पलेट (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">
	
   <template>"styles.jrtx"</template>
   
   <style name = "alternateStyle" fontName = "Arial" forecolor = "red">
      <conditionalStyle>
         <conditionExpression>
            <![CDATA[new Boolean($V{countNumber}.intValue() % 2 == 0)]]> </conditionExpression> <style forecolor = "blue" isBold = "true"/> </conditionalStyle> </style> <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 style = "alternateStyle" 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" 
               style = "Strong"/>
            <textElement textAlignment = "Center" verticalAlignment = "Middle" />
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$F{name}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>

</jasperReport>

शैली टेम्पलेट की सामग्री styles.jrtxइस प्रकार हैं। इसे C: \ tools \ jasperreports-5.0.1 \ test निर्देशिका में सहेजें।

<?xml version = "1.0"?>

<!DOCTYPE jasperTemplate PUBLIC "-//JasperReports//DTD Template//EN"
  "http://jasperreports.sourceforge.net/dtds/jaspertemplate.dtd">

<jasperTemplate>
   <style name = "Strong" isBold = "true" pdfFontName = "Helvetica-Bold" 
      backcolor = "lightGray forecolor = "green"/>
</jasperTemplate>

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

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

यहां, हम देख सकते हैं कि फ़ॉन्ट का रंग भी गणना के लिए नीले रंग में बदल गया है (स्तंभ देश में)। स्तंभ नाम में, फ़ॉन्ट रंग को हरे रंग में बदल दिया जाता है (यह शैली शैली टेम्पलेट से संदर्भित है)।

हमने अपने पिछले अध्यायों में देखा है, रिपोर्ट पर प्रदर्शित डेटा आमतौर पर रिपोर्ट मापदंडों और रिपोर्ट क्षेत्रों से प्राप्त होता है। रिपोर्ट चर और उनके भावों का उपयोग करके इस डेटा को संसाधित किया जा सकता है। ऐसी स्थितियाँ हैं जब रिपोर्ट की अभिव्यक्तियों या चर का उपयोग करके एक जटिल कार्यक्षमता आसानी से प्राप्त नहीं की जा सकती है। इसके उदाहरण जटिल हो सकते हैं स्ट्रिंग जोड़तोड़, मैप्स का निर्माण, या स्मृति में वस्तुओं की सूची या 3 पार्टी जावा एपीआई का उपयोग करते हुए तारीखों में हेरफेर। ऐसी स्थितियों के लिए, जैस्पररीपोर्ट हमें ऐसा करने का एक सरल और शक्तिशाली साधन प्रदान करता हैScriptlets

स्क्रिप्टलेट जावा कोड के अनुक्रम होते हैं जो हर बार रिपोर्ट की गई घटना को निष्पादित करते हैं। स्क्रिप्ट चर के माध्यम से रिपोर्ट चर के मूल्यों को प्रभावित किया जा सकता है।

शास्त्रार्थ घोषणा

हम दो तरीकों से एक स्क्रिप्ट की घोषणा कर सकते हैं -

  • का उपयोग कर <scriptlet> तत्व। इस तत्व का नाम विशेषता और वर्ग विशेषता है। वर्ग विशेषता वर्ग है, जो फैली का नाम निर्दिष्ट करना चाहिए JRAbstractScriptlet वर्ग। क्लास क्लासथ में रिपोर्ट भरने के समय कक्षा उपलब्ध होनी चाहिए और एक खाली कंस्ट्रक्टर होना चाहिए, ताकि इंजन इसे मक्खी पर तुरंत लगा सके।

  • विशेषता का उपयोग करना scriptletClass तत्व का <jasperReport>, रिपोर्ट टेम्पलेट (JRXML) में। इस विशेषता को स्क्रिप्टलेट के संपूर्ण योग्य नाम (संपूर्ण पैकेज नाम सहित) के साथ सेट करके, हम इंगित करते हैं कि हम एक स्क्रिप्टलेट का उपयोग करना चाहते हैं। इस विशेषता के साथ बनाया गया स्क्रिप्टलेट उदाहरण, स्क्रिप्टलेट की सूची में पहले स्क्रिप्टलेट की तरह कार्य करता है और इसका पूर्वनिर्धारित नाम REPORT है।

शास्त्र की कक्षा

एक स्क्रिप्ट एक जावा वर्ग है, जिसे निम्नलिखित में से किसी एक वर्ग का विस्तार करना चाहिए -

  • net.sf.jasperreports.engine.JRAbstractScriptlet- इस वर्ग में कई अमूर्त विधियाँ हैं जिन्हें हर कार्यान्वयन में ओवरराइड किया जाना चाहिए। इन तरीकों को उचित समय पर जैस्पररीपोर्ट्स द्वारा स्वचालित रूप से कहा जाता है। डेवलपर को सभी अमूर्त तरीकों को लागू करना चाहिए।

  • net.sf.jasperreports.engine.JRDefaultScriptlet- इस वर्ग में JRAbstractScriptlet में हर विधि के डिफ़ॉल्ट खाली कार्यान्वयन शामिल हैं। एक डेवलपर को केवल उन तरीकों को लागू करने की आवश्यकता होती है, जिन्हें वह अपने प्रोजेक्ट के लिए आवश्यक करता है।

निम्न तालिका उपरोक्त वर्ग में विधियों को सूचीबद्ध करती है। रिपोर्ट भरने के चरण के दौरान, इन तरीकों को उचित समय पर रिपोर्ट इंजन द्वारा बुलाया जाएगा।

S.NO विधि और विवरण
1

public void beforeReportInit()

रिपोर्ट आरंभीकरण से पहले फोन किया।

2

public void afterReportInit()

रिपोर्ट आरंभीकरण के बाद फोन किया।

3

public void beforePageInit()

प्रत्येक पृष्ठ को प्रारंभ करने से पहले कॉल किया जाता है।

4

public void afterPageInit()

प्रत्येक पृष्ठ के आरंभ होने के बाद कॉल किया जाता है।

5

public void beforeColumnInit()

प्रत्येक कॉलम को इनिशियलाइज़ करने से पहले कॉल किया जाता है।

6

public void afterColumnInit()

प्रत्येक कॉलम को इनिशियलाइज़ करने के बाद कॉल किया जाता है।

7

public void beforeGroupInit(String groupName)

पैरामीटर में निर्दिष्ट समूह से पहले कॉल किया जाता है।

8

public void afterGroupInit(String groupName)

पैरामीटर में निर्दिष्ट समूह के बाद कॉल किया जाता है।

9

public void beforeDetailEval()

रिपोर्ट के विवरण अनुभाग में प्रत्येक रिकॉर्ड से पहले कॉल किया जाता है।

10

public void afterDetailEval()

रिपोर्ट के विवरण अनुभाग में प्रत्येक रिकॉर्ड के बाद कॉल किया जाता है।

प्रति रिपोर्ट में किसी भी संख्या में स्क्रिप्ट निर्दिष्ट की जा सकती है। यदि कोई स्क्रिप्टलेट किसी रिपोर्ट के लिए निर्दिष्ट नहीं है, तो इंजन अभी भी एक एकल JRDefaultScriptlet उदाहरण बनाता है और इसे अंतर्निहित REPORT_SCRIPTLET पैरामीटर के साथ पंजीकृत करता है।

हम किसी भी अतिरिक्त तरीकों को जोड़ सकते हैं जो हमें अपने स्क्रिप्टलेट्स के लिए आवश्यक हैं। रिपोर्ट इन तरीकों को बिल्ट-इन पैरामीटर REPORT_SCRIPTLET का उपयोग करके कॉल कर सकते हैं।

ग्लोबल स्क्रिप्टलेट्स

हम स्क्रिप्टलेट को रिपोर्ट करने के लिए दूसरे तरीके से जोड़ सकते हैं, जो कि विश्व स्तर पर स्क्रिप्ट्स की घोषणा करके है। यह दिए गए जैस्पररपोर्ट्स परिनियोजन में भरी जा रही सभी रिपोर्टों पर स्क्रिप्ट को लागू करता है। यह इस तथ्य से आसान हो जाता है कि स्क्रिप्टलेट्स को एक्सटेंशन के रूप में जैस्पररीपोर्ट में जोड़ा जा सकता है। पटकथा विस्तार बिंदु net.sf.jasperreports.engine.scriptlets.ScriptletFactory इंटरफ़ेस द्वारा दर्शाया गया है। JasperReports रनटाइम पर एक्सटेंशन के माध्यम से उपलब्ध सभी स्क्रिप्टलेट कारखानों को लोड करेगा। फिर, यह उनमें से प्रत्येक को स्क्रिप्टलेट के उदाहरणों की सूची के लिए पूछेगा जो वे उस वर्तमान रिपोर्ट पर लागू करना चाहते हैं जिसे चलाया जा रहा है। जब स्क्रिप्ट उदाहरणों की सूची के लिए पूछते हैं, तो इंजन कुछ संदर्भ जानकारी देता है जिसे फ़ैसला करने के लिए फ़ैक्टरी उपयोग कर सकता है, जो वर्तमान रिपोर्ट में वास्तव में लागू होते हैं।

राज्यपालों को रिपोर्ट करें

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

JasperReports में दो साधारण रिपोर्ट गवर्नर होते हैं जो एक निर्दिष्ट अधिकतम पृष्ठों की संख्या या एक निर्दिष्ट टाइमआउट अंतराल के आधार पर एक रिपोर्ट निष्पादन को रोक देंगे। वे हैं -

  • net.sf.jasperreports.governors.MaxPagesGovernor- यह एक वैश्विक स्क्रिप्टलेट है जो वर्तमान में चलाई जा रही रिपोर्ट पर लागू होती है या नहीं, यह तय करने के लिए दो कॉन्फ़िगरेशन गुणों की तलाश कर रही है। विन्यास गुण हैं -

    • net.sf.jasperreports.governor.max.pages.enabled=[true|false]

    • net.sf.jasperreports.governor.max.pages=[integer]

  • net.sf.jasperreports.governors.TimeoutGovernor- यह भी एक वैश्विक स्क्रिप्टलेट है जो निम्नलिखित दो कॉन्फ़िगरेशन गुणों की तलाश कर रहा है ताकि यह तय हो सके कि यह लागू होता है या नहीं।

    विन्यास गुण हैं -

    • net.sf.jasperreports.governor.timeout.enabled=[true|false]

    • net.sf.jasperreports.governor.timeout=[milliseconds]

दोनों राज्यपालों की संपत्तियों को वैश्विक स्तर पर jasperreports.properties फ़ाइल में या रिपोर्ट स्तर पर कस्टम रिपोर्ट गुणों के रूप में सेट किया जा सकता है। यह उपयोगी है क्योंकि अलग-अलग रिपोर्टों में अलग-अलग अनुमानित आकार या टाइमआउट सीमाएं हो सकती हैं और इसलिए भी क्योंकि आप चाहते हैं कि राज्यपाल सभी रिपोर्ट के लिए इसे चालू कर सकते हैं, जबकि कुछ के लिए इसे बंद कर सकते हैं, या इसके विपरीत।

उदाहरण

आइए एक पटकथा कक्षा लिखें (MyScriptlet)। फ़ाइल C: \ Tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint \ MyScriptlet.java की सामग्री इस प्रकार हैं -

package com.tutorialspoint;

import net.sf.jasperreports.engine.JRDefaultScriptlet;
import net.sf.jasperreports.engine.JRScriptletException;


public class MyScriptlet extends JRDefaultScriptlet {

   public void afterReportInit() throws JRScriptletException{
      System.out.println("call afterReportInit()");
      // this.setVariableValue("AllCountries", sbuffer.toString());
      this.setVariableValue("someVar", new String("This variable value 
         was modified by the scriptlet."));
   }

   public String hello() throws JRScriptletException {
      return "Hello! I'm the report's scriptlet object.";
   }

}

उपरोक्त लिपि श्रेणी का विवरण इस प्रकार है -

  • में afterReportInit विधि, हम चर के लिए एक मूल्य सेट"someVar" it.setVariableValue ("someVar", नया स्ट्रिंग ("यह चर मान स्क्रिप्ट द्वारा संशोधित किया गया था।"))।

  • कक्षा के अंत में, एक अतिरिक्त विधि कहलाती है 'hello'परिभाषित किया गया है। यह एक ऐसी विधि का एक उदाहरण है जिसे स्क्रिप्टलेट में जोड़ा जा सकता है जो वास्तव में एक चर सेट करने के बजाय एक मूल्य देता है।

इसके बाद, हम अपने मौजूदा रिपोर्ट टेम्पलेट (अध्याय रिपोर्ट डिजाइन ) में स्क्रिप्टलेट क्लास संदर्भ जोड़ेंगे । संशोधित रिपोर्ट टेम्पलेट (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"
   scriptletClass = "com.tutorialspoint.MyScriptlet">
	
   <style name = "alternateStyle" fontName = "Arial" forecolor = "red">
      
      <conditionalStyle>
         <conditionExpression>
            <![CDATA[new Boolean($V{countNumber}.intValue() % 2 == 0)]]> </conditionExpression> <style forecolor = "blue" isBold = "true"/> </conditionalStyle> </style> <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> <variable name = "someVar" class = "java.lang.String"> <initialValueExpression> <![CDATA["This is the initial variable value."]]> </initialValueExpression> </variable> <title> <band height = "100"> <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> <textField isBlankWhenNull = "true"> <reportElement x = "0" y = "50" width = "515" height = "30" forecolor = "#993300"/> <textElement textAlignment = "Center"> <font size = "10"/> </textElement> <textFieldExpression class = "java.lang.String"> <![CDATA[$V{someVar}]]>
            </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 style = "alternateStyle" 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[$F{name}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>
   
   <summary>
      <band height = "45">
            
         <textField isStretchWithOverflow = "true">
            <reportElement x = "0" y = "10" width = "515" height = "15" />
            <textElement textAlignment = "Center"/>
               
            <textFieldExpression class = "java.lang.String">
               <![CDATA["There are " + String.valueOf($V{REPORT_COUNT}) + " records on this report."]]> </textFieldExpression> </textField> <textField isStretchWithOverflow = "true"> <reportElement positionType = "Float" x = "0" y = "30" width = "515" height = "15" forecolor = "# 993300" /> <textElement textAlignment = "Center"> <font size = "10"/> </textElement> <textFieldExpression class = "java.lang.String"> <![CDATA[$P{REPORT_SCRIPTLET}.hello()]]>
            </textFieldExpression>
            
         </textField>
         
      </band>
   </summary>
	
</jasperReport>

संशोधित रिपोर्ट टेम्पलेट का विवरण नीचे दिया गया है -

  • हमने MyScriptlet क्लास को <jasperReport> एलिमेंट की एट्रीब्यूट स्क्रिप्टलेटक्लास में संदर्भित किया है।

  • स्क्रिप्टलेट केवल एक्सेस कर सकते हैं, लेकिन रिपोर्ट फ़ील्ड और मापदंडों को संशोधित नहीं करते हैं। हालाँकि, स्क्रिप्टलेट रिपोर्ट चर मानों को संशोधित कर सकते हैं। यह SetVariableValue () विधि को कॉल करके पूरा किया जा सकता है। इस पद्धति को JRAbstractScriptlet क्लास में परिभाषित किया गया है, जो हमेशा किसी भी स्क्रिप्टलेट का मूल वर्ग होता है। यहाँ, हमने एक वेरिएबल someVar को परिभाषित किया है , जिसे MyScriptlet द्वारा वैल्यू के लिए संशोधित किया जाएगायह मान स्क्रिप्टलेट द्वारा संशोधित किया गया था

  • उपरोक्त रिपोर्ट टेम्पलेट में सारांश बैंड में एक विधि कॉल है जो दिखाता है कि नए तरीके (स्क्रिप्टलेट में) कैसे लिखें और रिपोर्ट टेम्पलेट में उनका उपयोग करें। ($P{REPORT_SCRIPTLET}.hello())

रिपोर्ट भरने के लिए जावा कोड अपरिवर्तित रहते हैं। फ़ाइल की सामग्री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 को अध्याय पर्यावरण सेटअप से लिया गया है और इसे बिल्ड .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 bu
   [javac] Compiling 4 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.
   [java] call afterReportInit()
   [java] call afterReportInit()

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 minutes 49 seconds

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

यहाँ हम देखते हैं कि दो संदेश MyScriptlet वर्ग से प्रदर्शित होते हैं -

  • शीर्षक अनुभाग में - यह चर मान स्क्रिप्ट द्वारा संशोधित किया गया था
  • सबसे नीचे - नमस्ते! मैं रिपोर्ट की स्क्रिप्टलेट ऑब्जेक्ट हूं।

सब्रेपोर्ट्स जैस्पररिपोर्ट्स की अच्छी विशेषताओं में से एक है। यह सुविधा किसी अन्य रिपोर्ट के भीतर एक रिपोर्ट को शामिल करने की अनुमति देती है, अर्थात एक रिपोर्ट दूसरे की सब -पोर्ट हो सकती है। सबप्रोर्ट हमें रिपोर्ट डिज़ाइन को सरल रखने में मदद करते हैं, क्योंकि हम कई सरल रिपोर्ट बना सकते हैं और उन्हें मास्टर रिपोर्ट में इनकैप्सुलेट कर सकते हैं। सबरपोर्ट्स को सामान्य रिपोर्टों की तरह ही संकलित और भरा जाता है। किसी भी रिपोर्ट टेम्प्लेट का उपयोग एक सब रिपोर्ट के रूप में किया जा सकता है जब किसी अन्य रिपोर्ट टेम्प्लेट में शामिल किया जाता है, बिना कुछ बदले (रिपोर्ट टेम्पलेट के)।

सबरपोर्ट सामान्य रिपोर्ट टेम्पलेट्स की तरह हैं। वे वास्तव में net.sf.jasperreports.engine.JasperReport ऑब्जेक्ट हैं, जो net.sf.jasperreports.engine.design.JasperDesign ऑब्जेक्ट को संकलित करने के बाद प्राप्त होते हैं ।

<सबरपोर्ट> तत्व

मास्टर रिपोर्ट में सब्रेपोर्ट पेश करते समय एक <सबरपोर्ट> तत्व का उपयोग किया जाता है। यहां <सबरपोर्ट> JRXML तत्व में उप-तत्वों की सूची दी गई है।

  • <reportElement>

  • <पैरामीटर्सपाइज़रप्रेशन> - इसका उपयोग रिपोर्ट के मापदण्डों को पास करने के लिए किया जाता है। नक्शा आमतौर पर मास्टर रिपोर्ट में एक पैरामीटर से प्राप्त किया जाता है, या पेरेंट रिपोर्ट के मापदंडों को सबरेपोर्ट में पारित करने के लिए अंतर्निहित REPORTS_PARAMETERS_MAP पैरामीटर का उपयोग करके। इस एक्सप्रेशन को हमेशा java.util.ap ऑब्जेक्ट पर वापस करना चाहिए जिसमें कुंजियाँ पैरामीटर नाम हैं।

  • <subreportParameter> - इस तत्व का उपयोग सबरपोर्ट के मापदंडों को पास करने के लिए किया जाता है। इसका एक विशेषता नाम है , जो अनिवार्य है।

  • <connectionExpression> - इसका उपयोग java.sql.Connection को subreport में पास करने के लिए किया जाता है । इसका उपयोग केवल तब किया जाता है जब रिपोर्ट भरने के चरण के दौरान सबप्रपोर्ट टेम्पलेट को डेटाबेस कनेक्शन की आवश्यकता होती है।

  • <dataSourceExpression> - इसका उपयोग एक डेटा स्रोत को सब्रेपोर्ट में पास करने के लिए किया जाता है। यह डेटा स्रोत आमतौर पर मास्टर रिपोर्ट में एक पैरामीटर से या सब -पोर्ट के लिए पेरेंट रिपोर्ट के डेटा स्रोत को पास करने के लिए अंतर्निहित REPORT_DATA_SOURCE पैरामीटर का उपयोग करके प्राप्त किया जाता है।

  • तत्व ( connectionExpression और dataSourceExpression ) एक ही समय में <subreport> तत्व घोषणा में मौजूद नहीं हो सकते। ऐसा इसलिए है क्योंकि हम डेटा स्रोत और सबरेपोर्ट के लिए कनेक्शन दोनों की आपूर्ति नहीं कर सकते हैं। हमें उनमें से एक पर फैसला करना चाहिए और उस पर टिक जाना चाहिए।

  • <returnValue> - इसका उपयोग सबरपोर्ट के वैरिएबल्स में से एक को मास्टर रिपोर्ट के वैरिएबल में से एक को असाइन करने के लिए किया जाता है। इस उप तत्व में निम्न प्रकार के गुण हैं -

    • subreportVariable - यह विशेषता सबरपोर्ट वैरिएबल के नाम को निर्दिष्ट करती है जिसका मान लौटाया जाना है।

    • .Variable - यह विशेषता उस मूल रिपोर्ट चर का नाम निर्दिष्ट करती है, जिसके मूल्य को सबप्रपोर्ट से मान के साथ कॉपी / बढ़ाना है।

    • गणना - यह विशेषता मान ले सकती है: कुछ भी नहीं, गणना, डिस्टिंक्टाउंट, सम, औसत, सबसे कम, उच्चतम, मानक विचलन, भिन्न। विशेषता गणना के लिए डिफ़ॉल्ट मान "कुछ भी नहीं" है।

    • incrementerFactoryClass - यह विशेषता इंक्रीमेंटर इंस्टेंस बनाने के लिए फ़ैक्टरी क्लास को निर्दिष्ट करती है।

  • <subreportExpression> - यह इंगित करता है कि सबरपोर्ट के लिए संकलित रिपोर्ट टेम्पलेट कहां खोजना है। यह तत्व ए हैclassविशेषता। वर्ग java.lang.String, java.io.File, java.net.URL, java.io.InputStream, net.sf.jasperreports.engine.JasperReport: विशेषता इन मूल्यों के किसी भी ले जा सकते हैं। डिफ़ॉल्ट मान java.lang.String है

  • isUsingCache - यह <subreport> तत्व का एक गुण है। यह एक बूलियन है, जब सही पर सेट किया जाता है , तो रिपोर्टिंग इंजन अपने निर्दिष्ट स्रोत का उपयोग करके पहले से लोड किए गए सबप्रपोर्ट टेम्पलेट ऑब्जेक्ट को पहचानने की कोशिश करेगा। यह कैशिंग कार्यक्षमता केवल सबरपोर्ट तत्वों के लिए उपलब्ध है, जिसमें java.lang लौटाने वाले भाव हैं। ऑब्जेक्ट्स को सबप्रपोर्ट टेम्प्लेट स्रोत के रूप में दर्शाते हैं, फ़ाइल नाम, URL या क्लासपैथ संसाधनों का प्रतिनिधित्व करते हैं।

उदाहरण

JRDataSource का उपयोग करके सबप्रपोर्ट के निर्माण को प्रदर्शित करने के लिए एक सरल उदाहरण लें। चलो पहले दो नए रिपोर्ट टेम्पलेट लिखते हैं, एक सबरपोर्ट और दूसरा मास्टर रिपोर्ट। सबरपोर्ट (address_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 = "address_report_template" pageWidth = "175" pageHeight = "842" 
   columnWidth = "175" leftMargin = "0" rightMargin = "0" 
   topMargin = "0" bottomMargin = "0">

   <field name = "city" class = "java.lang.String"/>
   <field name = "street" class = "java.lang.String"/>
   
   <background>
      <band splitType = "Stretch"/>
   </background>
   
   <title>
      <band height = "20" splitType = "Stretch">
         
         <staticText>
            <reportElement x = "0" y = "0" width = "100" height = "20"/>
            
            <textElement>
               <font size = "14" isBold = "true"/>
            </textElement>
				
            <text><![CDATA[Addresses]]></text>
         </staticText>
      
      </band>
   </title>
   
   <pageHeader>
      <band height = "12" splitType = "Stretch"/>
   </pageHeader>
   
   <columnHeader>
      <band height = "12" splitType = "Stretch"/>
   </columnHeader>
   
   <detail>
      <band height = "27" splitType = "Stretch">
         
         <textField>
            <reportElement x = "0" y = "0" width = "120" height = "20"/>
            
            <textElement>
               <font size = "12" isBold = "true"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$F{city}+" Address:"]]> </textFieldExpression> </textField> <textField isStretchWithOverflow = "true"> <reportElement x = "120" y = "0" width = "435" height = "20"/> <textElement> <font size = "12"/> </textElement> <textFieldExpression class = "java.lang.String"> <![CDATA[$F{street}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>
   
   <columnFooter>
      <band height = "8" splitType = "Stretch"/>
   </columnFooter>
  
   <pageFooter>
      <band height = "11" splitType = "Stretch"/>
   </pageFooter>
   
   <summary>
      <band height = "9" splitType = "Stretch"/>
   </summary>

</jasperReport>

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

package com.tutorialspoint;

public class SubReportBean {
   private String city;
   private String street;

   public String getCity() {
      return city;
   }

   public void setCity(String city) {
      this.city = city;
   }

   public String getStreet() {
      return street;
   }

   public void setStreet(String street) {
      this.street = street;
   }
}

यहां, हमने दो क्षेत्रों को 'शहर' और 'स्ट्रीट' घोषित किया है और संबंधित गेटटर और सेटर विधियां परिभाषित की गई हैं।

अब, अपने मौजूदा को अपडेट करते हैं DataBeanफ़ाइल। हम एक नया फ़ील्ड सबरपोर्टबीनलिस्ट जोड़ेंगे , जो एक java.util.List है। यह फ़ील्ड SubReportBean ऑब्जेक्ट्स की सूची रखेगा। DataBean फ़ाइल की सामग्री नीचे दी गई है। इसे निर्देशिका C: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint पर सहेजें।

package com.tutorialspoint;

import java.util.List;

public class DataBean {
   private String name;
   private String country;
   private List<SubReportBean> subReportBeanList;

   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;
   }

   public List<SubReportBean> getSubReportBeanList() {
      return subReportBeanList;
   }

   public void setSubReportBeanList(List<SubReportBean> subReportBeanList) {
      this.subReportBeanList = subReportBeanList;
   }
}

चलिए अब फाइल को C: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint \DataBeanList.java। इस फ़ाइल की सामग्री इस प्रकार हैं -

package com.tutorialspoint;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class DataBeanList {
   public ArrayList<DataBean> getDataBeanList() {

      // Create sub report data
      SubReportBean subBean1 = new SubReportBean();
      subBean1.setCity("Mumbai");
      subBean1.setStreet("M.G.Road");
      SubReportBean subBean2 = new SubReportBean();
      subBean2.setCity("New York");
      subBean2.setStreet("Park Street");
      SubReportBean subBean3 = new SubReportBean();
      subBean3.setCity("San Fransisco");
      subBean3.setStreet("King Street");

      ArrayList<DataBean> dataBeanList = new ArrayList<DataBean>();

      // Create master report data
      dataBeanList.add(produce("Manisha", "India",
         Arrays.asList(subBean1)));
      dataBeanList.add(produce("Dennis Ritchie", "USA",
         Arrays.asList(subBean2)));
      dataBeanList.add(produce("V.Anand", "India",
         Arrays.asList(subBean1)));
      dataBeanList.add(produce("Shrinath", "California",
         Arrays.asList(subBean3)));

      return dataBeanList;
   }

   /*
    * This method returns a DataBean object,
    * with name, country and sub report
    * bean data set in it.
    */
   private DataBean produce(String name, String country,
      List<SubReportBean> subBean) {
      DataBean dataBean = new DataBean();

      dataBean.setName(name);
      dataBean.setCountry(country);
      dataBean.setSubReportBeanList(subBean);

      return dataBean;
   }
}

उपरोक्त फ़ाइल में विधि उत्पादन () में, हम SubReportBean की सूची सेट कर रहे हैं।

अब, एक नया मास्टर रिपोर्ट टेम्पलेट (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" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth ="555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20">

   <parameter name = "SUBREPORT_DIR" class = "java.lang.String" isForPrompting = "false">
      <defaultValueExpression>
         <![CDATA["C:\\tools\\jasperreports-5.0.1\\test\\"]]>
      </defaultValueExpression>
   </parameter>
   
   <field name = "country" class = "java.lang.String"/>
   <field name = "name" class = "java.lang.String"/>
   <field name = "subReportBeanList" class = "java.util.List"/>
   
   <background>
      <band splitType = "Stretch"/>
   </background>
   
   <title>
      <band height = "35" splitType = "Stretch">
         
         <staticText>
            <reportElement x = "0" y = "0" width = "204" height = "34"/>
            
            <textElement>
               <font size = "26" isBold = "true"/>
            </textElement>
				
            <text><![CDATA[Contact Report]]></text>
         </staticText>
      
      </band>
   </title>
   
   <pageHeader>
      <band height = "17" splitType = "Stretch"/>
   </pageHeader>
   
   <columnHeader>
      <band height = "21" splitType = "Stretch"/>
   </columnHeader>
   
   <detail>
      <band height = "112" splitType = "Stretch">
            
         <staticText>
            <reportElement x = "0" y = "0" width = "100" height = "20"/>
            
            <textElement>
               <font size = "12" isBold = "true"/>
            </textElement>
				
            <text><![CDATA[Name:]]></text>
         </staticText>
         
         <staticText>
            <reportElement x = "0" y = "20" width = "100" height = "20"/>
            
            <textElement>
               <font size = "12" isBold = "true"/>
            </textElement>
				
            <text><![CDATA[Country:]]></text>
         </staticText>
         
         <textField>
            <reportElement x = "104" y = "0" width = "277" height = "20"/>
            
            <textElement>
               <font size = "12"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$F{name}]]> </textFieldExpression> </textField> <textField> <reportElement x = "104" y = "20" width = "277" height = "20"/> <textElement> <font size = "12"/> </textElement> <textFieldExpression class = "java.lang.String"> <![CDATA[$F{country}]]>
            </textFieldExpression>
         </textField>
         
         <subreport>
            <reportElement positionType = "Float" x = "335" y = "25" width = "175"
               height = "20" isRemoveLineWhenBlank = "true" backcolor = "#99ccff"/>

            <dataSourceExpression>
               new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource
                  ($F{subReportBeanList}) </dataSourceExpression> <subreportExpression class = "java.lang.String"> <![CDATA[$P{SUBREPORT_DIR} + "address_report_template.jasper"]]>
            </subreportExpression>
         </subreport>
         
         <line>
            <reportElement x = "0" y = "50" width = "550" height = "1"/>
         </line>
      
      </band>
   </detail>
   
   <columnFooter>
      <band height = "19" splitType = "Stretch"/>
   </columnFooter>
   
   <pageFooter>
      <band height = "18" splitType = "Stretch"/>
   </pageFooter>
   
   <summary>
      <band height = "14" splitType = "Stretch"/>
   </summary>

</jasperReport>

उपरोक्त टेम्पलेट में, हमने एक नया पैरामीटर "SUBREPORT_DIR" परिभाषित किया है, जो सबरपोर्ट के मार्ग को परिभाषित करता है। हमने एक क्षेत्र subReportBeanList को java.util.List के रूप में परिभाषित किया है , जो फ़ाइल DataBean में संपत्ति से मेल खाती है। तत्व <सबरपोर्ट> में उप-तत्व है <dataSourceExpression>। हमने JRBeanCollectionDataSource की एक आवृत्ति में सूची सबरपोर्टबीनलिस्ट को डाल दिया है । उप-तत्व <subreportExpression /> में, हमने सबरपोर्ट नाम (AddressReport.jasper) दिया है।

अब, एक नया वर्ग लिखते हैं CreateReportहमारे रिपोर्ट टेम्पलेट को संकलित और निष्पादित करना। फ़ाइल की सामग्रीC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\CreateReport.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.JasperCompileManager;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperReport;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;

public class CreateReport {

   public static void main(String[] args) {
      String masterReportFileName = "C://tools/jasperreports-5.0.1/test"
         + "/jasper_report_template.jrxml";
      String subReportFileName = "C://tools/jasperreports-5.0.1/test"
         + "/AddressReport.jrxml";
      String destFileName = "C://tools/jasperreports-5.0.1/test"
         + "/jasper_report_template.JRprint";
			
      DataBeanList DataBeanList = new DataBeanList();
      ArrayList<DataBean> dataList = DataBeanList.getDataBeanList();
      JRBeanCollectionDataSource beanColDataSource = new 
         JRBeanCollectionDataSource(dataList);

      try {
         /* Compile the master and sub report */
         JasperReport jasperMasterReport = JasperCompileManager
            .compileReport(masterReportFileName);
         JasperReport jasperSubReport = JasperCompileManager
            .compileReport(subReportFileName);

         Map<String, Object> parameters = new HashMap<String, Object>();
         parameters.put("subreportParameter", jasperSubReport);
         JasperFillManager.fillReportToFile(jasperMasterReport, 
            destFileName, parameters, beanColDataSource);

      } catch (JRException e) {

         e.printStackTrace();
      }
      System.out.println("Done filling!!! ...");
   }
}

यहाँ, हम देखते हैं कि हम मास्टर और सब रिपोर्ट टेम्प्लेट संकलित कर रहे हैं और रिपोर्ट भरने के लिए मास्टर रिपोर्ट (.jasper) फाइल पास कर रहे हैं।

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

अब, हमारी सभी फाइलें तैयार हैं, चलो हमारी नियमित 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.CreateReport (viewFullReport डिफ़ॉल्ट लक्ष्य है) निम्नानुसार है -

Buildfile: C:\tools\jasperreports-5.0.1\test\build.xml

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

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
   [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.CreateReport
   [java] Compiling Report Design ...
   [java] log4j:WARN No appenders could be found for logger
   (net.sf.jasperreports.engine.xml.JRXmlDigesterFactory).
   [java] log4j:WARN Please initialize the log4j system properly.
   [java] Done filling!!! ...

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: 72 minutes 13 seconds

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

यहां, हम देख सकते हैं कि विशेषताएँ नाम, देश और पता प्रदर्शित किए जाते हैं।

पहले लोगों को चार्ट डेटा एकत्र करने और रिपोर्ट टेम्पलेट में एक छवि तत्व का उपयोग करके चार्ट को प्रस्तुत करने के लिए स्क्रिप्टलेट पर निर्भर रहना पड़ता था। JasperReports अब इसे सरल बनाता है, क्योंकि इसमें नए चार्ट घटक का उपयोग करके चार्ट के लिए अंतर्निहित समर्थन है।

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

  • समग्र चार्ट घटक।

  • चार्ट डेटासेट (जो समूह डेटा से संबंधित सेटिंग्स को चार्ट करता है)।

  • चार्ट प्लॉट (जो चार्ट आइटम्स को रेंडर करने के तरीके से संबंधित विजुअल सेटिंग्स को ग्रुप करता है)।

जैस्पररीपोर्ट वर्तमान में निम्नलिखित प्रकार के चार्ट का समर्थन करता है: पाई, पाई 3 डी, बार, 3 डी, एक्सवाई बार, स्टैक्ड बार, स्टैक्ड बार 3 डी, लाइन, एक्सवाई लाइन, एरिया, एक्सवाई एरिया, स्टैक्ड एरिया, स्कैटर, बबल, टाइम सीरीज, हाई -लो-ओपन-क्लोज, कैंडलस्टिक, मल्टीपल एक्सिस, मीटर, थर्मामीटर और गैंट।

चार्ट गुण

चार्ट सामान्य रिपोर्ट तत्व हैं, इसलिए वे अपने कुछ गुणों को अन्य सभी रिपोर्ट तत्वों के साथ साझा करते हैं। एक JRXML तत्व है जिसे <कहा जाता हैchart>, सभी प्रकार के चार्ट बनाने के लिए उपयोग किया जाता है। यह तत्व विशेष चार्ट-विशिष्ट सेटिंग्स को समूहित करता है जो सभी प्रकार के चार्ट पर लागू होता है।

चार्ट उप-तत्व

<चार्ट> तत्व के उप-तत्व हैं -

  • <reportElement> - ये स्थैतिक पाठ, पाठ क्षेत्र, चित्र, रेखाएँ, और आयत जैसी प्रदर्शन योग्य वस्तुएँ हैं जिन्हें आप अपने रिपोर्ट टेम्पलेट अनुभागों में रखते हैं।

  • <Box> - इस तत्व का उपयोग बॉर्डर द्वारा चार्ट को घेरने के लिए किया जाता है जो प्रत्येक तरफ अनुकूलन योग्य होता है।

  • <chartTitle>- चार्ट के शीर्षक को रखने के लिए इस तत्व का उपयोग किया जाता है। स्थिति विशेषता रिपोर्ट में चार्ट का शीर्षक स्थिति का फैसला किया। इस तत्व की विशेषताएं हैं -Position(मान शीर्ष , निचला , बाएँ , दाएँ हो सकता है । बहरा मान शीर्ष है ),color। <चार्टटाइटल> में फ़ॉन्ट और शीर्षक है

  • <chartSubtitle>- इस तत्व का उपयोग चार्ट के उपशीर्षक को रखने के लिए किया जाता है। इस तत्व की विशेषता है -color। <chartSubtitle> है फॉन्ट और subtitleExpression उसके उप-तत्व के रूप में।

  • <chartLegend>- तत्व फ़ॉन्ट-संबंधित गुणों के साथ-साथ पाठ रंग और इस तत्व का उपयोग करके चार्ट किंवदंती की पृष्ठभूमि रंग को नियंत्रित कर सकता है। इस तत्व की विशेषताएं हैं -textColor तथा backgroundColor

  • <anchorNameExpression> - यह तत्व एंकर के लिए लक्ष्य बनाता है।

  • <hyperlinkReferenceExpression> - इस तत्व में एक रिपोर्ट अभिव्यक्ति है जो बाहरी संसाधन (आमतौर पर एक URL) के नाम को दर्शाता है।

  • <hyperlinkAnchorExpression> - हाइपरलिंक एक बाहरी संसाधन में एक एंकर को इंगित करता है।

  • <hyperlinkPageExpression> - हाइपरलिंक वर्तमान रिपोर्ट में एक पृष्ठ को इंगित करता है।

  • <hyperlinkTooltipExpression>- यह तत्व हाइपरलिंक के टूलटिप को नियंत्रित करता है। अभिव्यक्ति का प्रकार java.lang.String होना चाहिए ।

  • <hyperlinkParameter> - यह तत्व जब वर्तमान में पैरामीटर मानों के आधार पर एक अंतिम हाइपरलिंक उत्पन्न करता है।

चार्ट विशेषताएँ

सभी चार्ट प्रकारों के लिए उपलब्ध <चार्ट> तत्व में विशेषताएँ हैं -

  • isShowLegend- इस विशेषता का उपयोग यह निर्धारित करने के लिए किया जाता है, यदि रिपोर्ट पर एक चार्ट किंवदंती प्रदर्शित की जाएगी। मान सत्य , या असत्य हो सकते हैं । डिफ़ॉल्ट मान सत्य है

  • evaluationTime- निर्धारित करता है कि चार्ट की अभिव्यक्ति का मूल्यांकन कब किया जाएगा। मान अभी , रिपोर्ट , पृष्ठ , स्तंभ , समूह , बैंड हो सकते हैं । डिफ़ॉल्ट मान अब है

  • evaluationGroup- यह विशेषता चार्ट के भावों के मूल्यांकन के लिए समूह का नाम निर्धारित करती है। इस विशेषता के लिए मान समूह के नाम से मेल खाना चाहिए, हम चार्ट के मूल्यांकन समूह के रूप में उपयोग करना चाहते हैं।

  • hyperlinkType- यह विशेषता किसी भी पाठ मान को पकड़ सकती है। डिफ़ॉल्ट मान कोई नहीं है । इसका मतलब है, न तो पाठ क्षेत्र और न ही छवियां हाइपरलिंक का प्रतिनिधित्व करती हैं, भले ही विशेष हाइपरलिंक अभिव्यक्तियां मौजूद हों।

  • hyperlinkTarget- यह विशेषता दर्शक में क्लिक किए जाने पर निर्दिष्ट लिंक के व्यवहार को अनुकूलित करने में मदद करती है। मान स्व , या रिक्त हो सकते हैं । डिफ़ॉल्ट मान स्व है

  • bookmarkLevel- यह गुण जब एक पूर्णांक में सेट होता है, तो पीडीएफ को निर्यात की गई रिपोर्ट में बुकमार्क उत्पन्न करता है। डिफ़ॉल्ट मान 0 है

  • customizerClass- यह एक वर्ग (वैकल्पिक) का नाम है जिसका उपयोग चार्ट को अनुकूलित करने के लिए किया जा सकता है। इस तत्व के लिए मान एक स्ट्रिंग होना चाहिए जिसमें एक कस्टमाइज़र वर्ग का नाम हो।

चार्ट अनुकूलन

जैसा कि ऊपर उल्लेख किया गया है, जैस्पररीपोर्ट JFreeChart को अंतर्निहित चार्टिंग लाइब्रेरी के रूप में उपयोग करता है । JFreeChart में ऐसी सुविधाएँ हैं जो सीधे तौर पर JasperReports द्वारा समर्थित नहीं हैं। हम इन सुविधाओं का लाभ उठाकर कस्टमाइज़र क्लास को <चार्ट> तत्व में कस्टमाइज़रक्लास विशेषता के माध्यम से आपूर्ति कर सकते हैं । एक कस्टमाइज़र वर्ग कुछ भी नहीं है, लेकिन net.sf.jasperreports.engine.JRChartCustomizer इंटरफ़ेस का कार्यान्वयन है । इस इंटरफ़ेस को लागू करने का सबसे आसान तरीका net.sf.jasperreports.engine.JRAbstractChartCustomizer वर्ग है और इस प्रकार रिपोर्ट डेटा के आधार पर अधिक लचीले चार्ट अनुकूलन के लिए मापदंडों, फ़ील्ड्स, और चर तक पहुंच है।

चार्ट डेटासेट

सभी चार्ट प्रकारों में एक सामान्य गुण <हैdataset> तत्व। चार्ट डेटासेट रिपोर्ट डेटा को मैप करने और रनटाइम पर चार्ट डेटा को पुनः प्राप्त करने में मदद करते हैं। प्रत्येक चार्ट प्रकार में चार्ट के भावों को परिभाषित करने के लिए विभिन्न उप-तत्व होते हैं। ये भाव चार्ट उत्पन्न करने के लिए उपयोग किए गए डेटा को परिभाषित करते हैं। इन सभी उप-तत्वों में एक <डाटासेट> तत्व होता है जो चार्ट के भावों का मूल्यांकन और रीसेट होने पर परिभाषित करता है।

जैस्परपरपोर्ट्स में कई प्रकार के चार्ट डेटासेट उपलब्ध हैं क्योंकि प्रत्येक प्रकार का चार्ट कुछ डेटासेट्स के साथ काम करता है: पाई, श्रेणी, एक्सवाई, टाइम सीरीज, टाइम पीरियड, एक्सवाईजेड और हाई-लो। इनमें से प्रत्येक डेटासेट प्रकार के नेटवर्क्स लागू करता है net.sf.jasperreports.engine.JRChartDataset इंटरफ़ेस जो चार्ट डेटासेट को परिभाषित करता है। सभी चार्ट डेटासेट उसी तरह से इनिशियलाइज़ और इन्क्रीमेंट करते हैं; हालाँकि, वे केवल उस डेटा या डेटा श्रृंखला के प्रकार में भिन्न होते हैं जो वे मैप करते हैं।

दातासेट गुण

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

गुण विवरण मूल्यों
resetType यह विशेषता निर्धारित करती है कि चार्ट अभिव्यक्ति का मान रीसेट कब किया जाए। कोई नहीं, रिपोर्ट, पृष्ठ, कॉलम, समूह। डिफ़ॉल्ट मान हैReport
resetGroup यह विशेषता उस समूह का नाम निर्धारित करती है जिस पर चार्ट अभिव्यक्ति मूल्य रीसेट है। इस विशेषता का मान JRXML रिपोर्ट टेम्पलेट में घोषित किसी भी समूह के नाम से मेल खाना चाहिए।
incrementType यह विशेषता चार्ट अभिव्यक्ति के मूल्य को पुनर्गणना करने के लिए निर्धारित करती है। कोई नहीं, रिपोर्ट, पृष्ठ, कॉलम, समूह। डिफ़ॉल्ट मान है"None"
incrementGroup यह विशेषता उस समूह का नाम निर्धारित करती है जिस पर चार्ट अभिव्यक्ति पुनर्गणना होती है। इस विशेषता का मान JRXML रिपोर्ट टेम्पलेट में घोषित समूह के नाम से मेल खाना चाहिए।

निम्नलिखित तालिका तत्व के उप-तत्वों को सारांशित करती है <डाटासेट> -

उप तत्व विवरण
<IncrementWhenExpression> चार्ट उपकेंद्रों के उपयोग के माध्यम से अवांछित डेटा को फ़िल्टर करके जिस तरह से चार्ट डेटासेट बढ़ाया जाता है, उसे अनुकूलित किया जा सकता है।
<DatasetRun> इसमें एक रिपोर्ट सबडेटासेट को तत्काल भरने के लिए आवश्यक जानकारी शामिल है।

डेटासेट प्रकार

विशिष्ट डेटासेट प्रकार नीचे दिए गए हैं -

पाई डेटासैट

एक पाई डाटासेट निम्नलिखित अभिव्यक्तियों द्वारा विशेषता है -

  • <keyExpression> - उन श्रेणियों का प्रतिनिधित्व करता है जो पाई चार्ट में स्लाइस बनाएंगे। यह अभिव्यक्ति किसी भी java.lang.Comparable ऑब्जेक्ट को वापस कर सकती है।

  • <valueExpression> - डेटासेट में प्रत्येक श्रेणी / कुंजी के अनुरूप मान उत्पन्न करता है। मान हमेशा java.lang.Number ऑब्जेक्ट होते हैं।

  • <labelExpression> - यदि यह अभिव्यक्ति गायब है, तो चार्ट पाई चार्ट में प्रत्येक स्लाइस के लिए डिफ़ॉल्ट लेबल प्रदर्शित करेगा। इस अभिव्यक्ति का उपयोग करें, जो java.lang.String मान देता है, पाई चार्ट के लिए आइटम लेबल को अनुकूलित करने के लिए।

  • <अनुभागहाइपरलिंक> - पाई अनुभागों से जुड़े हाइपरलिंक सेट करता है।

श्रेणी डेटासेट

एक श्रेणी डाटासेट <श्रेणीSeries> तत्व द्वारा विशेषता है, जिसमें शामिल हैं -

  • <seriesExpression> - श्रृंखला के नाम को इंगित करता है। यह अभिव्यक्ति किसी भी java.lang.Comparable ऑब्जेक्ट को वापस कर सकती है।

  • <categoryExpression> - श्रृंखला अभिव्यक्ति द्वारा निर्दिष्ट श्रृंखला के अंदर प्रत्येक मान के लिए श्रेणी का नाम देता है। श्रेणियाँ java.lang.Comparable ऑब्जेक्ट हैं।

  • <valueExpression> - डेटासेट में प्रत्येक श्रेणी के अनुरूप मान उत्पन्न करता है। मान हमेशा java.lang.Number ऑब्जेक्ट होते हैं।

  • <labelExpression> - यदि यह अभिव्यक्ति गायब है, तो चार्ट चार्ट में प्रत्येक आइटम के लिए डिफ़ॉल्ट लेबल प्रदर्शित करेगा। चार्ट के लिए आइटम लेबल को अनुकूलित करने के लिए java.lang.String मानों को लौटाने वाली इस अभिव्यक्ति का उपयोग करें।

  • <itemHyperlink> - चार्ट आइटम से जुड़े हाइपरलिंक सेट करता है।

XY डेटासेट

XY डेटासेट की विशेषता <xySeries> तत्व से है, जिसमें शामिल हैं -

  • <seriesExpression> - श्रृंखला के नाम को इंगित करता है। यह अभिव्यक्ति किसी भी java.lang.Comparable ऑब्जेक्ट को वापस कर सकती है।

  • <xValueExpression> - java.lang.Number मान को वर्तमान डेटा श्रृंखला में जोड़े जाने वाले (x, y) जोड़े से X मान का प्रतिनिधित्व करता है।

  • <yValueExpression> - java.lang.Number मान को वर्तमान डेटा श्रृंखला में जोड़े जाने वाले (x, y) जोड़े से Y मान का प्रतिनिधित्व करता है।

  • <labelExpression> - यदि यह अभिव्यक्ति गायब है, तो चार्ट चार्ट में प्रत्येक आइटम के लिए डिफ़ॉल्ट लेबल प्रदर्शित करेगा। चार्ट के लिए आइटम लेबल को अनुकूलित करने के लिए java.lang.String मानों को लौटाने वाली इस अभिव्यक्ति का उपयोग करें।

  • <itemHyperlink> - चार्ट आइटम से जुड़े हाइपरलिंक सेट करता है।

XYZ डेटासेट

XYZ डेटासेट की विशेषता <xyzSeries> तत्व से है, जिसमें शामिल हैं -

  • <seriesExpression> - श्रृंखला के नाम को इंगित करता है। यह अभिव्यक्ति किसी भी java.lang.Comparable ऑब्जेक्ट को वापस कर सकती है।

  • <xValueExpression> - java.lang.Number मान को वर्तमान डेटा श्रृंखला में जोड़े जाने वाले (x, y, z) आइटम से X मान का प्रतिनिधित्व करता है।

  • <yValueExpression> - java.lang.Number मान को वर्तमान डेटा श्रृंखला में जोड़ा जाएगा (x, y, z) आइटम से Y मान का प्रतिनिधित्व करता है।

  • <zValueExpression> - java.lang.Number मान (x, y, z) आइटम से वर्तमान मान का प्रतिनिधित्व करता है जो वर्तमान डेटा श्रृंखला में जोड़ा जाएगा।

  • <labelExpression> - यदि यह अभिव्यक्ति गायब है, तो चार्ट चार्ट में प्रत्येक आइटम के लिए डिफ़ॉल्ट लेबल प्रदर्शित करेगा। चार्ट के लिए आइटम लेबल को अनुकूलित करने के लिए java.lang.String मानों को लौटाने वाली इस अभिव्यक्ति का उपयोग करें।

  • <itemHyperlink> - चार्ट आइटम से जुड़े हाइपरलिंक सेट करता है।

समय श्रृंखला डेटासेट

समय श्रृंखला डेटासेट की विशेषता टाइमपेरोड विशेषता और <टाइमसीरीज> तत्व द्वारा होती है। टाइमपिरोड विशेषता डेटासेट के अंदर डेटा श्रृंखला के प्रकार को निर्दिष्ट करती है। समय श्रृंखला में दिन, महीने, वर्ष या अन्य पूर्वनिर्धारित समय अवधि से जुड़े संख्यात्मक मूल्य हो सकते हैं। संभावित मान इस प्रकार हैं: वर्ष, तिमाही, महीना, सप्ताह, दिन - यह डिफ़ॉल्ट मान, घंटा, मिनट, दूसरा, मिलिसेकंड है।

<TimeSeries> तत्व में शामिल है -

  • <seriesExpression> - श्रृंखला के नाम को इंगित करता है। यह अभिव्यक्ति किसी भी java.lang.Comparable ऑब्जेक्ट को वापस कर सकती है।

  • <timePeriodExpression> - एक java.util.ate मान लौटाता है, जिसमें से इंजन उपरोक्त उल्लिखित टाइमपेरियोड विशेषता के लिए निर्धारित मूल्य के आधार पर संबंधित समयावधि निकालेगा।

  • <valueExpression> - डेटासेट की वर्तमान श्रृंखला को बढ़ाते समय संबंधित समयावधि मान के साथ जुड़ने के लिए java.lang.Number मान लौटाता है।

  • <labelExpression> - यदि यह अभिव्यक्ति गायब है, तो चार्ट चार्ट में प्रत्येक आइटम के लिए डिफ़ॉल्ट लेबल प्रदर्शित करेगा। चार्ट के लिए आइटम लेबल को अनुकूलित करने के लिए java.lang.String मानों को लौटाने वाली इस अभिव्यक्ति का उपयोग करें।

  • <itemHyperlink> - चार्ट आइटम से जुड़े हाइपरलिंक सेट करता है।

समय अवधि डेटासेट

एक समय अवधि डेटासेट की विशेषता है <timePeriodSeries> तत्व, जिसमें शामिल हैं -

  • <seriesExpression> - श्रृंखला के नाम को इंगित करता है। यह अभिव्यक्ति किसी भी java.lang.Comparable ऑब्जेक्ट को वापस कर सकती है।

  • <startDateExpression> - उस समय अंतराल की शुरुआत को निर्दिष्ट करता है जिसके साथ समय अवधि श्रृंखला में जोड़े जाने पर संख्यात्मक मान जुड़ा होगा।

  • <endDateExpression> - उस दिनांक अंतराल के अंत को निर्दिष्ट करता है जिसके साथ समय अवधि श्रृंखला में जोड़े जाने पर संख्यात्मक मान जुड़ा होगा।

  • <valueExpression> - java.lang.Number वैल्यू को चालू तिथि और समाप्ति तिथि के भावों द्वारा निर्दिष्ट वर्तमान तिथि अंतराल के साथ जोड़ देता है।

  • <labelExpression> - यदि यह अभिव्यक्ति गायब है, तो चार्ट चार्ट में प्रत्येक आइटम के लिए डिफ़ॉल्ट लेबल प्रदर्शित करेगा। चार्ट के लिए आइटम लेबल को अनुकूलित करने के लिए java.lang.String मानों को लौटाने वाली इस अभिव्यक्ति का उपयोग करें।

  • <itemHyperlink> - चार्ट आइटम से जुड़े हाइपरलिंक सेट करता है।

उच्च निम्न डेटासेट

उच्च निम्न डेटासेट की विशेषता निम्न अभिव्यक्तियों से होती है -

  • <SeriesExpression> - वर्तमान में, केवल एक श्रृंखला को उच्च-निम्न या कैंडलस्टिक चार्ट के अंदर समर्थित किया गया है। हालांकि, इस एकल श्रृंखला को एक java.lang.Comparable मान द्वारा पहचाना जाना चाहिए जो इस अभिव्यक्ति द्वारा लौटाया गया है, और इसे चार्ट के लीजेंड में श्रृंखला के नाम के रूप में भी उपयोग किया जाना चाहिए।

  • <dateExpression> - वह दिनांक लौटाता है जिसमें वर्तमान (उच्च, निम्न, खुला, बंद, वॉल्यूम) आइटम संदर्भित होता है।

  • <highExpression> - एक java.lang.Number मान लौटाता है, जो डेटासेट के बढ़ने पर श्रृंखला में जोड़े गए डेटा आइटम का हिस्सा होगा।

  • <lowExpression> - एक java.lang.Number मान लौटाता है, जो डेटासेट के बढ़ने पर श्रृंखला में जोड़े गए डेटा आइटम का हिस्सा होगा।

  • <openExpression> - एक java.lang.Number मान देता है, जो डेटासेट के बढ़ने पर श्रृंखला में जोड़े गए डेटा आइटम का एक हिस्सा होगा।

  • <closeExpression> - एक java.lang.Number मान लौटाता है, जो डेटासेट के बढ़ने पर श्रृंखला में जोड़े गए डेटा आइटम का हिस्सा होगा।

  • <VolumeExpression> - एक संख्यात्मक अभिव्यक्ति जो वर्तमान डेटा आइटम के लिए उपयोग करने के लिए वॉल्यूम मान लौटाता है। इसका उपयोग केवल कैंडलस्टिक चार्ट के लिए किया जाता है।

  • <itemHyperlink> - चार्ट आइटम से जुड़े हाइपरलिंक सेट करता है।

मान डेटासेट

यह एक विशेष चार्ट डाटासेट कार्यान्वयन है जिसमें एकल मान शामिल है और इसका उपयोग मीटर और थर्मामीटर चार्ट के प्रतिपादन के लिए किया जाता है। मान <valueExpression> अभिव्यक्ति का उपयोग करके एकत्र किया जाता है।

चार्ट भूखंड

सभी चार्ट प्रकारों के माध्यम से एक और आम JRXML तत्व <हैplot> तत्व। यह हमें चार्ट की कई विशेषताओं जैसे कि अभिविन्यास और पृष्ठभूमि रंग को परिभाषित करने की अनुमति देता है। चार्ट के प्रकार के आधार पर भूखंड अलग-अलग होते हैं।

प्लॉट अट्रैक्शन

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

गुण विवरण मूल्यों
पीछे का रंग यह विशेषता चार्ट की पृष्ठभूमि के रंग को परिभाषित करती है। कोई भी छह अंक का हेक्साडेसिमल मान इस विशेषता के लिए एक मान्य मूल्य है। हेक्साडेसिमल मान एक # से पहले होना चाहिए।
उन्मुखीकरण यह विशेषता चार्ट के अभिविन्यास को परिभाषित करती है। क्षैतिज, लंबवत डिफ़ॉल्ट मान "वर्टिकल" है
backgroundAlpha यह विशेषता चार्ट की पृष्ठभूमि रंग की पारदर्शिता को परिभाषित करती है। इस विशेषता के मान्य मानों में 0 और 1 के बीच कोई भी दशमलव संख्या सम्मिलित है। संख्या जितनी अधिक होगी, पृष्ठभूमि उतनी ही कम पारदर्शी होगी। डिफ़ॉल्ट मान "1." है
foregroundAlpha यह विशेषता चार्ट के अग्रभूमि रंगों की पारदर्शिता को परिभाषित करती है। इस विशेषता के मान्य मानों में 0 और 1 के बीच कोई भी दशमलव संख्या सम्मिलित है। संख्या जितनी अधिक होगी, पृष्ठभूमि उतनी ही कम पारदर्शी होगी। डिफ़ॉल्ट मान "1." है
labelRotation यह विशेषता क्लॉकवाइज़ या एंटी-क्लॉकवाइज़ को घुमाने के लिए एक्स-एक्सिस पर टेक्स्ट लेबल्स के रोटेशन की अनुमति देती है। यह विशेषता केवल उन चार्टों पर लागू होती है जिनके लिए x अक्ष संख्यात्मक नहीं है या दिनांक प्रदर्शित नहीं करता है। डिफ़ॉल्ट मान "0.0" है।

<प्लॉट> तत्व में एक सबलेमेंट है <SeriesColor> जो विशेषताएँ हैं: सीरीऑर्डर और रंग । यह तत्व श्रृंखला के लिए रंगों को अनुकूलित करता है, और रंग क्रम में उनकी स्थिति।

चार्ट भूखंडों के लिए विशिष्ट सेटिंग्स

  • piePlot - इसकी कोई विशिष्ट सेटिंग नहीं है

  • pie3DPlot- इसमें डेफ़िनेटर विशेषता शामिल है , 0 से 1 तक का एक संख्यात्मक मान जो प्लॉट क्षेत्र की ऊंचाई के प्रतिशत के रूप में पाई की गहराई का प्रतिनिधित्व करता है।

  • barPlot - कोई टिक लेबल, टिक मार्क या आइटम लेबल दिखा या छिपा सकता है, और दोनों अक्ष के लिए सेटिंग्स प्रदान करता है।

  • bar3DPlot - BarPlot के रूप में एक ही सेटिंग प्रदान करता है, और xOffset और yOffset विशेषताओं का उपयोग करके एक 3D प्रभाव उत्पन्न करता है।

  • linePlot - एक आइटम बिंदुओं को जोड़ने वाली लाइनों को दिखा या छिपा सकता है, आइटम बिंदुओं से जुड़ी आकृतियों को दिखा या छिपा सकता है, और दोनों अक्ष के लिए सेटिंग्स प्रदान करता है।

  • scatterPlot - LinePlot के समान, यह आइटम बिंदुओं को जोड़ने वाली रेखाओं को दिखा या छिपा सकता है, आइटम बिंदुओं से जुड़ी आकृतियों को दिखा या छिपा सकता है, और दोनों अक्ष के लिए सेटिंग्स प्रदान करता है।

  • areaPlot - दोनों अक्ष के लिए सेटिंग्स प्रदान करता है।

  • bubblePlot - एक बुलबुला आयामों को सेट कर सकता है स्केलपाइप विशेषता सेट करके, और दोनों अक्ष के लिए सेटिंग्स प्रदान करता है।

  • timeSeriesPlot - एक आइटम बिंदुओं को जोड़ने वाली लाइनों को दिखा या छिपा सकता है, आइटम बिंदुओं से जुड़ी आकृतियों को दिखा या छिपा सकता है, और दोनों अक्ष के लिए सेटिंग्स प्रदान करता है।

  • highLowPlot - एक खुले टिक्स को दिखा या छिपा सकता है, करीब की टिक को दिखा या छिपा सकता है, और दोनों अक्ष के लिए सेटिंग्स प्रदान करता है।

  • candlestickPlot - एक वॉल्यूम को दिखा या छिपा सकता है, और दोनों अक्ष के लिए सेटिंग्स प्रदान करता है।

  • meterPlot - डायल आकार, पैमाने कोण, माप इकाइयों, टिक अंतराल, डायल रंग, सुई रंग, टिक रंग, मूल्य प्रदर्शन फ़ॉन्ट, रंग और प्रारूप पैटर्न, डेटा रेंज, और मीटर अंतराल के लिए विशिष्ट सेटिंग्स शामिल हैं।

  • thermometerPlot - वैल्यू लोकेशन, मर्करी कलर, शो / हाइड वैल्यू लाइन्स, वैल्यू डिस्प्ले फॉन्ट, कलर एंड फॉर्मेट पैटर्न, डेटा रेंज, लो रेंज, मीडियम रेंज और हाई रेंज के लिए विशिष्ट सेटिंग्स शामिल हैं।

  • multiAxisChart - भूखंड में शामिल अक्ष के लिए विशिष्ट सेटिंग्स शामिल हैं।

चार्ट के प्रकार

JasperReports कई चार्ट प्रकारों के लिए अंतर्निहित समर्थन प्रदान करता है। वे नीचे सूचीबद्ध हैं -

  • pieChart - पाई डेटासेट और पाई प्लॉट का संयोजन।

  • pie3DChart - समूह एक पाई डाटासेट और एक पाई 3 डी साजिश।

  • barChart - एक श्रेणी डाटासेट और एक बार साजिश का एक मूल संयोजन।

  • bar3DChart - एक श्रेणी डाटासेट और एक बार 3 डी भूखंड लपेटता है।

  • xyBarChart - समय अवधि डेटासेट, समय श्रृंखला डेटासेट और XY डेटासेट का समर्थन करता है, और अक्ष और आइटम को रेंडर करने के लिए बार प्लॉट का उपयोग करता है।

  • stackedBarChart - एक श्रेणी डाटासेट से डेटा का उपयोग करता है और एक बार साजिश का उपयोग करके अपनी सामग्री प्रदान करता है।

  • stackedBar3DChart - एक श्रेणी डाटासेट से डेटा का उपयोग करता है और एक बार 3 डी साजिश का उपयोग कर अपनी सामग्री प्रदान करता है।

  • lineChart - समूह एक श्रेणी डेटासेट और एक लाइन प्लॉट।

  • xyLineChart - समूह एक XY डेटासेट और एक लाइन प्लॉट।

  • areaChart - एक श्रेणी डेटासेट का उपयोग एरिया प्लॉट का उपयोग करके किया जाता है।

  • stackedAreaChart - एक श्रेणी डेटासेट का उपयोग एरिया प्लॉट का उपयोग करके किया जाता है।

  • xyAreaChart - XY डेटासेट के डेटा का उपयोग करता है और इसे एरिया प्लॉट के माध्यम से प्रस्तुत करता है।

  • scatterChart - स्कैटर प्लॉट के साथ एक XY डेटासेट लपेटता है।

  • bubbleChart - बबल प्लॉट के साथ एक XYZ डेटासेट मिलाता है।

  • timeSeriesChart - समूह एक समय श्रृंखला डाटासेट और एक समय श्रृंखला साजिश।

  • highLowChart - हाई-लो डेटासेट और हाई-लो प्लॉट का संयोजन।

  • candlestickChart - हाई-लो डेटासेट से डेटा का उपयोग करता है, लेकिन एक विशेष कैंडलस्टिक प्लॉट के साथ।

  • meterChart - मीटर प्लॉट से रेंडरिंग विकल्पों का उपयोग करते हुए, डायल पर वैल्यू डेटासेट से एकल मान प्रदर्शित करता है।

  • thermometerChart - थर्मामीटर भूखंड से रेंडरिंग विकल्पों का उपयोग करके एक मूल्य डाटासेट में एकल मूल्य प्रदर्शित करता है।

  • multiAxisChart - एक सामान्य डोमेन अक्ष साझा करने वाले सभी रेंज एक्सिस शामिल हैं।

उदाहरण

चार्ट प्रदर्शित करने के लिए, आइए एक नया रिपोर्ट टेम्पलेट (jasper_report_template.jrxml) लिखें। यहां, हम <जोड़ देंगेbarChart> तत्व से <पेजहेडर> अनुभाग और <pieChart> से <सारांश> अनुभाग। हम प्रत्येक विषय के लिए प्राप्त अंकों को चार्ट में प्रदर्शित करेंगे। इसे निर्देशिका में सहेजें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 = "595" pageHeight = "860"
   columnWidth = "515" leftMargin = "40" rightMargin = "40"
   topMargin = "50" bottomMargin = "50">

   <field name = "subjectName" class = "java.lang.String"/>
   <field name = "marks" class = "java.lang.Integer"/>
   
   <variable name = "countNumber" class = "java.lang.Integer" calculation = "Count">
      <variableExpression>
         <![CDATA[Boolean.TRUE]]>
      </variableExpression>
   </variable>
   
   <background>
      <band splitType = "Stretch"/>
   </background>
   
   <title>
      <band height = "79" splitType = "Stretch"/>
   </title>
   
   <pageHeader>
      <band height = "200">
    
         <barChart>
            <chart evaluationTime = "Report">
               <reportElement x = "0" y = "0" width = "555" height = "200"/>
            
               <chartTitle>
                  <titleExpression>
                     <![CDATA["My First JR Bar Chart"]]>
                  </titleExpression>
               </chartTitle>
            </chart>
      
            <categoryDataset>
               <dataset incrementType = "None"/>
            
               <categorySeries>
                  <seriesExpression>
                     <![CDATA[$F{subjectName}]]>
                  </seriesExpression>
            
                  <categoryExpression>
                     <![CDATA[$F{subjectName}]]> </categoryExpression> <valueExpression> <![CDATA[$F{marks}]]>
                  </valueExpression>

               </categorySeries>
            </categoryDataset>
      
            <barPlot isShowTickMarks = "false">
               <plot/>
            </barPlot>
         </barChart>
      
      </band>
   </pageHeader>
   
   <columnHeader>
      <band height = "20" splitType = "Stretch"/>
   </columnHeader>
   
   <detail>
      <band height = "20" splitType = "Stretch"/>
   </detail>
   
   <columnFooter>
      <band height = "20" splitType = "Stretch"/>
   </columnFooter>
   
   <pageFooter>
      <band height = "20" splitType = "Stretch"/>
   </pageFooter>
   
   <summary>
      <band height = "400" splitType = "Stretch">
      
         <pieChart>
            <chart evaluationTime = "Report">
               <reportElement x = "135" y = "0" width = "270" height = "300"/>
            
               <chartTitle>
                  <titleExpression>
                     <![CDATA["My First JR Pie Chart"]]>
                  </titleExpression>
               </chartTitle>
            </chart>
         
            <pieDataset>
               <dataset incrementType = "None"/>
               
               <keyExpression>
                  <![CDATA[$F{subjectName}]]> </keyExpression> <valueExpression> <![CDATA[$F{marks}]]>
               </valueExpression>
            </pieDataset>
            
            <piePlot>
               <plot/>
               <itemLabel/>
            </piePlot>
         </pieChart>
      
      </band>
   </summary>
	
</jasperReport>

उपरोक्त फ़ाइल का विवरण नीचे दिया गया है -

  • बार चार्ट बनाने के लिए उपयोग किया जाने वाला JRXML तत्व </ barChart> <pageHeader> में है। इसमें एक </ चार्ट> उप-तत्व होता है, जिसमें चार्ट के आयाम और स्थिति को परिभाषित करने वाला एक <ReportElement> उप-तत्व होता है।

  • बार चार्ट में <डाटासेट> तत्व को <श्रेणीडैटसेट> और </ श्रेणीडैटसेट> जेआरएक्सएमएल तत्वों के बीच संलग्न किया जाना चाहिए।

  • <श्रेणीडैटसेट> में <श्रेणी श्रेणी> तत्व होना चाहिए। यह तत्व परिभाषित करता है कि डेटा तत्व किस पट्टी का प्रतिनिधित्व करेगा (विषय नाम, इस उदाहरण में)।

  • <categoryDataset> में एक तत्व भी होना चाहिए, जो यह परिभाषित करता है कि डेटा को तुलना के लिए श्रेणियों में कैसे अलग किया जाएगा। यहां, डेटा को विषय नामों से अलग किया गया है।

  • <ValueExpression> तत्व परिभाषित करता है कि चार्ट में प्रत्येक बार के मूल्य को निर्धारित करने के लिए किस अभिव्यक्ति का उपयोग किया जाता है। यहां, हम "निशान" का उपयोग कर रहे हैं।

  • पाई चार्ट के लिए, हमने <सारांश> अनुभाग के तहत तत्व <pieChart> का उपयोग किया है। इसमें एक </ चार्ट> उप-तत्व शामिल है।

  • उप-तत्व में एक रिपोर्ट अभिव्यक्ति शामिल है जो चार्ट में एक कुंजी के रूप में उपयोग करने का संकेत देती है। यहाँ, हमने subjectName का उपयोग किया है।

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

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

      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 subjectName;
   private Integer marks;

   public String getSubjectName() {
      return subjectName;
   }

   public void setSubjectName(String subjectName) {
      this.subjectName = subjectName;
   }

   public Integer getMarks() {
      return marks;
   }

   public void setMarks(Integer marks) {
      this.marks = marks;
   }

}

यहां तक ​​कि फ़ाइल की सामग्री भी 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("English", 58));
      dataBeanList.add(produce("SocialStudies", 68));
      dataBeanList.add(produce("Maths", 38));
      dataBeanList.add(produce("Hindi", 88));
      dataBeanList.add(produce("Scince", 78));
      
      return dataBeanList;
   }

   /*
    * This method returns a DataBean object, with subjectName ,
    * and marks set in it.
    */
   private DataBean produce(String subjectName, Integer marks) {
      DataBean dataBean = new DataBean();

      dataBean.setSubjectName(subjectName);
      dataBean.setMarks(marks);

      return dataBean;
   }
}

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

इसके बाद, हमारी नियमित 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, defaulting to bu
   [javac] Compiling 3 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: 19 minutes 45 seconds

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

यहाँ, हम देखते हैं कि पेज चार्ट में बार चार्ट बनाया जाता है और सारांश अनुभागों में पाई चार्ट बनाया जाता है।

क्रॉसस्टैब (क्रॉस-टेबुलेशन) रिपोर्ट वे रिपोर्टें होती हैं, जिनमें सारणी में पंक्तियों और स्तंभों में डेटा की व्यवस्था होती है। क्रॉस्टैब ऑब्जेक्ट का उपयोग मुख्य रिपोर्ट के भीतर क्रॉस्टैब रिपोर्ट डालने के लिए किया जाता है। क्रोसस्टैब्स का उपयोग किसी भी स्तर के डेटा (नाममात्र, क्रमिक, अंतराल या अनुपात) के साथ किया जा सकता है, और आमतौर पर सारांशित डेटा को गतिशील तालिका के रूप में रिपोर्ट किए गए चर में प्रदर्शित किया जाता है। चर का उपयोग समुच्चय, गणना, औसत मूल्यों जैसे कुल डेटा को प्रदर्शित करने के लिए किया जाता है।

क्रॉसस्टैब गुण

JRXML तत्व <crosstab> एक रिपोर्ट में क्रॉसस्टैब डालने के लिए उपयोग किया जाता है।

गुण

निम्नलिखित <की विशेषता की एक सूची हैcrosstab> तत्व -

  • isRepeatColumnHeaders- इंगित करता है कि पृष्ठ विराम के बाद कॉलम हेडर पुनर्मुद्रित किया जाना चाहिए या नहीं। डिफ़ॉल्ट मान सत्य है

  • isRepeatRowHeaders- इंगित करता है कि क्या क्रॉस हेडर को क्रोस्टैब कॉलम के ब्रेक के बाद फिर से प्रिंट किया जाना चाहिए। डिफ़ॉल्ट मान सत्य है

  • columnBreakOffset- जब एक कॉलम ब्रेक होता है, तो पिक्सेल में मापी जाने वाली ऊर्ध्वाधर जगह की मात्रा को इंगित करता है, इससे पहले के क्रॉस्टैब के टुकड़े को उसी पृष्ठ पर पिछले एक के नीचे रखा जाना चाहिए। डिफ़ॉल्ट मान 10 है।

  • runDirection- इंगित करता है कि क्या क्रॉसस्टैब डेटा बाएं से दाएं (LTR) या दाएं से बाएं (RTL) भरा जाना चाहिए। डिफ़ॉल्ट मान LTR है।

  • ignoreWidth- इंगित करता है कि क्या क्रॉसस्टैब प्रारंभिक क्रॉस्टैब चौड़ाई सीमा से आगे बढ़ेगा और स्तंभ विराम उत्पन्न नहीं करेगा। इसके अलावा, यह क्रोस्टैब चौड़ाई सीमा के भीतर कॉलम रेंडर करना बंद कर देगा और सभी पंक्तियों के प्रतिपादन के बाद ही शेष कॉलम के साथ जारी रहेगा। डिफ़ॉल्ट मान गलत है

उप तत्व

A <crosstab> तत्व के निम्नलिखित उप तत्व हैं -

  • <reportElement>- यह तत्व अपने संलग्नक के भीतर क्रॉस्टैब की स्थिति, चौड़ाई और ऊंचाई को परिभाषित करता है। इस तत्व के लिए विशेषताओं में सभी मानक <reportElement> विशेषताएँ शामिल हैं।

  • <crosstabParameter>- इस तत्व का उपयोग रिपोर्ट चर और मापदंडों को क्रोस्टैब के भीतर से एक्सेस करने के लिए किया जाता है। इस तत्व के लिए विशेषताओं में शामिल हैं -

    • name - यह पैरामीटर नाम को परिभाषित करता है।

    • class - यह पैरामीटर वर्ग को दर्शाता है।

  • <parametersMapExpression>- इस तत्व का उपयोग रिपोर्ट चर या पैरामीटर java.util.Map की आवृत्ति से गुजरने के लिए किया जाता है , क्रॉसस्टैब के लिए मापदंडों के एक सेट के रूप में। इस तत्व में कोई विशेषता नहीं है।

  • <crosstabDataset>- यह तत्व क्रोस्साब को पॉप्युलेट करने के लिए डेटासेट को परिभाषित करता है (विस्तृत विवरण के लिए अगला भाग देखें)। इस तत्व के लिए विशेषताओं में शामिल हैं -

    • isDataPreSorted - यह इंगित करता है कि डेटासेट में डेटा पूर्व-सॉर्ट किया गया है या नहीं। डिफ़ॉल्ट मान गलत है

  • <crosstabHeaderCell>- यह तत्व क्रॉसस्टैब के ऊपरी-बाएँ कोने पर स्थित उस क्षेत्र की सामग्री को परिभाषित करता है जहाँ कॉलम हेडर और पंक्ति हेडर मिलते हैं। इस सेल के आकार की गणना स्वचालित रूप से परिभाषित पंक्ति और स्तंभ की चौड़ाई और ऊंचाई के आधार पर की जाती है।

  • <rowGroup>- यह तत्व डेटा को पंक्तियों में विभाजित करने के लिए उपयोग किए जाने वाले समूह को परिभाषित करता है। इस तत्व के लिए विशेषताओं में शामिल हैं -

    • name - यह पंक्ति समूह के नाम को परिभाषित करता है।

    • चौड़ाई - यह पंक्ति समूह की चौड़ाई को परिभाषित करता है।

    • headerPosition - इस शीर्ष लेख सामग्री (शीर्ष, मध्य, नीचे, मांसपेशियों) की स्थिति को परिभाषित करता है।

    • TotalPosition - यह संपूर्ण स्तंभ की स्थिति को परिभाषित करता है (प्रारंभ, अंत, कोई नहीं)।

    इस तत्व में निम्नलिखित उप तत्व शामिल हैं -

    • <bucket>

    • <crosstabRowHeader>

    • <crosstabTotalRowHeader>

  • <columnGroup>- यह तत्व डेटा को कॉलम में विभाजित करने के लिए उपयोग किए गए समूह को परिभाषित करता है। इस तत्व के लिए विशेषताओं में शामिल हैं -

    • name - यह कॉलम ग्रुप नाम को परिभाषित करता है।

    • ऊँचाई - यह स्तंभ समूह शीर्ष लेख की ऊँचाई को परिभाषित करता है।

    • हैडरपोजिशन - यह हेडर कंटेंट ( राइट, लेफ्ट, सेंटर, स्ट्रेच ) की स्थिति को परिभाषित करता है ।

    • TotalPosition - यह संपूर्ण स्तंभ की स्थिति को परिभाषित करता है ( प्रारंभ, अंत, कोई नहीं )।

    इस तत्व में निम्नलिखित उप तत्व शामिल हैं -

    • <bucket>

    • <crosstabColumnHeader>

    • <crosstabTotalColumnHeader>

  • <measure>- यह तत्व पंक्तियों और स्तंभों में की जाने वाली गणना को परिभाषित करता है। इस तत्व के लिए विशेषताओं में शामिल हैं -

    • name - यह नाप के नाम को परिभाषित करता है।

    • वर्ग - यह माप वर्ग को इंगित करता है।

    • गणना - यह क्रॉसस्टैब सेल मूल्यों के बीच की जाने वाली गणना को इंगित करता है। इसका मान इनमें से कोई भी हो सकता है - नथिंग, काउंट, डिस्टिंक्टाउंट, सम, एवरेज, लोएस्ट, हाईएस्ट, स्टैण्डर्ड डिविएशन, वेरिएंस और फर्स्ट । डिफ़ॉल्ट मान हैNothing

  • <crosstabCell>- यह तत्व परिभाषित करता है कि गैर-हेडर कोशिकाओं में डेटा कैसे रखा जाएगा। इस तत्व के लिए विशेषताओं में शामिल हैं -

    • columnTotalGroup - यह समूह को स्तंभ की गणना करने के लिए उपयोग करने के लिए इंगित करता है।

    • ऊँचाई - यह कोशिका की ऊँचाई को परिभाषित करता है।

    • rowTotalGroup - यह समूह को कुल पंक्ति की गणना करने के लिए उपयोग करने के लिए इंगित करता है।

    • चौड़ाई - यह कोशिका की चौड़ाई को परिभाषित करता है।

  • <whenNoDataCell>- यह तत्व एक खाली क्रॉसस्टैब सेल पर प्रदर्शित करने के लिए परिभाषित करता है। इस तत्व में कोई विशेषता नहीं है।

Crosstab में डेटा ग्रुपिंग

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

  • bucketExpression - डेटा समूह आइटम प्राप्त करने के लिए अभिव्यक्ति का मूल्यांकन किया जाना है।

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

  • orderByExpression - डेटा को सॉर्ट करने के लिए उपयोग किए गए मान को इंगित करता है।

एक क्रॉसस्टैब में पंक्ति और स्तंभ समूह (ऊपर परिभाषित) पर भरोसा करते हैं buckets

बिल्ट-इन क्रॉसस्टैब कुल चर

नीचे दिए गए योजना के अनुसार नामित चर के माध्यम से सेल के अनुरूप विभिन्न स्तरों के माप और योग के वर्तमान मूल्य की सूची दी जा सकती है -

  • माप गणना का वर्तमान मूल्य एक चर में मापा जाता है जिसमें माप के समान नाम होता है।

  • <माप> _ <कॉलम समूह> _ALL - यह एक ही पंक्ति से कॉलम समूह में सभी प्रविष्टियों के लिए कुल पैदावार देता है।

  • <माप> _ <पंक्ति समूह> _ALL - यह पंक्ति समूह में सभी प्रविष्टियों के लिए कुल समान स्तंभ से प्राप्त करता है।

  • <माप> _ <पंक्ति समूह> _ <कॉलम समूह> _ALL - यह पंक्ति और स्तंभ समूहों दोनों में सभी प्रविष्टियों के अनुरूप कुल पैदावार देता है।

उदाहरण

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

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

<!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" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20">

   <parameter name = "ReportTitle" class = "java.lang.String"/>
   <parameter name = "Author" class = "java.lang.String"/>
   
   <field name = "name" class = "java.lang.String"/>
   <field name = "country" class = "java.lang.String"/>
   
   <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> <summary> <band height = "60"> <crosstab> <reportElement width = "782" y = "0" x = "0" height = "60"/> <rowGroup name = "nameGroup" width = "100"> <bucket> <bucketExpression class = "java.lang.String"> <![CDATA[$F{name}]]>
               </bucketExpression>
            </bucket>
            
            <crosstabRowHeader>
            
               <cellContents>
                  <box border = "Thin" borderColor = "black"/>
                  
                  <textField>
                     <reportElement width = "100" y = "0" x = "0" height = "20"/>
                     <textElement textAlignment = "Right" 
                        verticalAlignment = "Middle"/>
                     
                     <textFieldExpression>
                        <![CDATA[$V{nameGroup}]]> </textFieldExpression> </textField> </cellContents> </crosstabRowHeader> </rowGroup> <columnGroup name = "countryGroup" height = "20"> <bucket> <bucketExpression class = "java.lang.String"> $F{country}
               </bucketExpression>
            </bucket>
            
            <crosstabColumnHeader>
               <cellContents>
                  <box border = "Thin" borderColor = "black"/>
                  <textField isStretchWithOverflow = "true">
                     <reportElement width = "60" y = "0" x = "0" height = "20"/>
                     <textElement verticalAlignment = "Bottom"/>
                     <textFieldExpression>
                        <![CDATA[$V{countryGroup}]]> </textFieldExpression> </textField> </cellContents> </crosstabColumnHeader> </columnGroup> <measure name = "tailNumCount" class = "java.lang.Integer" calculation = "Count"> <measureExpression>$F{country}</measureExpression>
         </measure>
         
         <crosstabCell height = "20" width = "60">
            <cellContents backcolor = "#FFFFFF">
               <box borderColor = "black" border = "Thin"/>
               <textField>
                  <reportElement x = "5" y = "0" width = "55" height = "20"/>
                  <textElement textAlignment = "Left" 
                     verticalAlignment = "Bottom"/>
                  <textFieldExpression class = "java.lang.Integer">
                      $V{tailNumCount}
                  </textFieldExpression>
               </textField>
            </cellContents>
         </crosstabCell>
      
      </crosstab>
      
      </band>
   </summary>
	
</jasperReport>

उपरोक्त फ़ाइल का विवरण इस प्रकार है -

  • Crosstab को <crosstab> तत्व द्वारा परिभाषित किया गया है।

  • <rowGroup> तत्व डेटा को पंक्तियों में विभाजित करने के लिए एक समूह को परिभाषित करता है। यहां, प्रत्येक पंक्ति एक अलग नाम के लिए डेटा प्रदर्शित करेगी।

  • <Bucket> और <bucketExpression> तत्व परिभाषित करते हैं कि समूह पंक्ति के रूप में उपयोग करने के लिए क्या रिपोर्ट अभिव्यक्ति <rowGroup> है। यहां, हमने पंक्तियों को नाम से विभाजित करने के लिए नाम क्षेत्र का परिसीमन के रूप में उपयोग किया।

  • <CrosstabRowHeader> तत्व पंक्ति शीर्षलेख के रूप में उपयोग की जाने वाली अभिव्यक्ति को परिभाषित करता है। इसमें एक एकल उप-तत्व होता है, जिसका नाम <cellContents> है, जो क्रॉस्टैब के अंदर एक आंतरिक बैंड की तरह कार्य करता है। <CrosstabRowHeader> के अंदर पाठ क्षेत्र के लिए चर नाम को परिभाषित करने के बजाय, हमने नाम को <rowGroup> (इसके नाम विशेषता के माध्यम से) सौंपा है, इसलिए यह एक अंतर्निहित चर बनाता है। <CrosstabRowHeader> तत्व पूरी पंक्ति के लिए हेडर सेल की सामग्री को परिभाषित करता है। यह एक एकल <cellContents> तत्व को इसके एकमात्र उप-तत्व के रूप में लेता है।

  • <ColumnGroup> तत्व और साथ ही इसके उप-तत्व <rowGroup> तत्व के अनुरूप हैं, सिवाय इसके कि यह पंक्तियों के बजाय स्तंभों को प्रभावित करता है।

  • <माप> तत्व पंक्तियों और स्तंभों में की जाने वाली गणना को परिभाषित करता है। गणना विशेषता यह बताने के गणना

  • <CrosstabCell> तत्व परिभाषित करता है कि गैर-हेडर कोशिकाओं में डेटा कैसे रखा जाएगा। इस तत्व में एकल <crosstabCell> तत्व भी शामिल है जो इसका एकमात्र उप-तत्व है।

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

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
   [javac] Compiling 3 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: 20 minutes 53 seconds

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

यहाँ, हम देखते हैं कि प्रत्येक देश और नाम सारणीबद्ध हैं।

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

निम्नलिखित चरणों में, हमने सूचीबद्ध किया है कि विभिन्न भाषाओं में एक रिपोर्ट कैसे बनाई जाए और रिपोर्ट अंतर्राष्ट्रीयकरण की कुछ अन्य विशेषताएं भी -

  • रिपोर्ट टेम्पलेट के साथ एक संसाधन बंडल java.util.ResourceBundle संबद्ध करें । रिपोर्ट टेम्पलेट के साथ java.util.ResourceBundle ऑब्जेक्ट को संबद्ध करने के दो तरीके हैं।

    • डिज़ाइन समय में, लक्ष्य टेम्पलेट के आधार नाम के लिए रिपोर्ट टेम्प्लेट ऑब्जेक्ट के रिसोर्सबंडल विशेषता को सेट करके ।

    • रिपोर्ट-भरने के समय REPORT_RESOURCE_BUNDLE पैरामीटर के मान के रूप में java.util.ResourceBundle ऑब्जेक्ट की आपूर्ति करके एक गतिशील / रनटाइम एसोसिएशन बनाया जा सकता है ।

    • यदि रिपोर्ट को उस स्थान में उत्पन्न किया जाना है जो वर्तमान से अलग है, तो रिपोर्ट को भरते समय रनटाइम लोकल को निर्दिष्ट करने के लिए अंतर्निहित REPORT_LOCALE पैरामीटर का उपयोग किया जा सकता है।

  • रिपोर्ट अंतर्राष्ट्रीयकरण की सुविधा के लिए, एक विशेष वाक्यविन्यास $R{}java.lang.String संसाधनों को संदर्भ के साथ जुड़े java.util.ResourceBundle ऑब्जेक्ट के अंदर रखा गया है । $R{} चरित्र सिंटैक्स कुंजी बंडल के आधार पर संसाधन बंडल से स्थानीय-विशिष्ट संसाधन को निकालता है, जिसे कोष्ठक के बीच रखा जाना चाहिए -

<textFieldExpression>
   $R{report.title}
</textFieldExpression>

उपर्युक्त पाठ फ़ील्ड रनटाइम्सअप्लाइड लोकेल और रिपोर्ट.टाइट कुंजी के आधार पर रिपोर्ट टेम्पलेट से जुड़े संसाधन बंडल से स्ट्रिंग मान निकालकर रिपोर्ट का शीर्षक प्रदर्शित करता है ।

  • रिपोर्ट लोकेल के आधार पर विभिन्न भाषाओं में संदेश स्वरूपित करना, रिपोर्ट के अंदर अंतर्निहित विधि है net.sf.jasperreports.engine.fill.JRCalculator । यह विधि java.text.MessageFormat वर्ग के समान कार्यक्षमता प्रदान करती है । इस विधि, संदेश () में तीन सुविधाजनक हस्ताक्षर हैं जो आपको संदेशों में तीन संदेश मापदंडों का उपयोग करने की अनुमति देते हैं।

  • एक अंतर्निर्मित str () विधि (रिपोर्ट भावों के अंदर $ R {} सिंटैक्स के बराबर), जो रिपोर्ट लोकेल के आधार पर संसाधन बंडल सामग्री तक पहुँच प्रदान करता है।

  • दिनांक और समय स्वरूपण के लिए, अंतर्निहित REPORT_TIME_ZONE पैरामीटर का उपयोग उचित समय परिवर्तन सुनिश्चित करने के लिए किया जा सकता है।

  • जेनरेट किए गए आउटपुट में, लाइब्रेरी टेक्स्ट रन दिशा के बारे में जानकारी रखती है ताकि भाषाओं में उत्पन्न होने वाले दस्तावेज़ राइट-टू-लेफ्ट राइटिंग (जैसे अरबी और हिब्रू) को सही तरीके से प्रस्तुत किया जा सके।

  • यदि कोई एप्लिकेशन निर्मित रिपोर्ट देखने के लिए अंतर्निहित स्विंग दर्शक पर निर्भर करता है, तो उसे टूलटिप्स या प्रदर्शित किए गए अन्य पाठों का पालन करके अंतर्राष्ट्रीयकरण करने की आवश्यकता होती है। यह करना बहुत आसान है क्योंकि दर्शक स्थानीय-विशिष्ट जानकारी निकालने के लिए पूर्वनिर्धारित संसाधन बंडल पर निर्भर करता है। इस संसाधन बंडल का आधार नाम net.sf.jasperreports.view.viewer है।

उदाहरण

अंतर्राष्ट्रीयकरण प्रदर्शित करने के लिए, आइए नई रिपोर्ट टेम्पलेट (jasper_report_template.jrxml) लिखें। जेआरएक्सएमएल की सामग्री नीचे दी गई है। इसे C: \ tools \ jasperreports-5.0.1 \ test निर्देशिका में सहेजें।

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

<!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" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20" resourceBundle = "localizationdemo">
   
   <title>
      <band height = "552">
         
         <textField>
            <reportElement positionType = "Float" x = "150" y = "20" 
               width = "400" height = "50"/>
            
            <textElement>
               <font size = "24"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{REPORT_LOCALE}.getDisplayName ($P{REPORT_LOCALE})]]>
            </textFieldExpression>
         </textField>

         <textField isStretchWithOverflow = "true" isBlankWhenNull = "true">
            <reportElement positionType = "Float" x = "20" y = "125" 
               width = "530" height = "20"/>
            
            <textElement textAlignment = "Justified">
               <font size = "14"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$R{localization.text1}]]>
            </textFieldExpression>
         
         </textField>
      
      </band>
   </title>

</jasperReport>

उपरोक्त फ़ाइल में, संसाधन jasperReport> तत्व की विशेषता बंडले जैस्पररीपोर्ट को बताता है कि रिपोर्ट के लिए उपयोग करने के लिए स्थानीयकृत स्ट्रिंग्स कहाँ से प्राप्त करें। हमें गुण के मान से मेल खाते एक रूट नाम के साथ एक संपत्ति फ़ाइल बनाने की आवश्यकता है। रिपोर्ट भरते समय यह फ़ाइल CLASSPATH में कहीं भी मौजूद होनी चाहिए। इस उदाहरण में, संपत्ति फ़ाइलlocalizationdemo.properties निर्देशिका के तहत सहेजा गया है C:\tools\jasperreports-5.0.1\test। इस फ़ाइल की सामग्री इस प्रकार है -

localization.text1 = This is English text.

एक अलग स्थान का उपयोग करने के लिए, फ़ाइल का नाम स्थानीयकरणडोमो [स्थानीय] होना चाहिए। यहां, हम स्पेनिश लोकेल के लिए एक फाइल लिखेंगे। इस फ़ाइल को इस रूप में सहेजें -C:\tools\jasperreports-5.0.1\test\localizationdemo_es.properties। इस फ़ाइल की सामग्री इस प्रकार है -

localization.text1 = Este texto es en Español.

संसाधन गुण गुण के लिए मान प्राप्त करने का सिंटैक्स $ R {कुंजी} है।

जसपरपोर्ट्स को यह बताने के लिए कि हम किस लोकेल का उपयोग करना चाहते हैं, हमें एक बिल्ट-इन पैरामीटर के लिए एक मान निर्दिष्ट करने की आवश्यकता है। इस पैरामीटर का नाम REPORT_LOCALE नामक एक स्थिरांक के रूप में परिभाषित किया गया है, और इस स्थिरांक को net.sf.jasperreports.engine.JRParameter वर्ग में परिभाषित किया गया है । स्थिर मूल्य java.util.Locale का एक उदाहरण होना चाहिए । इस तर्क को रिपोर्ट भरने और उत्पन्न करने के लिए जावा कोड में शामिल किया गया है। आइए इस फाइल को सेव करेंJasperReportFillI18.javaC: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint निर्देशिका। फ़ाइल की सामग्री इस प्रकार है -

package com.tutorialspoint;

import java.util.HashMap;
import java.util.Locale;

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

public class JasperReportFillI18 {

   public static void main(String[] args) {
      String sourceFileName = "C://tools/jasperreports-5.0.1/test/"
         + "jasper_report_template.jasper";
      HashMap parameterMap = new HashMap();
      if (args.length > 0) {
         parameterMap.put(JRParameter.REPORT_LOCALE, new Locale(args[0]));
      }
      try {
         JasperFillManager.fillReportToFile(sourceFileName, null, 
            new JREmptyDataSource());
      } catch (JRException e) {
         // TODO Auto-generated catch block
         e.printStackTrace();
      }

   }
}

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

हम अपनी नियमित 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.JasperReportFillI18 (viewFullReport डिफ़ॉल्ट लक्ष्य है) निम्नानुसार है -

C:\tools\jasperreports-5.0.1\test>ant  -Dmain-class=com.tutorialspoint.JasperReportFillI18
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
   [javac] Compiling 1 source file to C:\tools\jasperreports-5.0.1\test\classes
   [javac] Note: C:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\
      JasperReportFillI18.java
   uses unchecked or u
   [javac] Note: Recompile with -Xlint:unchecked for details.

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.JasperReportFillI18
   [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: 3 minutes 28 seconds

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