Jaspersofter Studio



如上图 ,表中需要的字段要在Fields里面进行新增配置





进行关联,其中Fields里的List是代码里的数组名字



Fields里定义的字段都要在对象里面定义,并赋值,才可以被插入报表.

引入依赖

<dependency>
            <groupId>net.sf.jasperreports</groupId>
            <artifactId>jasperreports</artifactId>
            <version>6.13.0</version>
            <exclusions>
                <exclusion>
                    <groupId>com.lowagie</groupId>
                    <artifactId>itext</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>net.sf.jasperreports</groupId>
            <artifactId>jasperreports-fonts</artifactId>
            <version>6.13.0</version>
        </dependency>

        <dependency>
            <groupId>com.lowagie</groupId>
            <artifactId>itext</artifactId>
            <version>2.1.7</version>
        </dependency>

        <dependency>
            <groupId>com.itextpdf</groupId>
            <artifactId>itextpdf</artifactId>
            <version>5.5.0</version>
        </dependency>
        <dependency>
            <groupId>com.itextpdf</groupId>
            <artifactId>itext-pdfa</artifactId>
            <version>5.5.0</version>
        </dependency>
        <dependency>
            <groupId>com.pansenlink</groupId>
            <artifactId>report-fonts</artifactId>
            <version>1.0.0</version>
        </dependency>
        <dependency>
            <groupId>com.itextpdf</groupId>
            <artifactId>itext-asian</artifactId>
            <version>5.2.0</version>
        </dependency>

jasperReport导出实现:

      eos.setDetailsList(new JRBeanCollectionDataSource(maps, false));
            orderList.add(eos);
            JasperPrint enquiryNoPrint = JasperFillManager.fillReport(enquiryRef, parameters, new JRBeanCollectionDataSource(orderList, false));
            printList.add(enquiryNoPrint);

            JRPdfExporter exporter = new JRPdfExporter();
            exporter.setExporterInput(SimpleExporterInput.getInstance(printList));
            exporter.setExporterOutput(new SimpleOutputStreamExporterOutput(outputStream));
            exporter.exportReport();

具体实现方法

public void exportOrderPdf(Long id, BaseUserEntity user, ServletOutputStream outputStream) throws IOException, JRException {
        //报表结果集查询
        NewPurchaseOrderModel result = newPurchaseOrderService.purchaseOrderDetail(user, id);
        List<OrderRequestDetailsModel> details = result.getPurOrderDetailsList();
        PurOrder order = result.getOrders();
        List<JasperPrint> printList = new ArrayList<>();
        Map<String, Object> parameters = new HashMap<>(16);

        try (InputStream enquiryRef = resourceLoader.getResource("classpath:report/enquiry_order.jasper").getInputStream()) {

            List<Map<String, Object>> maps = new ArrayList<>();
            List<Map<String, Object>> mapTaxed = new ArrayList<>();
            EnquiryOrderSource eos = new EnquiryOrderSource();
            eos.setEnquiryNo(order.getOrderNo());
            Date createDate = order.getCreateDate();
            eos.setCreateDate(format.format(createDate));

            Map<String, Object> mapTax = new HashMap<>();
            mapTax.put("untaxedAmount",changeF2Y(order.getUntaxedAmount()));
            mapTax.put("totalAmount",changeF2Y(order.getTotalAmount()));
            eos.setTotalData(new JRBeanCollectionDataSource(mapTaxed, false));

            List<EnquiryOrderSource> orderList = new ArrayList<>();
            for (OrderRequestDetailsModel detail : details) {
                Map<String, Object> map = new HashMap<>();
                map.put("materialsCode", detail.getMaterialsCode() == null ? "" : detail.getMaterialsCode());
                map.put("materialsName", detail.getMaterialsName() == null ? "" : detail.getMaterialsName());
                map.put("planDate", detail.getPlanDate() == null ? "" : format.format(detail.getPlanDate()));
                map.put("materialsPrice", detail.getMaterialsPrice() == null ? "" : changeF2Y(detail.getMaterialsPrice()));
                map.put("totalAmount", detail.getTotalAmount() == null ? "" : changeF2Y(detail.getTotalAmount()));
                maps.add(map);
            }
            eos.setDetailsList(new JRBeanCollectionDataSource(maps, false));
            orderList.add(eos);
            JasperPrint enquiryNoPrint = JasperFillManager.fillReport(enquiryRef, parameters, new JRBeanCollectionDataSource(orderList, false));
            printList.add(enquiryNoPrint);

            JRPdfExporter exporter = new JRPdfExporter();
            exporter.setExporterInput(SimpleExporterInput.getInstance(printList));
            exporter.setExporterOutput(new SimpleOutputStreamExporterOutput(outputStream));
            exporter.exportReport();
        }

    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。