动态报表的方案二——文件方式

N天前写了一篇动态报表的文章,里面所用的方法比较简单,适合建立中规中矩的N行N列的简单报表。(具体请参看http://blog.csdn.net/LYMEGG1984/archive/2010/09/21/5898518.aspx)这段时间在做一些套打的程序时,发现这种方法不行,套打中的表格并不是简单的N行N列,而且需要控制的精度也相对的高,如此一来就不能用传入一个或几个表的方法解决问题了,所以只好另辟出路。

从套打的角度出发,如果可以把这个报表保存为一个模板,打印时调用,填充上要打印的数据,就可以解决大部分问题了。XtraReport报表编辑器里的保存,是可以保存为一个文件的,所以它应该提供了一个从文件加载的方法,这时我们可以发现XtraReport里有一个LoadLayout的方法,可以加载报表文件,再往下我们可以发现它的重载方法是可以从IO.Stream里加载报表文件,也就是说,我们可以进一步的把这个报表模板以二进制的方式保存在数据库里。需要的时候,从数据库调用即可。

这时我们发现还有一个问题,就是填充数据的问题。这个问题就有很多的解决办法。我简单的说说我所用的方法,我的方法是,数据源我还是用一个DataTable传递;在做报表模板的时候,在需要填充数据的控件的Tag属性上,填上数据源上的列名;然后加载模板后稍作处理即可。

因为代码中涉及其他公司的东西,就不能尽数全贴代码,只能贴针对问题贴关键的代码,如果有问题,欢迎讨论!!

加载模板的代码:

 

 

填充数据的方法,这个问题的解决方法有很多,希望大家讨论,提出更好的方法:

 

 

PS:如果你在一个博客名叫笨蛋EGG的163博客看到这篇文章,请不要怀疑,这篇是在163博客首发的,现在搬家转过这里来了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值