如何通过一个JRBeanCollectionDataSource到iReport的?(How To

2019-08-02 22:35发布

我目前正试图用碧玉来帮助我创建报告。 我有我想要显示在此方法的信息和数据:

private void writeToFile(final List<ScenarioLoadModel> sceneLoadModel) throws Exception {
  final BufferedWriter bw = new BufferedWriter(new FileWriter("/Uma/nft/result.psv"));

  for (final ScenarioLoadModel slm : sceneLoadModel) {
    bw.write(slm.getScenarioId() + PSP + slm.getScenarioId() + PSP + slm.getScenarioConfig().getName() + PSP + slm.getLoad() + PSP + "" + EOL);
    if (!slm.getScenarios().isEmpty()) {
      final int tempCount = slm.getScenarios().get(0).getTemplates().size();
      final int sceneCount = slm.getScenarios().size();
      for (int tempIdx = 0; tempIdx < tempCount; tempIdx++) {
        String id = null;
        int pass = 0;
        int fail = 0;
        final Map<String, BigDecimal> metricMap = new HashMap<String, BigDecimal>();
        final DefaultStatisticalCategoryDataset dataset = new DefaultStatisticalCategoryDataset();
        for (int sceneIdx = 0; sceneIdx < sceneCount; sceneIdx++) {
          final Template temp = slm.getScenarios().get(sceneIdx).getTemplates().get(tempIdx);
          if (temp.isError()) {
            fail++;
          } else {
            pass++;
          }
          if (sceneIdx == 0) {
            id = temp.getId();
          }
          final MetricGroupModel mgm = slm.getScenarios().get(sceneIdx).getMetricGroupModel().get(tempIdx);
          if (mgm != null) {
            for (final MetricModel mm : mgm.getMetricModel()) {
              for (final MetricValue mv : mm.getMetricValue()) {
                dataset.add(mv.getValue(), new BigDecimal(0.0), mv.getType(), id);
              }
            }
          }
        }
        final TemplateConfig tc = TemplateManager.getTemplateConfig(id);

        bw.write(slm.getScenarioId() + PSP);
        bw.write(id + PSP + tc.getName() + PSP + 1 + PSP + pass + "/" + fail);
        for (final Object row : dataset.getRowKeys()) {
          final Number mean = dataset.getValue((String) row, id);
          bw.write(PSP + row + PSP + mean);
        }
        bw.write(EOL);
      }
    }
  }

  bw.close();
}

从我的理解,我创建豆,然后把他们都在一个bean工厂,创建我的对象,将准备传递给iReport的。

我怎样才能把所有这些信息为豆? 我基本上是想豆包括场景/测试案例和它是否通过。 (这是用于测试自动化)

Answer 1:

我想读你的代码,使你想什么列AA最好的猜测,但没有上下文,我不知道。 所有的bean是一个POJO,私人领域和公共getter和setter。

假设不分组,基本上每个ScenarioLoadModel将对应于你最终会得到这样一个bean报告一行:

public class ScenariaResults {

    private String id;

    private String name;

    private String load;

    private int passCount;

    private int failCount;

    public ScenariaResults(String id, String name, String load, int passCount,
            int failCount) {
        super();
        this.id = id;
        this.name = name;
        this.load = load;
        this.passCount = passCount;
        this.failCount = failCount;
    }

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getLoad() {
        return load;
    }

    public void setLoad(String load) {
        this.load = load;
    }

    public int getPassCount() {
        return passCount;
    }

    public void setPassCount(int passCount) {
        this.passCount = passCount;
    }

    public int getFailCount() {
        return failCount;
    }

    public void setFailCount(int failCount) {
        this.failCount = failCount;
    }

    @Override
    public String toString() {
        return "ScenariaResults [id=" + id + ", name=" + name + ", load="
                + load + ", passCount=" + passCount + ", failCount="
                + failCount + "]";
    }

}

所以在代码基本上你有你上面建立的情况下, ScenarioResults并将它们添加到列表中。 一旦你的列表,所有你需要做的是建立一个的JRDataSource:

List<ScenarioResults> dataBeanList = ...call your method to get the list of results
//create the datasource
JRDataSource dataSource = new JRBeanCollectionDataSource(dataBeanList);

现在的iReport设计报表时,它可以是一个有点棘手的自动导入的字段。 基本上先用豆您的项目添加到classpath中iReports(可能只是它指向的bin文件夹或jar file`):工具 - >选项 - > Classpath选项卡。 现在按照以下步骤来添加字段。

  1. 点击以下图标:
  2. 选择JavaBean Datasource标签。
  3. 输入您的bean的类名。 (EX。 ScenarioResults
  4. 点击Read attributes
  5. 高亮显示您希望在此报表中的字段,然后点击Add Selected Field(s)
  6. 点击OK

现在,如果你想测试报告看起来像什么数据,而不是只是一个空洞的数据源,这是那里的工厂进来。 这只是测试,同时使用的iReport。 你需要创建一个将主要为您创建一个伪数据组的一类。 它应该是这个样子:

import java.util.ArrayList;
import java.util.List;

public class ScenarioResultsFactory {

    public static List<ScenarioResults> createBeanCollection() {
        List<ScenarioResults> list = new ArrayList<ScenarioResults>();       
        list.add(new ScenarioResults("1", "test", "load", 10, 5));
        //add as many as you want       
        return list;
    }

}

现在,你需要创建一个指向它在iReport的一个数据源。

  1. 旁边的工具条中的数据源下拉列表中单击与提示`报告数据源的图标。
  2. 点击New
  3. 选择JavaBeans set datasource 。 点击Next
  4. 对于名称中输入ScenarioResultsFactory
  5. 对于工厂类,你需要把类名包括包。 因此,如果类是在com包你应该有com.ScenarioResultsFactory这里。
  6. 对于静态方法把createBeanCollection如果不是已经存在。
  7. 检查Use field description复选框。 点击Test ,以确保它的工作。
  8. 点击Save


文章来源: How To Pass a JRBeanCollectionDataSource to iReport?