birt教程之多层交叉汇总报表
如何使用Excel的数据表进行数据的多维交叉汇总分析可视化报表自动生成和决策支持
如何使用Excel的数据表进行数据的多维交叉汇总分析可视化报表自动生成和决策支持在今天的信息时代,数据分析和决策支持成为企业和组织重要的一环。
Excel作为一款常用的电子表格软件,在数据分析和可视化方面有着强大的功能和灵活性。
本文将介绍如何使用Excel的数据表进行多维交叉汇总分析,并通过可视化报表生成和决策支持。
一、数据准备在开始进行数据分析之前,首先需要准备好相关的数据。
将需要分析的数据整理成数据表的形式,确保各个维度的数据都包含在内,并按照相应的字段进行排列。
确保数据的准确性和完整性对于后续的分析至关重要。
二、多维交叉汇总分析1. 使用数据透视表Excel中的数据透视表功能可以方便地进行多维交叉汇总分析。
首先,选中整个数据表,然后点击“插入”菜单中的“数据透视表”选项。
在弹出的对话框中,选择需要分析的字段,并将它们拖拽到“行”、“列”和“值”区域。
可以根据需要对字段进行排序、筛选和汇总。
通过数据透视表,可以快速地汇总数据并查看各个维度之间的交叉情况。
2. 使用数据透视图除了数据透视表,Excel还提供了数据透视图功能。
在数据透视图中,可以自定义多维交叉汇总分析的方式。
在数据透视图中,选择需要分析的字段,并对字段进行拖拽。
通过拖拽字段,可以自由地定制交叉汇总的方式,从而获得更灵活的数据分析结果。
数据透视图功能可以帮助用户更好地理解数据并进行详细的分析。
三、可视化报表生成数据分析的结果通常需要以报表的形式进行展示,以便更好地理解和传达分析结论。
Excel提供了丰富的图表和图形功能,可以帮助用户生成各种样式的可视化报表。
1. 使用图表工具在Excel的菜单栏中选择“插入”选项卡,然后选择适合的图表类型,如柱状图、折线图、饼图等。
通过选取不同的图表类型,可以更直观地展示数据分析的结果。
在选取好图表类型之后,再选择需要分析的数据,并进行微调和格式化,以得到更美观的图表。
图表工具可以帮助用户快速生成可视化报表,并且可以根据需要进行调整和修改。
01-Birt工具数据报表开发手册
Birt数据报表开发手册1. 创建模板双击BIRT应用程序以启动Birt报表设计环境,首次启动未加载任何报表开发资源。
主界面如下:根据报表设计的需要,Birt本身提供了一些常规的模板:当然,也可以根据实际需要,添加一些使用频率比较高的模板。
下面将以两张图形,一张列表,且图形在上横向排列的模板为例,创建新模板。
点击文件菜单中的新建,选择新建模板,根据实际情况修改模板名称和存储路径:为此模板添加一些附加属性,如该模板的描述信息和模板布局的预览图像等。
点击完成,开始编辑此模板的布局。
在组件按钮区域依次选取:一个标签,用于放置报表的标题,双击输入标题文本。
也可根据需要动态的文本。
一个网格:用于放置水平的两张图形,因此网格设置为2列1行。
可根据实际情况调整。
一张表:用于放置数据报表,明细数据列设置为8列1行。
可根据实际情况调整。
关于组件的使用,将在后面的章节中具体说明。
用鼠标右击网格中的其中一个空白处,依次选择插入,图表。
在弹出的对话框中选取需要的图形。
同样的方法处理另外网格的另外一个。
有关图形的制作,将在图形报表开发手册中详细说明。
设置每种组件的属性,在OutLine窗口中选中已经拖放的组件,根据需要对其相应的属性进行调整。
如字体大小,颜色,对齐方式,样式等设置完成后,模板样式如下:保存模板的配置信息,以便在以后的报表开发中可以直接读取该模板。
2. 新建共享资源库在Birt的资源管理器中添加一些共享资源,如共享库:在弹出的对话框中输入Library库文件的保存路径和名称:确定后,Library库的创建完成。
如果操作无误,可以在对应的目录下浏览到新建的库。
3. 新建数据源在共享库中新建一个制作报表需要的数据库连接,以Oracle9i数据库连接为例,需要先配置数据驱动(数据库的驱动程序配置方法已经在报表设计器的配置手册文档中体现)。
然后在新建的库中,用鼠标右击数据源,选择新建数据源:在弹出的对话框中选择对应数据源类型,并为该数据源命名:选择正确的数据库驱动和URL后,就可以进行数据库的连接测试:可以根据报表需要,创建一个或者多个数据源的配置:数据源创建完成后,可以通过选择选择资源管理器中共享资源,Library库下新建的数据源,右击鼠标选择添加到报表,将新建数据源添加值报表中供使用。
birt报表参数
birt报表参数BIRT报表参数是一种用于生成动态报表的工具,它可以根据用户的需求来动态地改变报表的内容和显示方式。
在本文中,我将介绍BIRT报表参数的一些基本概念和使用方法。
让我们来了解一下什么是BIRT报表参数。
BIRT报表参数是一种用于传递数据给报表的方式,它可以让用户在生成报表时输入一些参数值,从而影响报表的生成结果。
比如,我们可以通过报表参数来过滤数据、排序数据、设置报表的标题等等。
在BIRT中,报表参数的定义是在数据源上的,我们可以在数据源中定义一些参数,并在报表设计中使用这些参数。
当用户生成报表时,系统会提示用户输入参数值,并根据参数值来生成报表。
在使用BIRT报表参数时,首先需要在报表设计中定义参数。
定义参数的方式是在报表设计的参数视图中添加一个新的参数,并设置参数的名称、数据类型、默认值等属性。
参数的数据类型可以是字符串、整数、日期等,根据实际需求来设置。
定义好参数后,我们可以在报表设计的其他地方使用这个参数。
比如,我们可以将参数值作为过滤条件来过滤数据,或者将参数值作为标题的一部分来显示在报表上。
在使用BIRT报表参数时,我们可以通过多种方式来传递参数值。
一种常见的方式是通过URL传递参数值。
在URL中,我们可以使用参数名和参数值的键值对来传递参数值。
比如,我们可以使用以下URL来传递参数值:```http://localhost:8080/birtviewer/frameset?__report=report.rpt design¶m1=value1¶m2=value2```在上面的URL中,param1和param2是参数的名称,value1和value2是参数的值。
通过这种方式,我们可以在生成报表时动态地传递参数值。
除了通过URL传递参数值,我们还可以通过其他方式来传递参数值。
比如,我们可以在程序中使用API来设置参数值,或者在报表生成界面上手动输入参数值。
实用的Excel技巧利用数据表创建多维度交叉分析报表和动态数据报表
实用的Excel技巧利用数据表创建多维度交叉分析报表和动态数据报表实用的Excel技巧:利用数据表创建多维度交叉分析报表和动态数据报表Excel作为办公软件中最常用的数据处理工具之一,具备强大的功能和灵活性,可以帮助我们轻松处理各种复杂的数据分析需求。
在本文中,将介绍一些实用的Excel技巧,特别是如何利用数据表创建多维度交叉分析报表和动态数据报表。
通过灵活运用这些技巧,可以为我们的数据分析工作提供便利和效率。
一、利用数据表进行多维度交叉分析多维度交叉分析是一种能够同时对多个维度进行分析和比较的方法。
在Excel中,我们可以通过数据表功能来实现这一目标。
1. 创建数据表首先,我们需要将待分析的数据整理成数据表的形式。
选择数据区域,包括列头和数据,然后点击“插入”选项卡中的“数据表”按钮。
Excel会根据选定的数据自动创建一个数据表,同时将列头作为数据表的字段名。
2. 添加维度字段在数据表中,每一列的列头即为一个维度字段。
我们可以通过在字段名旁边的下拉箭头中选择需要的字段,将其添加到数据表中。
例如,如果我们的数据包括产品名称、销售地区和销售额三个维度,我们可以分别选择这三个字段,将其添加到数据表中。
3. 进行交叉分析一旦添加完所需的维度字段,我们就可以开始进行交叉分析了。
在数据表的右上角有一个“行字段”区域和一个“列字段”区域,我们可以将想要分析的字段拖拽到相应的区域中。
例如,我们将产品名称拖拽到“行字段”区域,销售地区拖拽到“列字段”区域,销售额拖拽到“值字段”区域,Excel会自动根据所选字段生成一个交叉分析报表。
4. 使用筛选器和排序器为了进一步优化分析结果,我们可以使用数据表的筛选器和排序器功能。
在表头的字段名旁边有一个小三角箭头,点击后可以选择筛选和排序的方式。
通过使用这些功能,我们可以灵活地对数据进行过滤和排序,更好地满足分析需求。
二、创建动态数据报表动态数据报表是指在原始数据发生变化时,报表能够自动更新和显示最新的数据内容。
解决Birt等报表工具制作报表的几个难题
解决Birt等报表工具制作报表的几个难题在本文中我们再继续讨论几个类似的制作难题,并把说明集中在如何编写集算器 SPL 脚本上,不再赘述如何在 Birt 中引入 SPL 的步骤了。
1. 组内跨行计算组内跨行计算是指在计算一行中某个计算列的值时,需要引用到组内其它行的数据来进行计算。
比如下面这个例子:库表 sample 有三个字段,其中 id 是分组字段。
需要设计一张分组表,使用id 分组,明细字段是v1,v2 以及计算列crossline, 其中crossline 的算法是本条记录 v1、v2 之和加上本组上一条记录的 v1、v2 之和。
示例源数据如下:最后要展现的报表结果如下图所示:编写集算器 SPL 代码如下:A1 连接数据库A2 查询数据库,同时多产生一列常数备用。
A3 按id 分组,并在每组数据中修改计算列crossline,最后合并,其中v1[-1]、v2[-1] 是集算器特有的定位上一行记录中字段的写法。
A4 关闭数据库A5 将 A2 中的计算结果数据集返回给报表工具2. 跨库数据源制作报表的数据往往来自于多种数据源,比如不同的物理数据库、文本文件、Excel 文件等,这些数据在报表中往往还需要相互关联进行运算。
报表工具本身能实现从多数据源取数,但进行关联运算会有一定的困难,或者运算性能非常差。
而由开发者自己编程去做关联运算,工作量一般又会非常大。
而集算器 SPL 恰恰能在这一点帮上大忙。
下面这个例子中,订单表 orders 和订单明细表 orderDetail 数据分别来自两个不同的数据库,二者之间要做join 运算。
两表数据如下:最后想要展现的报表结果如下:编写集算器 SPL 代码如下:A1 连接数据库 1A2 连接数据库 2A3 查询订单表数据A4 查询订单明细表数据A5A6 关闭数据库连接A7 以 A3 的 orderID 和 A4 的 orderID 为主键进行 left join,连接后的结果集有两个字段,第一个字段是 A3 的记录,第二个字段是A4 的记录。
数据分层汇总交叉报表SQL语句实现方法
数据分层汇总交叉报表SQL语句实现方法在管理系统中,管理人员往往需要对业务数据进行不同需求的分层汇总,并产生各种形式交叉报表。
为了实现此类报表,程序员需要构造层次结构非常复杂的SQL语句,甚至使用前台编程工具或其它报表工具来完成。
以下通过二个实例,介绍此类报表的实现方法。
一、WITH as 语句使用WITH AS 语句可以为一个子查询语句块定义一个名称,使用这个子查询名称可以在查询语句的很多地方引用这个子查询。
Oracle 数据库像对待内联视图或临时表一样对待被引用的子查询名称,从而起到一定的优化作用。
with子句是9i新增语法。
你可以在任何一个顶层的SELECT 语句以及几乎所有类型的子查询语句前,使用子查询定义子句。
被定义的子查询名称可以在主查询语句以及所有的子查询语句中引用,但未定义前不能引用。
with子句中不能嵌套定义<也就是with子句中不能有with子句>,但子查询中出现的“子查询定义”语句可以引用已定义的子查询名称。
<可以引用前面已经定义的with子句> 。
复杂的查询会产生很大的sql,with as语法显示一个个中间结果,显得有条理些,可读性与易维护性大为提高。
前面的中间结果可以被语句中的select或后面的中间结果表引用,类似于一个范围仅限于本语句的临时表,在需要多次查询某中间结果时可以提升效率。
语法结构:with t1 as (...),t2 as (..)二、字典准备为了实现数据分层汇总交叉报表,需要建立行的层次结构表与列的交叉汇总对照表。
1、交叉汇总对照表:一般分为,代码字段与代码汇总二个字段。
如:SELECT fee_code,fee_stat_cate FROM FIN_COM_FEECODESTAT WHERE REPORT_CODE = 'ZY11'FEE_CIDE为数据表中的费用代码,FEE_STAT_CA TE为费用汇总归类代码。
BIRT交叉表用法
Birt2.2M6 的CorssTab(交叉表)的用法1什么是交叉表首先你要知道什么是交叉表,又是在什么情况下需要用交叉表。
“交叉表”对象是一个网格,用来根据指定的条件返回值。
数据显示在压缩行和列中。
这种格式易于比较数据并辨别其趋势。
它由三个元素组成:◆行◆列◆摘要字段我找了一副图表,用以说明交叉表2创建交叉表步骤Birt 2.2M6首次出现了OLAP Cube功能,创建交叉表分为三步◆创建Cube◆创建CrossTab◆把Cube的维度和度量拖到相应的地方。
2.1选择Cube的数据集BIRT的数据立方体(Cube)是基于数据集的。
建一个Cube首先就是要选择Cube的数据集,所以先创建自己的数据源和数据集。
本例中我们建了一个名为crossTabDataSet 的数据集,数据集的预览如下图所示:2.2创建Cube在Data Exployer页的Cubes下面增加一个Cube,本例中,我们将Cube命名为TestCube,数据集选择我们刚才新建的crossTabDataSet。
2.3设置Cube的GroupGroup的设置页面如下:把我们需要在交叉表的维度拖到Groups的Group下。
(可以根据多个维度建立多个Group)2.4设置CrossTab然后,在设计面板中,双击Crosstab,在弹出的窗口中,选择我们刚才建好的Cube,点击‘Ok’。
设计页面上上出现了一个CrossTab的表格。
然后,打开DataExplor页,将Cube的维度和度量相应地拖放到规定的地方。
如下图所示。
预览效果如下图所示:至此,一个交叉表就完成了2.5给交叉表设置附加列如果想要出现本文开头的交叉表的效果(即:行小计和列小计计算结果),进行如下设置:右键单击横向维度右边的小三角,点击菜单中的Aggregation项:在出现的对话框中,将GrandTotals栏目中的NUM选上,Function选择Sum函数,OK即可。
birt教程之交叉报表
birt教程之交叉报表交叉报表构建数据源方法同上。
构建数据集1.在定义好数据集的基本信息之后,进入SQL SELECT语句查询界面,输入如下SQL语句,进行数据集的创建:select EBANK.CUSTOMER.CUSTOMER_NAME,EBANK.PRODUCT.PRODUCT_NAME,EBANK.CONTRACTSUM.*from EBANK.CUSTOMER,EBANK.PRODUCT,EBANK.CONTRACTSUM where EBANK.CONTRACTSUM.CUSTOMER= EBANK.CUSTOMER.CUSTOMER_IDand EBANK.CONTRACTSUM.PRODUCT= EBANK.PRODUCT.PRODUCT_ID2.如果创建正确,在结果预览窗口“Preview Relusts”中将看到一下信息:点击“Ok”完成数据集的创建。
在报表中加入交叉报表1.同上例,先在布局编辑器中建立一个1列2行的Grid。
2.从选用板“Palette”视图中拖拽一个“Cross Tab”至第二行的网格中。
在布局编辑器中可以看到我们创建的Cross Tab的样式。
数据准备1.选择数据资源管理器“Data Explorer”。
右键单击“Data Cubes”,选择“New Data Cube”,进入如下交叉表数据编辑界面:2.默认选择的是“Dayaset”,Name:为Cube命名,Customer Cube Primery dataset:选择相关的数据集。
打开下拉菜单选择之前建立的数据集contract3.在左边的主菜单中选择第二项“Groups and Summeries”,出现如下窗口(),在将Available Fields中的CUSTOMER_NAME拖拽到右边Groups (Dimensions)中标有“(Drop a field here to create a group)”的地方,如下图。
多级分类汇总和交叉汇总详细解释
多级分类汇总和交叉汇总详细解释多级分类汇总和交叉汇总,这俩听起来有点复杂,其实就像整理衣柜一样。
咱先说多级分类汇总。
这就好比你衣柜里的衣服特别多,乱成一团可不行。
你可能会先把衣服按季节分,春天的放一堆,夏天的放一堆,这就是一级分类。
然后呢,在每个季节的那堆里,你又按照上衣、裤子、裙子再细分,这就是二级分类。
要是再细致点,在上衣里还能根据长袖、短袖分,这就是多级分类汇总啦。
它的好处可多了,就像你要找一件秋天穿的长袖衬衫,这么一分,一下子就能找到,不用在整个衣柜里乱翻。
企业里也是这样啊,比如说销售数据,先按照地区分,这是一级。
再按照产品类型分,二级。
甚至还能按照销售人员再分下去,这样老板要看哪个地区哪种产品谁卖得好,一目了然。
再讲讲交叉汇总。
这个有点像玩拼图。
你看,每一块拼图都有自己的形状和颜色。
交叉汇总就是把不同维度的数据当成拼图块拼在一起看。
比如说,我们有一个学校的成绩数据,一边是各个学科,语文、数学、英语之类的,另一边是各个班级。
交叉汇总就是看每个班级在每个学科上的成绩情况。
这就好像是在看一幅拼图,每个小块都是不同班级和学科的组合。
从这里面你能发现好多有意思的事儿呢。
比如说哪个班级语文成绩整体都好,但是数学就不太行了。
这就像是拼图里有一块颜色特别鲜艳,有一块就有点暗淡。
这对于学校来说,就知道该给哪个班级补补数学啦。
在生活里也有这样的例子。
就拿家庭开支来说吧。
我们可以先把开支按照吃、穿、住、行分类,这是一级分类。
在吃的里面又分成买菜、下馆子之类的,这是多级分类汇总。
然后我们做交叉汇总,看看每个月在不同的地方花多少钱。
也许你会发现,这个月下馆子花的钱比买菜还多,这时候你就得想想是不是该控制一下下馆子的次数了。
这两个汇总方式啊,真的是特别有用。
要是不这么做,数据或者东西就像一锅粥,乱七八糟的。
你想啊,要是你的衣柜从来不整理,每次找衣服都要翻个底朝天,多麻烦。
企业要是不做这些汇总,就不知道哪个环节出问题了,就像开车没有导航,到处乱撞。
birt报表初级教程之嵌套报表
birt报表初级教程之嵌套报表嵌套报表嵌套报表其实是一种设计技巧的应用,类似编码过程中的模块化设计。
当报表的复杂程度让设计者开始觉得逻辑混乱的时候,可以使用嵌套报表设计方法,将报表拆分为多个不同的设计页面,然后使用一个总的页面将这些设计页面整合起来展现。
此外,嵌套报表有时候也会用于主从结构的实现,通过逐层嵌套,可以实现无限层次的主从结构数据展现。
本例,我们将每个客户的信息包括客户表中基本的信息以及他们的订单信息,在同一张表中按客户一一列出来,所使用的就是嵌套报表。
报表名我们定为:nestingTab.rptdesign构建数据源本例我们使用BIRT自带的数据源,在新建数据源选择数据源类型为默认的第一项:Classic Model Inc,Sample Database数据库驱动类别;org.eclipse.birt.report.data.oda.sampledb.Driver(ClassicModels Inc.SampleDB Driver);URL:jdbc:classicmodels:sampledb构建数据集本例我们需要建立2个数据集:1.建立数据集payments,所用SQL语句:(这里我们加入条件选择订单大于150000)select CUSTOMERNUMBER,sum(AMOUNT)amountfrom CLASSICMODELS.PAYMENTSgroup by CUSTOMERNUMBERhaving sum(AMOUNT)>150000order by amount desc2.建立数据集customers:所用SQL语句:select*from CLASSICMODELS.CUSTOMERS whereCLASSICMODELS.CUSTOMERS.CUSTOMERNUMBER=?输入SQL语句后,还要在数据集编辑窗口选择Parameters选项。
双击默认参数Pram1或者选择“Edit”,弹出如下窗口:输入:Name:CustID;Default Value:103;其它默认完成后,在Preview Result选项中就可看见结果预览:布局嵌套报表1.同上例,先在布局编辑器中建立一个1列2行的Grid。
Excel中的数据表实现数据的交叉分析与汇总
Excel中的数据表实现数据的交叉分析与汇总在处理大量数据时,Excel是一个非常实用的工具。
它不仅可以帮助我们创建数据表格,还可以进行数据的交叉分析与汇总。
本文将介绍如何在Excel中利用数据表格进行交叉分析与汇总的操作。
一、数据表的建立在进行数据的交叉分析与汇总之前,首先需要建立一个数据表。
数据表的建立包括表头和数据填充两个步骤。
1. 表头的设置表头是用来描述数据表中各列的内容的,它通常位于第一行。
在表头的设置中,需要注意以下几点:- 每一列的名称要清楚地反映出相应数据的含义。
- 表头可以合并单元格,以更好地组织和展示数据。
可以通过选中需要合并的单元格,然后在菜单栏中选择"合并和居中"来完成合并操作。
- 表头可以添加筛选器,使得对数据进行筛选更加方便。
选中表头所在的行,在菜单栏中选择"数据"->"筛选"->"筛选器"来添加筛选器。
2. 数据填充在表头设置好之后,下一步是填充数据。
数据填充可以通过手动输入数据或者导入外部数据的方式来完成。
如果有大量数据需要填充,可以使用Excel提供的自动填充功能。
在第一个单元格中输入数据,然后选中这个单元格,将鼠标移动到右下角的小黑点上,会出现一个黑色十字,按住鼠标左键并向下拖动即可快速填充数据。
二、数据的交叉分析数据的交叉分析是指根据不同条件对数据表中的数据进行交叉比较和分析。
在Excel中,可以通过透视表和条件汇总来完成数据的交叉分析。
1. 透视表的使用透视表是一种以交叉表的形式展示数据的方式,能够快速分析数据的总体情况和关联关系。
在Excel中,创建透视表的步骤如下:- 选中需要分析的数据表格。
- 在菜单栏中选择"插入"->"透视表",会出现一个透视表向导。
- 在透视表向导中,选择需要分析的字段,并将其拖拽到相应的区域中(如行区域、列区域或值区域)。
birt报表使用简要说明
Birt报表使用指南1Birt的安装方法把birt整合到了M yeclips e6.5中,(ec lips e的官方网站上提供有一个bi rt-rep ort-design er-all-in-o ne-2_2_2.zip,你直接解压缩这个就可以了,就免去了birt与My ec lipse6.5的整合)。
如果要把bi rt安装到Myecl ipse6.5中,要注意一些事情1.1ecl ip se的版本就是说你的eclipse版本要和适当的bir t版本配合,当前bi rt的最新稳定版是b irt2.3。
如果使用的是ec lips e3.3版本,你应该用bir t-repo rt-framewo rk-2_2_2.zi p,如果使用的是eclipse3.4,你应该用birt-report-f ra mework-2_3_0.zip版本不一致会出一些问题。
1.2在Myec lipse6.5中装birt。
My Eclipse6.5自带的是ecli pse3.3,所以只能下载birt-re port-fra me work-2_2_2.zip (下载地址:http://do wnlo ad.ecl ips /b ir t/downloa ds/index2.2.2.php)而birt-repo rt-frame wo rk-2_3_0.z ip是针对e clip se3.4的。
把下载下来的birt-r epo rt-fram ew ork-2_2_2.zip包解压,解压后的feature s文件夹下的所有文件拷贝到MyEcl ip se6.5安装目录下的..\my ecli pse\e clips e\fe atures 下,解压后的plug in s文件夹下的所有文件拷贝到..\my eclipse\ec lipse\plug ins下。
birt报表入门教程之多层交叉汇总报表
birt报表入门教程之多层交叉汇总报表1.1多层交叉汇总报表1.1.1加入汇总1.在3.8所建立的报表MultilayerCrosstab.rptdesign基础上,点击布局编辑器中Cross Tab左下角的“Cross Tab”图标选中本交叉表。
在Property Editor属性编辑器中选择“Row Area”,(可参考图3-11)。
2.在左边的选项栏中选择第一个选项“Sub Totals”,点击编辑器右边的“Add”按钮,弹出加入次级汇总(本例即根据客户类型进行汇总)的窗口:全部选择默认数据:点击“OK”完成创建。
3.在左边的选项栏中选择第二个选项“Grand Totals”,点击编辑器右边的“Add”按钮,弹出窗口加入行汇总,同样,数据全选默认。
点击“OK”完成创建。
4.在属性编辑器Property Editor视图中选择“Column Area”,同样在左边的选项栏中选择第二个选项“Grand Totals”,点击编辑器右边的“Add”按钮,弹出窗口加入列汇总,同样,数据全选默认。
点击“OK”完成创建。
创建完毕后,布局编辑器如下图:1.1.2格式化与预览格式化后如下图:预览结果如下:同为比较常用的报表工具,FineReport对多层交叉汇总报表的解决方案和实现方法与BIRT有所不同,在finereport交叉汇总是利用层次坐标实现的,以一个简单示例为例,解释具体实现思路和步骤,供BIRT使用者借鉴:1.问题描述逐层累计与跨层累计都是纵方向上的累计,也可以横向进行累计,如下图各个销售员每个月订单金额的累计:2.示例2.1新建报表,设计表样新建工作薄,添加数据集,SQL语句为select雇员ID,strftime('%m',订购日期)as月份,应付金额from订单where strftime('%Y',订购日期)= '2011',查询出2011年每个雇员,每月订单金额。
BIRT报表工具的使用总结
目录
什么是BIRT 为什么选择BIRT
如何使用BIRT
实操环境
/birt
birt-rcp-report-designer .zip 报表制作工具 birt-runtime.war 可以集成在JAVA项目中
客户端的官方例子
运行后,可以显示下面的view
设置-Aggegation聚合计算
设置-排序
if( params["srt"].value == "firstcol" ){row["CUSTOMERNUMBER"];} else if( params["srt"].value == "secondcol"){row["CUSTOMERNAME"];} else if( params["srt"].value == "thirdcol"){row["CONTACTLASTNAME"];}
高级-复用公共库
2.对选中的元素 进行套用自己定 义css
高级-业务类处理数据
高级-通过参数
传参数的场景 目地是通过不同的查询条件,过滤数据源 1.直接数据源就是使用参数变成带条件的查询 2.根据各列排训 3.数据源不变,只要过滤掉一些数据
高级-参数跳转
高级-连接
参数就是全局变量,可以URL替换实现数据更改
交叉表
交叉报表是报表当中常见的类型,属于基本的报表,是行、列方向都有分 组的报表。 行和列的交叉处可以对数据进行多种汇总计算,如:求和、平均值、记数、 最大值、最小值等。
学习关键点: 1. 见帮助里面的例子比较简单 , 只要确认好行、 列的分组项,和要计算的数值 2. 时间维度也非常简单,只要字段是日期型的, 直接拖进去就可以了
BIRT报表开发手册详解
开源报表BlRT开发手册北京宇信易诚科技有限公司2007-08-23目录1Birt 介绍 (5)U 报表介绍 (5)1.2基本概念 (5)1・3 丰富的报表 (5)1.4BIRT报表由四部分组成 (6)1.5报表设计器 (6)2Birt插件安装 (8)2.1插件版本说明 (8)12插件安装 (9)2.2.1完全安装 (9)2.2.2更新安装: (9)2.2.3分步安装 (9)3Birt报表开发实战 (13)3.1创建报表 (13)3.1.1创建报表工程 (13)3.1.2创建报表 (14)3.2数据源配置 (16)3.3创建数据集 (19)3.4网格报表 (20)3.4.1创建数据源 (21)3.4.2创建数据集 (21)343 对报表进行布局 (21)3.4.4格式化与预览 (23)3.5分组报表 (24)3.5.1创建数据源 (25)3.5.2构建数据集 (25)3.5.3对报表进行布局 (25)3.5.4设定分组数据 (25)3.5.5格式化报表 (27)3.6交叉报表 (28)3.6.1构建数据源 (28)362构建数据集 (28)363在报表中加入交叉报表 (28)3.6.4数据准备 (29)3.6.5向交叉表插入数据 (32)3.6.6加入汇总 (33)3.6.7格式化报表 (34)3.7嵌套报表 (35)3.7.1构建数据源 (36)3.7.2构建数据集 (36)3.7.3布局嵌套报表 (38)3.7.4将Table绑左数据集 (39)3.7.5设定主表数据 (39)3.7.6设定子表数据 (40)3.8交互报表 (42)3.83 加入响应参数 (45)384 布局扌艮表 (47)3.8.5插入报表数据 (48)3.8.6格式化与预览 (49)3.9报表钻取 (51)3.9.1设泄响应参数 (51)3.9.2预览结果 (54)3.10图表报表 (55)3」0」为报表插入图表 (55)3」0.2 设定图表属性 (55)3」0.3 图表预览 (60)3.11多层交叉报表 (61)3」1」构建数据源 (61)3.11.2构建数据集 (61)3.11.3在报表中加入交叉报表 (62)3.11.4数据准备 (63)3」1.5 向交叉表插入数据 (63)3」1.6 格式化与预览 (64)3.12多层交叉汇总报表 (65)3」2」加入汇总 (65)3.12.2格式化与预览 (66)3.13 其他 (67)3.61 格式化报表 (67)表头与标题 (67)3.13J.2 设泄单元格格式 (68)3.13J.3 样式套用 (68)3.61.4数据元素格式化 (69)3.13.2分页、页眉与页脚 (70)3.13.2」设置分页显示 (70)3」3.2.2 设置分页打印 (70)3.13.2.3 设冒页眉页脚 (71)3.13.3隔行高亮度显示 (73)3.13.4对报告进行布局 (76)3.13.4」添加删除行或列 (76)3」3.4.2 指定行髙或列宽 (76)3」3.4.3 添加图像 (77)3.13.5数据绑泄 (79)4Birt 报表script (82)4・1 avascript 脚本编写 (82)4.1.1隔行髙亮度显示 (82)4.2java脚本编写 (88)421 创建java 类 (88)4.2.2java类与报表交互 (92)4.3BIRT脚本参考 (98)5Birt报表部署 (99)5・ 1 直接使用运行birt-nmtime-2_2_0 包中的WebViewerExamplc (99)5.2集成到已有web应用 (100)5.3数据库驱动位置 (107)5.4报表url说明 (107)5. 5 web, xml 配置 (113)5. 6 viewer・ properties 说明 (115)5.7BIRT 在jsp 中tag 使用 (116)5.8关于BIRT编码 (123)1Birt介绍1.1报表介绍BIRT一一商业智能和报表工具。
ireport 4.5教程之交叉表
ireport4.5教程之交叉表一个CrossTabs是一种在设计的时候既不确定行数和也不确定列数的一种表格,在运行环境下它会像下面显示的不同年份的一个销售报表一样。
水果/年份200420052006草莓野生樱桃CrossTabs在jasperresports中从1.1.0版本时开始提供,同时iReport 也从1.1.0开始支持CrossTabs。
Jasperreports的CrossTabs工具允许对行和列的数据进行分组、汇总和自定义每一个cell里的内容。
填充CrossTab的数据可以来自主报表里的dataset 或来自subDataset。
使用iReport里提供的向导我们可以简单快速的创建功能强大的交叉报表组件。
一个CrossTabs本质上是一个表格,行和列的数量取决于填充这个表格的数据。
行和列也可以在groups里做聚合操作。
对于每一个行或列的group我们都可以得到一个细节信息和一个可选的行列数据的汇总。
交叉表向导(Crosstab wizard)为了说明怎么让一个crosstab工作起来,我们将使用向导创建一个crosstab,当我们在工具条里选择crosstab元素并将其添加到报表中时crosstab的向导会自动启动。
还是以DoradoSample里提供的hsql数据里的employee报为例,我们使用包含下面查询语句的空报表开始:Select*from employee我们把crosstab放在报表的底部:summary band在第一步里我们需要选择一个dataset来填充crosstab,我们这里使用主报表里提供的dataset,点击下一步继续。
在第二步里我们需要定义至少一个行分组.我们这里选择对所有记录使用DEPT_ID进行分组。
这样就意味着crosstab的每一行将会采用一个明确的部门编号,这样JasperReports将会使用部门编号对数据集里的数据进行重新整理计算。
BIRT报表技术培训
BIRT开发技术培训BIRT深入培训简介BIRT是一个Eclipse-based开放源代码报表系统。
它主要是用在基于Java与J2EE的Web应用程序上。
BIRT主要由两部分组成:一个是基于Eclipse的报表设计和一个可以加到你应用服务的运行期组件。
BIRT同时也提供一个图形报表制作引擎。
BIRT拥有和Dreamweaver一般的操作界面,可以像画table一样画报表,也可以生成图片、导出Excel、html分页,样式比script设置简单,另外BIRT还有OLAP导航功能。
基本概念数据源:数据的来源,或提供者。
如xml数据源、jdbc数据源、script数据源等数据集:数据集合,它必须与数据源关联,可以理解为查询的结果报表以及报表项,报表可视为是针对一组数据集的表现形式,而报表项这是这个表现形式的某个具体的单元。
它们之间的关系,与窗体和控件的关系非常类似。
报表、数据集、数据源三者间的关系:数据源---数据集---报表。
报表参数:查询参数的表现形式,使用它可以构建更灵活的报表模板和库:主要用于复用报表设计,提高报表开发的效率。
BIRT报表应用☐BIRT报表设计器的安装与配置 配置环境项目搭建☐使用BIRT报表设计器设计报表 设计一个简单报表给报表添加统计图表给报表添加统计图表使用Xml文件建立xml数据源使用JAVA对象建立脚本数据源配置环境IDE:birt-report-designer-all-in-one-2.2.2 (建议初学者下载,下载后是一个ECLIPSE,BIRT已经装好了,方便)Runtime:birt-runtime-2.2.2jdk1.4 or later☐项目搭建直接使用birt_runtime_2.2.2中的WebViewerExample。
⏹将其发布到C:\jakarta-tomcat-5.0.28\webapps目录下,并将其更改名称为birtApp。
⏹将已完成的报表,比如test.rptdesign放到birtApp的根目录下,即可通过http://localhost:8080/birt/frameset?__report=test.rptdesign直接在WTP集成的BIRT插件下的新建web project使用BIRT报表设计器设计报表☐设计一个简单报表创建一个项目⏹选择“文件-→新建-→项目”,出现一新项目对话框。
BIRT交叉报表动态列DEMO说明
该DEMO的环境是 tomcat5.0下,BIRT用的是2.6.2,数据库用的是mysql5.0,
该DEMO访问的地址是
http://localhost:8080/portal/birtView?__report=TestReport1.rptdesign&displayFields=account, cost_Center ,Application_Domain,big_Kind, special
参数
__report 是指定报表名字
displayFields 要显示的字段,用逗号隔开,如果不写该参数,显示所有字段。
其中的对应关系:
account -----账簿
cost_Center---- 成本中心
Application_Domain ----应用领域
big_Kind - -----大类
special ----专业
关于BIRT交叉报表动态删除列的说明
1、报表设计部分
数据源,修改自己的数据源
数据集
数据集的数据结构应该是这样:
具体数据可见test_table1.sql文件
2、报表元素
要删除交叉报表的分组列,需要删除列定义、列绑定、分组数据定义以及表头的内容
2.1数据集
账簿的分组定义
账簿分组列绑定定义
账簿账簿的分组数据定义如下:
账簿表头表格定义
账簿表头标签定义
交叉数据集
com.foreveross.kason.birt. BirtReportHandler类中doReport()方法用于删除交叉报表列分组字段的。
具体请看代码
最终结果:
显示全部列
根据参数显示其中3列。
集算器协助报表开发之转置交叉表
集算器协助报表开发之转置交叉表使用Jasper或BIRT等报表工具时,常会碰到一些非常规的统计,用报表工具本身或SQL都难以处理,比如源数据不符合交叉表的要求,需要转置后再呈现。
集算器具有结构化强计算引擎,集成简单,可以协助报表工具方便地实现此类需求。
下面通过一个例子来说明转置交叉表的实现过程。
数据库表booking报表要求呈现指定年份及上一年的预定情况,其中行组有三项,即三种预定状态,列组是年份,测度是当年yearEnd是来自报表的参数,表示用户指定的年份,比如2014。
A1中的代码用来计算上一年(比如2013),为了方便引用,上一年定义为yearBegin。
A2=myDB1.query("select * from booking where year between ? and ? order by year desc",yearBegin,yearEnd)这句代码用来从数据库查出指定年份及上一年的数据。
myDB1是数据源名,指向MYSQL。
函数query可执行SQL语句,也可以接受参数。
假设yearEnd=2014,则A2的计算如下:A3=create(row,col,value)这句代码用来新建序表A3。
A3有三个字段:row、col、value,将来可存储整理之后的数据。
新建后的A3如下:需要注意的是,序表类似数据库结果集,也是结构化二维表,但序表是泛型的,同一个字段可以存储不同的数据类型,序表也是有序的,可以按序号访问数据。
利用序表的这些特点可以方便地实现本案例。
A4: for ["visits","bookings","successfulbookings"]这句代码对集合["visits","bookings","successfulbookings"]进行循环访问,在循环中向A3追加数据,最终准备出报表需要的数据。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
birt教程之多层交叉汇总报表
1.1多层交叉汇总报表
1.1.1加入汇总
1.在3.8所建立的报表MultilayerCrosstab.rptdesign基础上,点击布局编辑器中Cross Tab左下角的“Cross Tab”图标选中本交叉表。
在Property Editor属性编辑器中选择“Row Area”,(可参考图3-11)。
2.在左边的选项栏中选择第一个选项“Sub Totals”,点击编辑器右边的“Add”按钮,弹出加入次级汇总(本例即根据客户类型进行汇总)的窗口:
全部选择默认数据:点击“OK”完成创建。
3.在左边的选项栏中选择第二个选项“Grand Totals”,点击编辑器右边的“Add”按钮,弹出窗口加入行汇总,同样,数据全选默认。
点击“OK”完成创建。
4.在属性编辑器Property Editor视图中选择“Column Area”,同样在左边的选项栏中选择第二个选项“Grand Totals”,点击编辑器右边的“Add”按钮,弹出窗口加入列汇总,同样,数据全选默认。
点击“OK”完成创建。
创建完毕后,布局编辑器如下图:
1.1.2格式化与预览
格式化后如下图:
预览结果如下:
同为比较常用的报表工具,FineReport对多层交叉汇总报表的解决方案和实现方法与BIRT有所不同,在finereport交叉汇总是利用层次坐标实现的,以一个简单示例为例,解释具体实现思路和步骤,供BIRT使用者借鉴:
1.问题描述
逐层累计与跨层累计都是纵方向上的累计,也可以横向进行累计,如下图各个销售员每个月订单金额的累计:
2.示例
2.1新建报表,设计表样
新建工作薄,添加数据集,SQL语句为select雇员ID,strftime('%m',订购日期)as月份,应付金额from订单where strftime('%Y',订购日期)= '2011',查询出2011年每个雇员,每月订单金额。
如下制作一张交叉表:
数据列设置如下:
单元格数据
集
数据列属性
A3ds1雇员
ID
居中,其余默认,设置数据字典显示对应
的雇员姓名
B2ds1月份居中,从左到右扩展,其余默认
B3ds1应付金
额
居中,汇总-求和,不扩展,其余默认
2.2横向累计
在C3单元格中,写入公式:=B3+C3[;B2:-1]:当前月份的金额加上一月累计金额。
其中C3[;B2:-1]表示上父格B2扩展出来的上一格(上月)的C3的值。
2.3保存与预览
保存模板,预览效果如上。
模板效果在线查看请点击Accumulative_3.cpt 已完成模板可参考%FR_HOME%\WebReport\WEB-INF\reportlets\doc\Advanced\Cac uate_Between_Cells\Accumulative_3.cpt。