找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2163|回复: 8

[EXCEL] (XD::Excel:i2ColNo)整数转EXCEL的列编号

[复制链接]

已领礼包: 40个

财富等级: 招财进宝

发表于 2013-7-11 09:19:30 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::Excel:i2ColNo
调用格式: (XD::Excel:i2ColNo n)
参数说明: n ---- 整数
返回值: 字符串
函数简介: 整数转EXCEL的列编号
函数来源: 转载
函数作者: ayl-2004
适用版本: 不限 
最后更新时间: 2013-07-11
备注: 命令: (xd::excel:i2colno 3)
"D"

命令: (xd::excel:i2colno 0)
"A"

命令: (xd::excel:i2colno 26)
"AA"

命令: (xd::excel:i2colno 345)
"MH"
演示图片: -

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

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

×
本帖最后由 newer 于 2013-7-11 09:21 编辑

  1. ;|
  2. 整数转EXCEL的列编号
  3. |;
  4. (defun XD::Excel:i2ColNo (a)
  5.   (cond
  6.     ((< a 0)
  7.       ""
  8.     )
  9.     ((>= a 0)
  10.       (strcat (XD::Excel:i2ColNo (1- (fix (/ a 26)))) (chr (+ 65
  11.                                                               (rem a 26)
  12.                                                            )
  13.                                                       )
  14.       )
  15.     )
  16.     (t
  17.       nil
  18.     )
  19.   )
  20. )

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

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-18 08:19:02 | 显示全部楼层
上述函数支持列数有限制,修订如下

理论上支持Autolisp支持的最大正整数, 但是
excel 2003 工作表最大有2^16=65536行,2^8=256列
excel 2007 - 2013 最大有2^20=1048576行,2^14=16384列
  1. ;|整数转EXCEL的列编号|;
  2. (defun XD::Excel:i2ColNo (a / l _i2ColNo)
  3.   (defun _i2ColNo (num / lst)
  4.     (cond
  5.       ((<= 1 num 26)
  6.        (setq lst (cons num lst))
  7.       )
  8.       ((> num 26)
  9.        (setq lst (append (_i2ColNo (/ num 26)) (list (rem num 26))))
  10.       )
  11.       (t lst)
  12.     )
  13.     lst
  14.   )
  15.   (if (and (>= (setq a (fix (abs a))) 1)
  16.            (setq l (_i2ColNo a))
  17.       )
  18.     (apply 'strcat
  19.            (mapcar '(lambda (x) (chr (+ 64 x))) l)
  20.     )
  21.   )
  22. )

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

使用道具 举报

已领礼包: 1757个

财富等级: 堆金积玉

发表于 2014-12-18 14:02:55 | 显示全部楼层
本帖最后由 守仁格竹GM 于 2014-12-18 14:07 编辑

两个函数支持的上限一样
(XD::Excel:i2ColNo  2147483647)
"FXSHRXX" new版主的结果
"FXSHRXW" ST版主的结果
结果不一样
(XD::Excel:i2ColNo  27)
"AB" new版主的结果
"AA" ST版主的结果

点评

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

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-18 14:10:03 来自手机 | 显示全部楼层
守仁格竹GM 发表于 2014-12-18 14:02
两个函数支持的上限一样
(XD::Excel:i2ColNo  2147483647)
"FXSHRXX" new版主的结果

哪个对呢?

点评

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

使用道具 举报

已领礼包: 1757个

财富等级: 堆金积玉

发表于 2014-12-18 14:32:45 | 显示全部楼层

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

使用道具 举报

已领礼包: 51个

财富等级: 招财进宝

发表于 2014-12-18 14:41:24 | 显示全部楼层
守仁格竹GM 发表于 2014-12-18 14:02
两个函数支持的上限一样
(XD::Excel:i2ColNo  2147483647)
"FXSHRXX" new版主的结果

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

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-18 14:52:10 来自手机 | 显示全部楼层
本帖最后由 st788796 于 2014-12-18 14:54 编辑
Lispboy 发表于 2014-12-18 14:41
从0开始算, 27 是 AB,
从1开始算, 27是AA


不同解析库的计算不一样,XdEx是由0列起始,Excel中由1 (A)起始
N 版的对应XdEx解析库

点评

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

使用道具 举报

已领礼包: 51个

财富等级: 招财进宝

发表于 2014-12-18 15:47:55 | 显示全部楼层
st788796 发表于 2014-12-18 14:52
不同解析库的计算不一样,XdEx是由0列起始,Excel中由1 (A)起始
N 版的对应XdEx解析库

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

使用道具 举报

已领礼包: 1211个

财富等级: 财源广进

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 07:03 , Processed in 0.213777 second(s), 49 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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