找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 506|回复: 2

[求助] VLISP读到EXCEL时的,某一列有数据的最后一行怎么求得?????

[复制链接]
发表于 2017-7-1 12:02:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
VLISP读到EXCEL时的,某一列有数据的最后一行怎么求得或在VLISP中如何表示最后一行?
'usedrange 不行,无限行啊...
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 20个

财富等级: 恭喜发财

发表于 2017-7-1 13:32:18 | 显示全部楼层
多看看 excel vba 手册,看看里面每个对象提供的方法和属性。

EXCEL对象的层次
EXCEL ---> WORKBOOKS---> WORKWORD----> SHEETS ----->SHEET
一个表格,是在sheet对象下面,所以,你要查sheet都有什么属性和方法,用 Rows属性,就获得了总共有多少行,Columns属性获得总共有多少列

下面代码摘自EXCEL VBA手册

本示例将工作表 Sheet1 上每隔一列的列宽设置为 4 磅。


[Visual Basic] 纯文本查看 复制代码
For Each rw In Worksheets("Sheet1").Rows
    If rw.Row Mod 2 = 0 Then
        rw.RowHeight = 4    
   End If
Next rw

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-7-1 15:17:20 | 显示全部楼层
EXCEL VBA我了解一些,也知怎么怎么求行数和列数,可VLISP应有特定的函数吧,因为我要直接在CAD中读EXCEL的数据
(setq shs (vlax-get-property wb "Sheets"))                       ;获取刚才打开工作簿的工作表集合
(setq sh  (vlax-get-property  shs "Item" sheetName))             ;获取指定的工作表
(setq rg (vlax-get-property  sh 'usedrange))               ;用指定的字符串创建工作表范围对象  
(setq vvv (vlax-get-property rg 'Value))                         ;获取范围对象的值  
(setq ttt (vlax-safearray->list (vlax-variant-value vvv)))       ;转换为list
关键是取得范围(setq rg (vlax-get-property  sh 'usedrange))
这个'usedrange 取了表中所有行和所有列。。无限,所以有问题,应该用类似于[b65536].End(xlUp).Row
可VLISP怎么办?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-24 02:36 , Processed in 0.309009 second(s), 32 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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