乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 188|回复: 9

[求助]VB读取数据文件的求助

[复制链接]

4

主题

12

帖子

3

银币

初来乍到

Rank: 1

铜币
28
发表于 2008-10-31 21:54:00 | 显示全部楼层 |阅读模式
1      X=-6.6660    Y=-9.0000    Z=7.5926     
   2      X=-5.0010    Y=-10.6386   Z=9.2911     
   3      X=-8.3340    Y=-10.6386   Z=9.2911     
   4      X=-13.3320   Y=-9.0000    Z=7.5926     
   5      X=-11.6670   Y=-10.6386   Z=9.2911     
   6      X=-15.0000   Y=-10.6386   Z=9.2911     
   7      X=-19.9980   Y=-9.0000    Z=7.5926     
   8      X=-18.3330   Y=-10.6386   Z=9.2911     
   9      X=-21.6660   Y=-10.6386   Z=9.2911     
   10     X=-26.6640   Y=-9.0000    Z=7.5926     
   11     X=-24.9990   Y=-10.6386   Z=9.2911     
   12     X=-28.3320   Y=-10.6386   Z=9.2911     
   13     X=-36.6630   Y=-9.0000    Z=7.5926     
   14     X=-34.9980   Y=-10.6386   Z=9.2911     
   15     X=-38.3310   Y=-10.6386   Z=9.2911     
   16     X=-5.0010    Y=-7.6322    Z=9.8935     
   17     X=-8.3340    Y=-7.6322    Z=9.8935     
   18     X=-11.6670   Y=-7.6322    Z=9.8935     
   19     X=-15.0000   Y=-7.6322    Z=9.8935     
   20     X=-18.3330   Y=-7.6322    Z=9.8935     
我想得到每一行等号之后的数据,有没有好的办法快速得到?
在这里先谢谢各位大侠了。
回复

使用道具 举报

124

主题

837

帖子

9

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1333
发表于 2008-11-1 14:25:00 | 显示全部楼层
用两次Split函数,第一次以空格分割,第二次以"="分割.
例如:
Sub test()
    Dim s As String
    s = "20     X=-18.3330   Y=-7.6322    Z=9.8935"
    Dim v As Variant
    v = VBA.Split(s, " ")
   
    Dim col As New Collection
    Dim i As Integer
    For i = LBound(v) To UBound(v)
        If VBA.InStr(1, v(i), "=") > 0 Then
            Dim vv As Variant
            vv = VBA.Split(v(i), "=")
            col.Add vv(1)
        End If
    Next
   
    '显示结果
    For i = 1 To col.Count
        MsgBox col(i)
    Next
End Sub
回复

使用道具 举报

120

主题

326

帖子

7

银币

中流砥柱

Rank: 25

铜币
806
发表于 2008-11-1 18:32:00 | 显示全部楼层
这是字符分离问题.
要点Split(s, " ")关键语句.
回复

使用道具 举报

158

主题

2315

帖子

10

银币

顶梁支柱

Rank: 50Rank: 50

铜币
2951
发表于 2008-11-1 20:17:00 | 显示全部楼层
我的方法是先把X=,Y=和Z=删除掉,再Split,得到的数组就可以直接用了。
回复

使用道具 举报

1

主题

26

帖子

4

银币

初来乍到

Rank: 1

铜币
30
发表于 2008-11-10 21:30:00 | 显示全部楼层
请问明总,以上你所说的方法如何实现呢?怎样删除这些数据?请指教
回复

使用道具 举报

158

主题

2315

帖子

10

银币

顶梁支柱

Rank: 50Rank: 50

铜币
2951
发表于 2008-11-10 21:49:00 | 显示全部楼层
这还不简单:v=Split(Replace(Replace(Replace(s,"X=",""),"Y=",""),"Z=","")," ")
回复

使用道具 举报

15

主题

70

帖子

2

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
130
发表于 2008-11-11 08:01:00 | 显示全部楼层
如明总所说,写程序就要找出最简单的规律。如果一定要使用程序替换的话,明总的办法最好;如果不使用程序替换,直接在记事本中打开,然后替换。
回复

使用道具 举报

1

主题

26

帖子

4

银币

初来乍到

Rank: 1

铜币
30
发表于 2008-11-11 10:16:00 | 显示全部楼层
恩,学习了,谢谢两位.
回复

使用道具 举报

0

主题

12

帖子

3

银币

初来乍到

Rank: 1

铜币
12
发表于 2008-11-21 12:25:00 | 显示全部楼层
学习到一点啊,确实比较方便!
顶一下!谢谢了!
回复

使用道具 举报

4

主题

12

帖子

3

银币

初来乍到

Rank: 1

铜币
28
发表于 2008-11-29 09:19:00 | 显示全部楼层
谢谢了。
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-7-4 16:04 , Processed in 0.432961 second(s), 72 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表