जैस्परपोर्ट - अंतर्राष्ट्रीयकरण

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

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

  • रिपोर्ट टेम्पलेट के साथ एक संसाधन बंडल 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

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