JasperReport导出Excel的问题

在JAVA的免费报表工具里面,JasperReport还算成功。

但是,在导出excel文档的时候,效果实在不敢恭维。我曾经一度想采用jxl来手动导出excel文档。

但是,经过自己摸索,还是感觉JasperReport可以达到要求。

下面是我的一些经验:

1、显式横线的秘诀:
最底下的横线必须满足:
横线top=band高度-1=(线的上面)临近文本框或者域的top+临近文本框或者域的height
中间的横线必须满足:

(线的上面)临近文本框或者域的top+临近文本框或者域的height=横线top

2、画竖线的秘诀:
竖线的left+竖线的width=(线的右边)临近文本框或者域的left
竖线的left=(线的左边)临近文本框或者域的left+临近文本框或者域的width

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要将 JasperReport 转换为 Excel 并设置页眉,你可以按照以下步骤进行操作: 1. 首先,确保你已经使用 JasperReports Library 创建了报表模板(.jrxml 文件)并编译成了 Jasper 文件(.jasper 文件)。 2. 导入相关的 Java 类库,包括 JasperReports 和 Apache POI。你可以在项目的依赖管理工具(如 Maven 或 Gradle)中添加相应的依赖。 3. 创建一个 Java 类来执行导出操作。在该类中,你需要加载 Jasper 报表文件,并将其转换为 Excel 格式。以下是一个示例代码: ```java import net.sf.jasperreports.engine.*; import net.sf.jasperreports.engine.export.JRXlsExporter; import net.sf.jasperreports.export.SimpleExporterInput; import net.sf.jasperreports.export.SimpleOutputStreamExporterOutput; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import java.io.FileOutputStream; import java.io.OutputStream; public class JasperToExcel { public static void main(String[] args) { try { // 加载 Jasper 报表文件 String reportPath = "path/to/your/report.jasper"; JasperPrint jasperPrint = JasperFillManager.fillReport(reportPath, null, new JREmptyDataSource()); // 创建一个 Excel 文档 HSSFWorkbook workbook = new HSSFWorkbook(); // 导出报表Excel JRXlsExporter exporter = new JRXlsExporter(); exporter.setExporterInput(new SimpleExporterInput(jasperPrint)); OutputStream outputStream = new FileOutputStream("path/to/output.xls"); exporter.setExporterOutput(new SimpleOutputStreamExporterOutput(outputStream)); // 设置页眉 exporter.setConfiguration(getExporterConfiguration()); exporter.exportReport(); // 关闭输出流和 JasperPrint 对象 outputStream.close(); JasperPrintManager.printReport(jasperPrint, true); } catch (Exception e) { e.printStackTrace(); } } private static SimpleXlsReportConfiguration getExporterConfiguration() { SimpleXlsReportConfiguration configuration = new SimpleXlsReportConfiguration(); configuration.setOnePagePerSheet(false); // 设置为 false,使得页眉在每个工作表上都可见 configuration.setDetectCellType(true); configuration.setCollapseRowSpan(false); configuration.setWhitePageBackground(false); configuration.setRemoveEmptySpaceBetweenRows(true); configuration.setIgnoreGraphics(false); return configuration; } } ``` 在上述代码中,你需要将 `reportPath` 替换为你的 Jasper 报表文件的路径,将 `outputStream` 替换为你希望导出Excel 文件的输出流。 4. 运行该 Java 类,它将生成一个带有设置的页眉的 Excel 文件。 请注意,上述示例代码中的页眉设置使用了 `SimpleXlsReportConfiguration` 类。你可以根据自己的需求进行更多的定制。此外,还可以使用其他的 Excel 导出器类(如 `JRXlsxExporter`)来生成 .xlsx 格式的文件。 希望这些信息对你有所帮助!如果你还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值