|
网站首页
|
业界新闻
|
小组
|
威客
|
人才
|
下载频道
|
博客
|
代码贴
|
在线编程
|
编程论坛
|
登录
注册
短消息
我发表的主题
我参与的主题
我收藏的贴子
我上传的附件
我下过的附件
编辑个人资料
我的博客
用户控制面板
搜索
道具
恢复默认风格
碧海青天
秋意盎然
棕红预览
粉色回忆
蓝雅绿
紫色淡雅
青青河草
e点小镇
橘子红了
红红夜思
水晶紫色
雪花飘飘
新年快乐
风格
短消息
论坛展区
帮助
编程论坛
→
数据库技术
→
『 VFP论坛 』
→ vfp调用excel生成报表,需填写大量数据,有什么办法提高效率?
我的收件箱(0)
欢迎加入我们,一同切磋技术
用户名:
密 码:
共有
2339
人关注过本帖,
1
人收藏
标题:
vfp调用excel生成报表,需填写大量数据,有什么办法提高效率?
取消只看楼主
加入收藏
rola_zhang
等 级:
论坛游民
帖 子: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
等 级:
论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
第
2
楼
收藏
得分:0
楼上的方法仅适用于一般的二维报表,而且事后需对报表格式作细节方面的改进。对于复杂报表还是解决不了问题
2009-11-14 21:12
举报帖子
使用道具
赠送鲜花
rola_zhang
等 级:
论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
第
3
楼
收藏
得分:0
还是谢谢3楼的朋友,期待更完善的解决方法!本人问题中提到的报表就是分组的复杂报表格式
2009-11-14 21:14
举报帖子
使用道具
赠送鲜花
rola_zhang
等 级:
论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
第
4
楼
收藏
得分: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
等 级:
论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
第
5
楼
收藏
得分: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
等 级:
论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
第
6
楼
收藏
得分:0
今天想到一个办法,初步尝试了一下,方法可行,就是不知道性能会有多大提升!有了结果,一定上来与大家分享!谢谢大家的支持
2009-11-15 21:33
举报帖子
使用道具
赠送鲜花
rola_zhang
等 级:
论坛游民
帖 子:12
专家分:11
注 册:2009-11-13
第
7
楼
收藏
得分: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
举报帖子
使用道具
赠送鲜花
7
1/1页
1
快速回复:
vfp调用excel生成报表,需填写大量数据,有什么办法提高效率?
数据加载中...
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.030454 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved