DynamicJasper - 垂直排序列

时间:2016-01-13 10:25:25

标签: java jasper-reports dynamic-jasper

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

示例:

  1. Column1 - Row1 - Row2
  2. 第2栏 - 第1行 - 第2行
  3. 第3栏 - 第1行 - 第2行
  4. 第4栏 - 第1行 - 第2行
  5. 我正在使用 DynamicReportBuilder ColumnBuilder 创建一个包含DJ的报告。

1 个答案:

答案 0 :(得分:1)

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

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

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