rad*_*101 25 excel birt overflow crosstab
我正在尝试使用BIRT创建一个excel电子表格.电子表格是将两个对象映射在一起的交叉表.根据MySQL数据库中的值,行数和列数是动态的.目前,我有一个PDF输出报告的工作实现.现在,我正在尝试为Excel创建第二版报告.
我复制了报表设计并开始调整它以使用Excel.一切看起来都不错,但只有前3列显示在标题之后.所有行都正确显示.
我尝试过以下方法:
我受到以下方面的限制:
这篇博客文章提到了我的问题:http: //www.spudsoft.co.uk/2011/10/the-spudsoft-birt-excel-emitters/ 但它没有提供除发射器开关之外的解决方案.具体的引用是"文件也有页面布局的问题,我无法解决(特别是广泛的报告将被切断)."
除了一篇博客文章,我的googlefu也让我失望了.任何帮助表示赞赏!谢谢!
这里有两个问题。第一个比较简单,第二个比较复杂。
1.为什么我的Excel中的交叉表被切断了?
2.如何在运行时根据报表的列数动态调整母版页宽度?
A1:交叉选项卡被切断,因为列宽已手动设置,其中列数将扩展超过母版页的设置宽度。每当您获取报表设计元素并进行调整时,BIRT 都会假设您知道自己在做什么,并且不会覆盖您的设置。
解决方案是重新创建报表元素(表或交叉表),而不是手动调整任何大小。当在 HTML 或 Excel 中运行时,所有列将自动设置为以可用的母版页宽度显示。
BIRT 4.2 交叉表、具有 2 英寸母版页宽度和 30 列的报表项的屏幕截图

A2:这并不容易,我现在不会提供答案。我将指出解决方案并确定一些障碍。此问题的有效解决方案必须包括使用示例数据库的有效解决方案。
(从 BIRT 4.2.1 开始)
挑战 1 -在完成报告表或交叉表项目之前,在事件中设置BIRT 报告脚本母版页宽度。您不能简单地计算报告中有多少列;
如果你想计算列数——
报表设计初始化
columnCount = 0;
Run Code Online (Sandbox Code Playgroud)
交叉表,onCreate
columnCount ++;
Run Code Online (Sandbox Code Playgroud)
在我的研究中,建议有两种路径用于在创建交叉表项之前对列进行计数。任何一个
运行 beforeFactory 中的数据集(这意味着对数据库进行两次查询,一次用于计数,一次用于报告),然后获取计数并使用它。
计算初始查询中的值并将其收集到数据集中 onFetch。
我遵循使用计算列的数据集、onFetch 选项,但没有得到它的工作。
挑战2 - 母版页的宽度属性必须在报表设计之前或渲染之前设置。beforeFactory 是最常推荐的。此外,母版页的宽度属性仅在母版页“类型”设置为“自定义”时才可用,在我的尝试中,我在属性编辑器常规中手动设置此属性。
将值从 onFetch 传递到 beforeFactory 必须使用 PersistentGlobalVariable 来完成,它只能传递字符串,而不能传递整数。我发现了各种方法都行不通。即使在 PersistentGlobalVariable 中传递“12in”也无法调整母版页宽度
beforeFactory 中的这些代码中的任何一个都会调整母版页宽度(当 Type = Custom 时)
传递价值
reportContext.getReportRunnable().designHandle.getDesignHandle().findMasterPage("Simple MasterPage").setProperty("width","12in");
Run Code Online (Sandbox Code Playgroud)
计算一个值并传递它
increaseWidth = 20;
reportContext.getReportRunnable().designHandle.getDesignHandle().findMasterPage( "Simple MasterPage").setProperty("width",((2+increaseWidth)+"in"));
Run Code Online (Sandbox Code Playgroud)
最后,我无法找到或创建一个功能报告来调整在报告运行时生成的数字列上传递的母版页宽度。我认为这是可能的,但这样做超出了我目前的能力。