JasperReports 5.6: JRXlsExporter.setParameter is deprecated

前端 未结 3 822
無奈伤痛
無奈伤痛 2020-12-07 18:31

I have this code to export a JasperReprot to XLS:

        JasperPrint jprint=JasperFillManager.fillReport(expRpg, null, new JRBeanCollectionDataSource(datali         


        
相关标签:
3条回答
  • 2020-12-07 19:13

    JRExporter became deprecated in 5.6. They introduced new interface Exporter and retrofitted all exporters to have ExporterInput, ReportExportConfiguration, ExporterConfiguration,ExporterOutput. See below link

    http://jasperreports.sourceforge.net/api/net/sf/jasperreports/export/Exporter.html

    This means that instead of setParameter, you need to create configuration using above mentioned classes or their child classes PDF export example. Excel export should follow same methodology

    JRPdfExporter exporter = new JRPdfExporter();
    
    exporter.setExporterInput(new SimpleExporterInput(jasperPrint));
    exporter.setExporterOutput(outputStream);
    SimplePdfExporterConfiguration configuration = new SimplePdfExporterConfiguration();
    exporter.setConfiguration(configuration);
    
    exporter.exportReport();
    

    Excel counterpart

    JRXlsExporter exporter = new JRXlsExporter();
    exporter.setExporterInput(new SimpleExporterInput(jasperPrint));
    exporter.setExporterOutput(new SimpleOutputStreamExporterOutput(destFile));
    SimpleXlsReportConfiguration configuration = new SimpleXlsReportConfiguration();
    configuration.setOnePagePerSheet(true);
    configuration.setDetectCellType(true);
    configuration.setCollapseRowSpan(false);
    exporter.setConfiguration(configuration);
    
    exporter.exportReport();
    

    SimpleXlsReportConfiguration will have excel export related configuration. Set values as per your requirement

    0 讨论(0)
  • 2020-12-07 19:20

    Here is my CODE:

    String sourceFileName = "./jasper_report_template.jasper";
    Map parameters = new HashMap();
    String printFileName = null;
    try {
          printFileName = JasperFillManager.fillReportToFile(sourceFileName, parameters, beanArrayDataSource);
          if(printFileName != null){
               //JasperPrintManager.printReport( printFileName, true);
                /** 1- export to PDF*/
                JasperExportManager.exportReportToPdfFile(printFileName,
                          "C://Users/zanderkong/Desktop/sample_report.pdf");
                /**3- export to Excel sheet*/
                RXlsExporter xlsExporter = new JRXlsExporter();
                xlsExporter.setExporterInput(new SimpleExporterInput(printFileName));
                xlsExporter.setExporterOutput(new SimpleOutputStreamExporterOutput("C://Users/zanderkong/Desktop/sample_report.xls"));
                SimpleXlsReportConfiguration configuration = new SimpleXlsReportConfiguration();
                configuration.setOnePagePerSheet(true);
                configuration.setDetectCellType(true);
                configuration.setCollapseRowSpan(false);
                xlsExporter.setConfiguration(configuration);
                xlsExporter.exportReport();
             }
            } catch (JRException e) {
                 e.printStackTrace();
              }      
    
    0 讨论(0)
  • 2020-12-07 19:34

    Thank to the above code , here is my code : Notice : Export excel with ireport, ireport 6.0 , java 7

     Map<String, Object> parametro = new HashMap<String, Object>();
                    parametro.put("USUARIO", UConstante.NAME_MINISTERIO_USER);
                    parametro.put("RUTA_LOGO", PuenteFile.getRutaFiles(FacesContext.getCurrentInstance(), PuenteFile.RUTA_IMG_LOGO));
                    parametro.put("PATH_SYSTEM", rutaFileSystemHD);
                    parametro.put("WHERE_DATA", WHERE_REGISTRO);
                    parametro.put("WHERE_PROYECTO_USUARIO", WHERE_PROYECTO_USUARIO);
                    parametro.put("WHERE_ZONA", WHERE_ZONA);
                    parametro.put("NAME_APP", RutaFile.NAME_APP);
                    parametro.put("ID_USUARIO", getUsuario().getId());
                    parametro.put("ID_PROYECTO", beanProyecto.getId());
                    parametro.put("SUBREPORT_DIR", SUBREPORT_DIR);
    
                    System.out.println(">>>>>> PARAMETROS :" + parametro.toString());
    
                  try {
                        JasperPrint jasperPrint = JasperFillManager.fillReport(path, parametro, PgConnector.getConexion());
                        JRXlsExporter xlsExporter = new JRXlsExporter();
                        xlsExporter.setExporterInput(new SimpleExporterInput(jasperPrint));
                        xlsExporter.setExporterOutput(new SimpleOutputStreamExporterOutput(PuenteFile.getRutaFiles(FacesContext.getCurrentInstance(), PuenteFile.RUTA_REPORT_FILE) + nameExcel));
                        SimpleXlsReportConfiguration xlsReportConfiguration = new SimpleXlsReportConfiguration();
                        SimpleXlsExporterConfiguration xlsExporterConfiguration = new SimpleXlsExporterConfiguration();
                        xlsReportConfiguration.setOnePagePerSheet(true);
                        xlsReportConfiguration.setRemoveEmptySpaceBetweenRows(false);
                        xlsReportConfiguration.setDetectCellType(true);
                        xlsReportConfiguration.setWhitePageBackground(false);
                        xlsExporter.setConfiguration(xlsReportConfiguration);
                        xlsExporter.exportReport();
    
                    } catch (Exception ex) {
                        ex.printStackTrace();
                    }
    
    0 讨论(0)
提交回复
热议问题