ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 17832|回复: 13

[Excel 程序开发] [第25期]数据提取(已结)

[复制链接]

TA的精华主题

TA的得分主题

发表于 2007-7-2 10:07 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助

序言
纵观竞赛区的VBA题目,大多实用性较低,这期出一个实用一点的题目,乃本人实际工作中遇到的问题。如果大家对竞赛题有什么意见或建议,请到此贴发表http://club.excelhome.net/viewthread.php?tid=250396&px=0

题目说明:
附件中有一个文本文件RealTimeData.txt,里面的数据为证券交易所与券商之间的通讯数据,数据传输采用STEP.1.0.0协议(证券交易数据交换协议,可参考附件),以消息的形式传输。每条消息都是以8=STEP.1.0.0
开始的,以10=xxx结束的,消息之间用(ASCII码为1的符号,晕,这个符号是非打印符号,加上之后就发不了贴,发了n次,大家在单元格输入=char(1)可看到此符号)做分隔符。现要提取前1000条消息到EXCEL中,每个字段占一列,如图所示。注意每条消息的长度不一定相等。


[此贴子已经被作者于2007-7-29 18:57:23编辑过]
单选投票, 共有 24 人参与投票

距结束还有: 3646 天17 小时16 分钟

您所在的用户组没有投票权限

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x

TA的精华主题

TA的得分主题

发表于 2007-7-3 22:42 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

答案已发送至:agstick@126.com,占位。

答案正确,但速度稍慢。

[此贴子已经被agstick于2007-7-22 18:15:50编辑过]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x

TA的精华主题

TA的得分主题

发表于 2007-7-4 17:42 | 显示全部楼层

没有很好的理解题意,也不知自己做的对否,已发至指定邮箱,请版主审验。

 


结果正确,但用ReadAll方法一次性读取数据不好,占用内存大,对大文件不实用(导致内存溢出),本题原文件有1G多,这里只是截取了一小部分。

[此贴子已经被agstick于2007-7-22 18:29:15编辑过]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x

TA的精华主题

TA的得分主题

发表于 2007-7-7 12:17 | 显示全部楼层


已经发了邮件,请老师批阅,谢谢!



结果正确,一次性全部读入不好,一来占内存,二来耗时。

[此贴子已经被agstick于2007-7-23 22:49:45编辑过]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x

TA的精华主题

TA的得分主题

发表于 2007-7-11 11:21 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助

已将EXCEL文件发送到你的邮箱:agstick@126.com,跟一贴占位


代码挺简洁的,一次性读入不好。

[此贴子已经被agstick于2007-7-23 22:52:04编辑过]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x

TA的精华主题

TA的得分主题

发表于 2007-7-13 08:04 | 显示全部楼层

回复为什么有40byte的限制

我的答案已发往你的邮箱,请查收,

我的答案已发往你的邮箱,请查收

我的答案已发往你的邮箱,请查收

我的答案已发往你的邮箱,请查收


结果正确,循环太慢。

[此贴子已经被agstick于2007-7-23 22:55:55编辑过]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x

TA的精华主题

TA的得分主题

发表于 2007-7-14 19:57 | 显示全部楼层

邮件已发送请查收

邮件已发送请查收

邮件已发送请查收

邮件已发送请查收


结果正确,一次性读入不好。

[此贴子已经被agstick于2007-7-23 22:57:26编辑过]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x

TA的精华主题

TA的得分主题

发表于 2007-7-14 21:29 | 显示全部楼层

好多期VBA题没做过了,这期的简单,凑一下热闹。

答案已发送至版主邮箱,请审阅。

占楼完毕。

********************************************************************


结果正确,速度较慢。

[此贴子已经被agstick于2007-7-23 23:03:41编辑过]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x

TA的精华主题

TA的得分主题

发表于 2007-7-16 11:12 | 显示全部楼层

参与一下!!!!!!!!!!!


结果正确,仍然是一次性读入。

[此贴子已经被agstick于2007-7-23 23:04:43编辑过]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x

TA的精华主题

TA的得分主题

 楼主| 发表于 2007-7-23 23:46 | 显示全部楼层

本题的主要考察大家灵活提取数据。

1、本题数据集很大,本来有1G多,这里只截取了不到2M,所以用一次性读取的方法并不合适,一个字符串变量最多存放大概20亿个字符,多了会溢出。

2、本题的每条消息的长度不确定且长短不一,不能通过读入固定长度的字符串来读取。因此,我们通过seek方法来查找出每一条消息的长度,逐条读取,这样可以节约内存,但对大量数据速度会有一定的影响。

 

 以下是我的答案,供参考,不一定是最好的解法,应根据不同情况,应用不同的方法。


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-21 16:50 , Processed in 0.042134 second(s), 14 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表