首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Jasper Reports -自定义格式工厂不使用定义的格式化程序类。

Jasper Reports -自定义格式工厂不使用定义的格式化程序类。
EN

Stack Overflow用户
提问于 2011-07-18 06:50:24
回答 1查看 3.5K关注 0票数 2

我正在处理Jasper报告,3.7.5版。

我试图使用自定义的FormatFactoy实现来处理日期字段的XML数据的空字符串表示( "“)的情况。我实现了一个实现FormatFactory的类,它应该处理这个问题。

代码语言:javascript
运行
复制
public class InvoicePrintFormatFactory implements FormatFactory {

    @Override
    public DateFormat createDateFormat(String string, Locale locale, TimeZone tz) {
        DateFormat format = new SimpleDateFormat(string, locale){

            @Override
            public Date parse(String source) throws ParseException {
                if((source == null) || (source.equals("")))
                    return null;
                return super.parse(source);
            }
        }

        return format;
    }

    @Override
    public NumberFormat createNumberFormat(String string, Locale locale) {

        NumberFormat format = new DecimalFormat(string){

            @Override
            public Number parse(String source) throws ParseException {
                if((source == null) || (source.equals("")))
                    return null;
                return super.parse(source);
            }
        }

        return format;
    }
}

在我的JRXMLDatsource中,我设置了如下源代码格式模式:

代码语言:javascript
运行
复制
JRXmlDataSource reportSource = new JRXmlDataSource(document, headRecordPath);
reportSource.setDatePattern("mm.dd.yy");
reportSource.setNumberPattern("####0.00");

当然,移交我的FormatFactory的一个实例

代码语言:javascript
运行
复制
reportParams.put(JRParameter.REPORT_FORMAT_FACTORY, new InvoicePrintFormatFactory());

如果数据源XML不包含日期字段的"“值,则这里一切正常。但如果发生这种情况,我会得到以下例外:

代码语言:javascript
运行
复制
org.apache.commons.beanutils.ConversionException: Unparseable date: ""
        at org.apache.commons.beanutils.locale.BaseLocaleConverter.convert(BaseLocaleConverter.java:241)
        at org.apache.commons.beanutils.locale.LocaleConvertUtilsBean.convert(LocaleConvertUtilsBean.java:285)
        at net.sf.jasperreports.engine.data.JRAbstractTextDataSource.convertStringValue(JRAbstractTextDataSource.java:69)
        at net.sf.jasperreports.engine.data.JRXmlDataSource.getFieldValue(JRXmlDataSource.java:313)
        at net.sf.jasperreports.engine.fill.JRFillDataset.setOldValues(JRFillDataset.java:821)
        at net.sf.jasperreports.engine.fill.JRFillDataset.next(JRFillDataset.java:785)
        at net.sf.jasperreports.engine.fill.JRBaseFiller.next(JRBaseFiller.java:1482)
        at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillReport(JRVerticalFiller.java:126)
        at net.sf.jasperreports.engine.fill.JRBaseFiller.fill(JRBaseFiller.java:946)
        at net.sf.jasperreports.engine.fill.JRBaseFiller.fill(JRBaseFiller.java:864)
        at net.sf.jasperreports.engine.fill.JRFiller.fillReport(JRFiller.java:84)
        at net.sf.jasperreports.engine.JasperFillManager.fillReport(JasperFillManager.java:624)
        at com.lmobile.crm.invoicePrinter.operator.Printer.operate(Printer.java:219)
        at com.lmobile.crm.invoicePrinter.service.InvoicePrintService.CreatePrintOrder(InvoicePrintService.java:39)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at za.co.softco.rest.ReflectionService.handle(ReflectionService.java:253)
        at za.co.softco.rest.ReflectionHandler.handle(ReflectionHandler.java:94)
        at za.co.softco.rest.RestWorker.handlePost(RestWorker.java:477)
        at za.co.softco.rest.RestWorker.handleClient(RestWorker.java:289)
        at za.co.softco.rest.RestWorker.run(RestWorker.java:152)
        at java.lang.Thread.run(Thread.java:680)
Caused by: java.text.ParseException: Unparseable date: ""
        at java.text.DateFormat.parse(DateFormat.java:337)
        at net.sf.jasperreports.engine.util.JRDateLocaleConverter.parse(JRDateLocaleConverter.java:84)
        at org.apache.commons.beanutils.locale.BaseLocaleConverter.convert(BaseLocaleConverter.java:230)
        ... 23 more

如果我调试自定义FormatFactory实现的方法调用,我注意到在遇到异常之前不会调用这两个方法。因此,我假设Jasper出于某种原因使用默认的FormatFactory。

我在这里做错了什么?有人知道这件事吗?

提前谢谢。

EN

回答 1

Stack Overflow用户

发布于 2017-06-27 18:44:42

我找到了一个教程,它对我很有用,基本上我在教程中看到了你的代码和代码之间的一些区别。First.不是实现FormatFactory,而是必须扩展DefaultFormatFactory 第二个。不能将类作为参数传递,只能在iReport的类路径中配置它。这是链接发布到jasperreports社区

答案是由用户唐林发布的,我会复制并粘贴答案,以防帖子丢失。

以下几点似乎有效:

  1. 单击“窗口>>首选项”>>“选择功能”>>检查“开发”>>单击“确定”

下一步:

  • 打开项目资源管理器右键单击“项目名称选择属性”选择“Java生成路径”单击“源”选项卡单击“添加文件夹”选择“新建文件夹集”文件夹名称: src单击“完成选择”选择“确定”设置默认输出文件夹:“项目名称/生成单击确定创建正常的报表”(使用日期的文本字段,参数或字段),

然后:

选择大纲面板中的报表打开“属性面板设置格式工厂类”以: com.company.reports.ReportFormatFactory下一步,在名为"com.company.reports“的包(文件夹)中的"src”目录中创建一些源代码。将以下内容粘贴到保存在该目录中的名为"ReportFormatFactory.java“的文件中:

代码语言:javascript
运行
复制
import java.text.DateFormat;
import java.util.Locale;
import java.util.TimeZone;

import net.sf.jasperreports.engine.util.DefaultFormatFactory;

/**
 * Delegates creation of date and number formatters to JasperReports' default
 * formatters. This class ensures that dates are formatted consistently across
 * all reports.
 */
public class ReportFormatFactory extends DefaultFormatFactory {
  /**
   * Returns a DateFormat instance that creates dates in YYYY/MM/dd format.
   *
   * @param pattern Unused.
   * @param locale Passed to the DefaultFormatFactory instance.
   * @param timezone Passed to the DefaultFormatFactory instance.
   *
   * @return An object that can format dates.
   */
  @Override
  public DateFormat createDateFormat(
    String pattern, Locale locale, TimeZone timezone ) {
    return super.createDateFormat( "YYYY/MM/dd", locale, timezone );
  }
}

运行报表时,应将日期格式化为YYYY/MM/dd.

如果要更改格式(例如,改为"dd/MM/YYYY"),请更新源代码中的日期格式行,然后重新启动Jaspersoft Studio (类加载器在修改后似乎不会重新加载ReportFormatFactory类)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6729469

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档