找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1624|回复: 2

[原创] Excel数字列号转换为字母列号

[复制链接]
发表于 2017-5-28 10:16:55 | 显示全部楼层 |阅读模式

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

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

×
本帖最后由 wdmzslw 于 2017-5-28 12:32 编辑

  • [sell=2];;说明:Excel数字列号转换为字母列号的函数
    ;;参数:num:整数。理论取值范围为1-18278,但Excel2007以后版本最大列数为16384(XFD),超过此值没有意义。
    ;;返回:字母字符串
    ;;作者:wdmzslw
    (defun Excel::COLnum2alph(num / v1 v2 v3)
            (setq v1 (/ num 676)
                        v2 (/ (rem num 676) 26)
                        v3 (rem (rem num 676) 26)
            )
            (if (= 0 v3)
                    (if (= 0 v2)
                            (setq v1 (- v1 1)
                                        v2 25
                                        v3 26
                            )
                            (setq v2 (- v2 1)
                                        v3 26
                            )
                    )
            )
            (if (and(/= v1 0 )(= 0 v2))
                            (setq v1 (- v1 1)
                                  v2 26
                    )
            )
            (vl-list->string(mapcar '(lambda(x)(+ x 64))(vl-remove-if '(lambda(x)(= x 0) )(list v1 v2 v3))))
    )[/sell]

(defun c:t1 (/ num)
        (while (setq num (getint"\n输入一个整数:"))
                (if (and (> num 0)(<= num 16384))
                        (princ (Excel::COLnum2alph num))
                )
                (princ"\n")
        )
)
输入一个整数:26
Z
输入一个整数:27
AA
输入一个整数:702
ZZ
输入一个整数:703
AAA
输入一个整数:16384
XFD

(defun c:t2 ( / n f)
        (setq n 0)
        (setq f (open "c:\\1.txt" "w"))
        (repeat 18278
                (write-line (vl-princ-to-string(Excel::COLnum2alph (setq n (1+ n)))) f)
        )
        (close f)
)

评分

参与人数 1D豆 +5 贡献 +1 收起 理由
newer + 5 + 1 很给力!经验;技术要点;资料分享奖!

查看全部评分

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
 楼主| 发表于 2017-5-28 10:16:56 | 显示全部楼层
(defun c:t1 (/ num)
        (while (setq num (getint"\n输入一个整数:"))
                (if (and (> num 0)(<= num 16384))
                        (princ (Excel::COLnum2alph num))
                )
                (princ"\n")
        )
)
输入一个整数:26
Z
输入一个整数:27
AA
输入一个整数:702
ZZ
输入一个整数:703
AAA
输入一个整数:16384
XFD

(defun c:t2 ( / n f)
        (setq n 0)
        (setq f (open "c:\\1.txt" "w"))
        (repeat 18278
                (write-line (vl-princ-to-string(Excel::COLnum2alph (setq n (1+ n)))) f)
        )
        (close f)
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 40个

财富等级: 招财进宝

发表于 2017-5-28 11:24:17 | 显示全部楼层

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-18 17:02 , Processed in 1.516784 second(s), 37 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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