gpt4 book ai didi

java - DynamicJasper - 垂直排序列

转载 作者:行者123 更新时间:2023-12-01 10:35:34 24 4
gpt4 key购买 nike

我想打印一个包含很多列(例如 30)的表格。DJ 是否可以垂直而不是水平排列这些列。

示例:

  1. 第 1 列 - 第 1 行 - 第 2 行
  2. 第 2 列 - 第 1 行 - 第 2 行
  3. 第 3 列 - 第 1 行 - 第 2 行
  4. 第 4 列 - 第 1 行 - 第 2 行

我正在使用DynamicReportBuilderColumnBuilder通过DJ创建报告。

最佳答案

AFIK 没有属性可以像您的示例中那样垂直实现列。

自从使用dynamic-jasper (java)以来,最简单的方法是转换数据源以表示新的数据结构

示例

public static JRDataSource convertToVerticalDatasource(JRDataSource ds, List<String> columns) throws JRException{
//This is are vertical rows
List<Map<String,?>> rows = new ArrayList<Map<String,?>>();

//add the rows for each column
for (String column : columns) {
Map<String,Object> row = new HashMap<String,Object>();
row.put("colName", column);
rows.add(row);
}
int curRow = 0;
//Loop our dataset and get rows, put them in to correct column
while(ds.next()){
if (rows.size()<curRow){
break;
}
Map<String,Object> rowMap= (Map<String, Object>) rows.get(curRow);
for (int i = 0; i < columns.size(); i++) {
JRDesignField field = new JRDesignField();

field.setName(columns.get(i));
Object value = ds.getFieldValue(field);
rowMap.put("row" + (i+1), value);
}
curRow++;
}

//Lets be nice (if someone need's to use it)
if (ds instanceof JRRewindableDataSource){
((JRRewindableDataSource) ds).moveFirst();
}
JRMapCollectionDataSource dsv = new JRMapCollectionDataSource(rows);
return dsv;
}

此示例提供了一个通用解决方案,其中列名称位于列字段 colName 中,行 1 位于列 row1 ecc

当然,由于您使用的是动态碧 Jade ,因此在构建列时您可能会找到适合您的解决方案的更有效的转换。

如果类似的解决方案需要与 jrxml 中的交叉表一起使用,则转换后的数据源不应将 row1、row2 作为列名,而应具有仅包含行(具有当前行的值)的列名,因此重复记录。

关于java - DynamicJasper - 垂直排序列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34764158/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com