找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 647|回复: 2

[求助] [求助]:这个表怎么转换成safearray?

[复制链接]
发表于 2006-8-22 11:16:26 | 显示全部楼层 |阅读模式

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

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

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

已领礼包: 593个

财富等级: 财运亨通

发表于 2006-8-22 22:46:21 | 显示全部楼层
Lisp 不能直接构造这样的 Safearray。但可以这样:
构造 variant 类型的safearray -> 用 vlax-safearray-put-element 依次给每个 var 赋值,其中每个值为按其类型的 variant

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

使用道具 举报

发表于 2006-8-23 11:37:34 | 显示全部楼层

  1. (Defun vlsys-list->variant (obj / item nest rrr rtn)  
  2.   (if (/= (type obj) 'list)
  3.     (setq rtn (vlax-make-variant obj))
  4.     (progn
  5.       (setq rrr         nil
  6.             nest nil
  7.       )
  8.       (foreach item obj
  9.         (setq rrr (append rrr (list (vlsys-list->variant item))))
  10.         (if (null nest)
  11.           (setq nest (= (type item) 'list))
  12.         )
  13.       )
  14.       (if nest
  15.         (setq rtn (vlsys-list->variant rrr))
  16.         (progn
  17.           (setq        rtn (vlax-make-safearray
  18.                       vlax-vbVariant
  19.                       (cons 0 (1- (length rrr)))
  20.                     )
  21.           )
  22.           (vlax-safearray-fill rtn rrr)
  23.         )
  24.       )
  25.     )
  26.   )
  27.   rtn
  28. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-29 13:36 , Processed in 0.169215 second(s), 36 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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