| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2339 人关注过本帖, 1 人收藏
标题:vfp调用excel生成报表,需填写大量数据,有什么办法提高效率?
取消只看楼主 加入收藏
rola_zhang
Rank: 2
等 级:论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
结帖率:100%
收藏(1)
已结贴  问题点数:20 回复次数:6 
vfp调用excel生成报表,需填写大量数据,有什么办法提高效率?
现手中有个月报表的数据量比较大,A4纸输出有400页,vfp调用excel生成报表时间需5分钟左右,

主要时间用在循环为每个单元格赋值,效率非常低。有没有办法可以同时给多个单元格赋值,值是不一定相同的!

我在VBA里找到的方法是oExcel.Range('&achXYList')=array(1,2,3)

vfp里数组这样给Range赋值是无效的.

各位大侠,有没有好的解决办法!

先行谢过了!!!
搜索更多相关主题的帖子: 办法 数据 效率 excel vfp 
2009-11-13 14:01
rola_zhang
Rank: 2
等 级:论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
收藏
得分:0 
楼上的方法仅适用于一般的二维报表,而且事后需对报表格式作细节方面的改进。对于复杂报表还是解决不了问题
2009-11-14 21:12
rola_zhang
Rank: 2
等 级:论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
收藏
得分:0 
还是谢谢3楼的朋友,期待更完善的解决方法!本人问题中提到的报表就是分组的复杂报表格式
2009-11-14 21:14
rola_zhang
Rank: 2
等 级:论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
收藏
得分:0 
回复 6楼 Tiger5392
以下是引用Tiger5392在2009-11-14 21:50:46的发言:

VFP调用Excel的时候让Excel不可见,也能提高效率。

已经不可见

[ 本帖最后由 rola_zhang 于 2009-11-15 21:29 编辑 ]
2009-11-15 21:25
rola_zhang
Rank: 2
等 级:论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
收藏
得分:0 
以下是引用sd_tysd在2009-11-15 10:48:32的发言:

excel 可以直接 同时打开《dbf》文件与excel打印表格,excel 打印表格可以只做成一页,与《dbf》连接 就可以直接分页打印《dbf》数据。
但是excel打印表格与《dbf》连接时要用 indirect()函数来解决换页。如:INDIRE ...

这样也只能针对一个dbf来实现,而且无法做到先全部预览再打印
2009-11-15 21:28
rola_zhang
Rank: 2
等 级:论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
收藏
得分:0 
今天想到一个办法,初步尝试了一下,方法可行,就是不知道性能会有多大提升!有了结果,一定上来与大家分享!谢谢大家的支持
2009-11-15 21:33
rola_zhang
Rank: 2
等 级:论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
收藏
得分:0 
尝试了两天,有了较好的结果。用全局变量_CLIPTEXT来实现VFP和Excel之间的拷贝和粘贴,可以实现大批量数据赋值。最初,我用_VFP.DataToClip来实现,其赋值数据始终带着字段名,用起来很不爽,后来输出全局变量_CLIPTEXT(_VFP.DataToClip复制的数据保存在这个变量中),发现用_VFP.DataToClip复制的数据其结构非常简单,为了避免多余的字段名这行数据,于是我就没有用_VFP.DataToClip,自己直接填写_CLIPTEXT,出人意料的是效率居然比_VFP.DataToClip还高,我想可能是_VFP.DataToClip里有其他一些参数的判断语句(如delimiter类型).输出数据的填写到_CLIPTEXT的格式如下:'aaaaa'+chr(9)+'bbbbb'+chr(9)+chr(9)+'ccccc'+chr(13)+chr(10)。chr(9)是Tab的值,表示列delimiter,chr(9)+chr(9)表示中间这列输出为'',chr(13)+chr(10)表示回车换行。这样一个数据表示填写某行的4个单元格。如果只输出一行,chr(13)+chr(10)可以不加。同理只需按照这个格式把多行的数据组成一串输出即可。我的报表性能通过这种方式,性能提高了300%,真是爽啊!

另外,Select/Merge等Excel语句尽量少使用,可以合并成成一条的语句表示的,尽量合并。

顺便提醒,这种方式不适合用在已经合并的单元格,如果使用,一定要按照基本单元格来组成数据输出,且合并单元格里的每个基本列必须填写数据(空数据也认可),输出的同时会自动拆分那些已经合并的单元格。
2009-11-17 17:14
快速回复:vfp调用excel生成报表,需填写大量数据,有什么办法提高效率?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.012388 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved