乐筑天下

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

VBA开发,刚学请多指教

[复制链接]

7

主题

20

帖子

1

银币

初来乍到

Rank: 1

铜币
48
发表于 2016-4-11 21:15:00 | 显示全部楼层 |阅读模式
怎么样用VBA开发读取文本文件,高程点信息,谢谢

fxvpnbgapzy.png

fxvpnbgapzy.png

该贴已经同步到

本帖以下内容被隐藏保护;需要你回复后,才能看到!

游客,如果您要查看本帖隐藏内容请回复
回复

使用道具 举报

23

主题

561

帖子

13

银币

中流砥柱

Rank: 25

铜币
653
发表于 2016-4-11 22:09:00 | 显示全部楼层
如果你是想学习vba,哪么,你的问题首先是读取文本文件,这你会吗?
回复

使用道具 举报

7

主题

20

帖子

1

银币

初来乍到

Rank: 1

铜币
48
发表于 2016-4-12 18:08:00 | 显示全部楼层

不会的,几乎零基础,因为要做开发,所以现在在努力学
回复

使用道具 举报

0

主题

14

帖子

2

银币

初来乍到

Rank: 1

铜币
14
发表于 2016-4-23 00:30:00 | 显示全部楼层

看错了
应该是SPLIT文本文件的数据
把数据转化成点的坐标值 x,y
然后绘图是不是这个意思?
回复

使用道具 举报

0

主题

14

帖子

2

银币

初来乍到

Rank: 1

铜币
14
发表于 2016-4-23 00:32:00 | 显示全部楼层
可以做成数组,数组的元素来源于TXT
然后再定义坐标点数组就是你获取来的数组
然后绘制POINT(0  TO 2)
什么的
回复

使用道具 举报

7

主题

20

帖子

1

银币

初来乍到

Rank: 1

铜币
48
发表于 2016-4-25 21:39:00 | 显示全部楼层

已经读取坐标值了,并且在CAD上展点了,我想通过比较求出x,y的最大最小值,不知道大神会不会啊
回复

使用道具 举报

5

主题

12

帖子

1

银币

初来乍到

Rank: 1

铜币
32
发表于 2016-4-27 06:12:00 | 显示全部楼层
是所有点的的最大X、Y值么
回复

使用道具 举报

7

主题

20

帖子

1

银币

初来乍到

Rank: 1

铜币
48
发表于 2016-4-27 08:57:00 | 显示全部楼层

对,就是求出X和Y的最大最小值,这是我的代码,不对的地方,希望帮忙改正,谢谢
  1. Dim L As Integer
  2. Dim H(10000) As Double, X(10000) As Double, Y(10000) As Double, Z(10000) As Double
  3. Dim Xmax As Double, Xmin As Double, Ymax As Double, Ymin As Double
  4. Sub txt_read()
  5. Dim txtname As String
  6. Dim L As Integer
  7.     L = 0 '初始值
  8.     Open "E:\demdata.txt" For Input As #1  '打开文件
  9.     Do While Not EOF(1) '文件读取循环
  10.     If X(L + 1) > X(L) Then
  11.     Xmax = X(L + 1)
  12.     ElseIf Y(L + 1) > Y(L) Then
  13.     Ymax = Y(L + 1)
  14.     Else
  15.     Xmin = X(L + 1)
  16.     Ymin = Y(L + 1)
  17.     End If
  18.     L = L + 1 '个数加1
  19.     Input #1, H(L), X(L), Y(L), Z(L) '读取文件数据, H贮存点序号,XYZ为坐标
  20.     Loop '文件读取循环
  21.     Close #1 '关闭文件
  22. End Sub
回复

使用道具 举报

2

主题

11

帖子

1

银币

初来乍到

Rank: 1

铜币
19
发表于 2016-4-27 09:37:00 | 显示全部楼层
我只是个三流的程序猿, Open  For Input As #1  从来没用过,不敢妄加评论呀。有事都baidu的。
但是  if  elseif  的情况不该交叉 。。。
  1.     L = 0 '初始值
  2.    Open "E:\demdata.txt" For Input As #1  '打开文件
  3.   Xmax = X(0) :Xmin = X(0)
  4.   Ymax = Y(0) :Ymin = Y(0)
  5.     Do While Not EOF(1) '文件读取循环
  6.     If X(L) >= Xmax Then
  7.     Xmax = X(L)
  8.     end if
  9.     If Y(L) >= Ymax Then
  10.     Ymax = Y(L)
  11.     End If
  12.    If X(L) <= Xmin Then
  13.     Xmin= X(L)
  14.     end if
  15.     If Y(L) <= Ymin Then
  16.     Ymin = Y(L)
  17.     End If
  18.     L = L + 1 '个数加1
回复

使用道具 举报

7

主题

20

帖子

1

银币

初来乍到

Rank: 1

铜币
48
发表于 2016-4-27 09:39:00 | 显示全部楼层

就是一个值一个值求吗,谢谢啦
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-4-20 01:05 , Processed in 3.437404 second(s), 75 queries .

© 2020-2025 乐筑天下

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