【问题标题】:DynamicJasper - Order columnns verticallyDynamicJasper - 垂直排列列
【发布时间】:2016-01-13 22:33:57
【问题描述】:

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

例子:

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

我正在使用 DynamicReportBuilderColumnBuilder 与 DJ 一起创建报告。

【问题讨论】:

    标签: java jasper-reports dynamic-jasper


    【解决方案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 和列row1 ecc 中的第1 行

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

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

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2021-03-29
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2010-09-15
      • 2013-09-15
      • 1970-01-01
      • 2019-07-09
      相关资源
      最近更新 更多