找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1686|回复: 9

[EXCEL] (XD::Excel:ColNo2Int)Excel列编号转数字

[复制链接]

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-18 08:34:22 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::Excel:ColNo2Int
调用格式: (XD::Excel:ColNo2Int str)
参数说明: str - 列编号
返回值: int - 整数
函数简介: Excel列编号转数字
函数来源: 原创
函数作者: st788796
适用版本: 不限 
最后更新时间: 2014-12-18
备注: -
演示图片: -

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

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

×
本帖最后由 st788796 于 2014-12-18 08:45 编辑

  1. (defun XD::Excel:ColNo2Int (str / i l)
  2.   (if (vl-every        '(lambda (x)
  3.                    (<= 65 x 90)
  4.                  )
  5.                 (setq l (vl-string->list (strcase str)))
  6.       )
  7.     (progn
  8.       (setq l (mapcar '(lambda (x) (- x 64)) l)
  9.             i (length l)
  10.       )
  11.       (apply '+
  12.              (mapcar '(lambda (x)
  13.                         (* x (expt 26 (setq i (1- i))))
  14.                       )
  15.                      l
  16.              )
  17.       )
  18.     )
  19.   )
  20. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 40个

财富等级: 招财进宝

发表于 2014-12-18 08:52:46 | 显示全部楼层
能举个例子吗,列字符串有什么写法要求没?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

 楼主| 发表于 2014-12-18 08:55:48 | 显示全部楼层
本帖最后由 st788796 于 2014-12-18 08:57 编辑
newer 发表于 2014-12-18 08:52
能举个例子吗,列字符串有什么写法要求没?

判断必须 a-z A-Z
_$ (XD::EXCEL:COLNO2INT "aa")
27
_$ (XD::EXCEL:COLNO2INT "XFD")
16384
_$ (XD::EXCEL:COLNO2INT "aXFD")
33960
_$ (XD::EXCEL:COLNO2INT "1aXFD")
nil
_$
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 51个

财富等级: 招财进宝

发表于 2014-12-18 10:24:49 | 显示全部楼层
字符串地址转行列号
(xdex_cell_addr2RC  <字符串地址>)

<字符串地址> 支持范围格式

命令: (xdex_cell_Addr2RC "b2")
(1 1)

命令: (xdex_cell_Addr2RC "c8")
(7 2)

命令: (xdex_cell_Addr2RC "a1")
(0 0)

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

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

 楼主| 发表于 2014-12-18 10:41:36 来自手机 | 显示全部楼层
Lispboy 发表于 2014-12-18 10:24
字符串地址转行列号
(xdex_cell_addr2RC  )


用ActiveX方式在lisp的表写入xls时主要把length行列转换为列编号,这样用range的value方法直接把列表写入,不用去遍历
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

 楼主| 发表于 2014-12-18 15:00:35 来自手机 | 显示全部楼层
本帖最后由 st788796 于 2014-12-18 15:02 编辑
Lispboy 发表于 2014-12-18 10:24
字符串地址转行列号
(xdex_cell_addr2RC  )



Excel 的RC引用是由 1 起始计数
AcDbTable 及 ODCL Grid 控件由 0 起始计数

点评

所以,EXCEL地址转换CAD下,1应该变成0 命令: (xdex_cell_Addr2RC "a1") (0 0)  详情 回复 发表于 2014-12-18 15:46
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 51个

财富等级: 招财进宝

发表于 2014-12-18 15:46:13 | 显示全部楼层
st788796 发表于 2014-12-18 15:00
Excel 的RC引用是由 1 起始计数
AcDbTable 及 ODCL Grid 控件由 0 起始计数

所以,EXCEL地址转换CAD下,1应该变成0

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

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

 楼主| 发表于 2014-12-18 15:49:05 来自手机 | 显示全部楼层
Lispboy 发表于 2014-12-18 15:46
所以,EXCEL地址转换CAD下,1应该变成0

命令: (xdex_cell_Addr2RC "a1")

CAD表格转过去还要+1:)

点评

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

使用道具 举报

已领礼包: 51个

财富等级: 招财进宝

发表于 2014-12-18 15:55:01 | 显示全部楼层
本帖最后由 Lispboy 于 2014-12-18 15:57 编辑
st788796 发表于 2014-12-18 15:49
CAD表格转过去还要+1

是啊,总有一方要适应另一方。 不变成行列数的时候,从0开始, 变成地址的时候从1.
EXCEL转行列数,是为了给CAD用,CAD行列转地址是为了给EXCEL用。都从函数内部解决。不要转2次。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

 楼主| 发表于 2014-12-18 16:09:59 来自手机 | 显示全部楼层
Lispboy 发表于 2014-12-18 15:55
是啊,总有一方要适应另一方。 不变成行列数的时候,从0开始, 变成地址的时候从1.
EXCEL转行列数,是为 ...

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-25 14:37 , Processed in 0.309957 second(s), 50 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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