输入数字列号获取EXCEL的列编号

根据输入的数字列号,转换为标准的excel列编号,比如:29对应AC
FUNCTION z_num_to_excel_column.
*"----------------------------------------------------------------------
*"*"本地接口:
*"  IMPORTING
*"     REFERENCE(IV_NUM) TYPE  I
*"  EXPORTING
*"     REFERENCE(IV_COLUMN) TYPE  STRING
*"----------------------------------------------------------------------

  IF iv_num LE 0.
    EXIT.
  ENDIF.

  DATA: lv_array  TYPE string,
        lv_num    TYPE i,
        lv_divide TYPE i,
        lv_mod    TYPE i,
        lv_float  TYPE p DECIMALS 2.

  lv_array = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'.

* 从右往左确定字母
  lv_num = iv_num.
  lv_mod = lv_num MOD 26.
  lv_mod = lv_mod - 1.
  IF lv_mod = -1.
    lv_mod = lv_mod + 26.
  ENDIF.
  iv_column = lv_array+lv_mod(1).

  lv_num = iv_num.
  WHILE lv_num > 26.
    lv_float = lv_num / 26.
    lv_num = lv_num / 26.  "Demo:27 AA
    IF lv_num > lv_float.
      lv_num = lv_num - 1.
    ENDIF.

    lv_mod = lv_num MOD 26.
    lv_mod = lv_mod - 1.
    IF lv_mod = -1.
      lv_mod = lv_mod + 26.
    ENDIF.

    CONCATENATE lv_array+lv_mod(1) iv_column INTO iv_column.
  ENDWHILE.

  CONDENSE iv_column.

ENDFUNCTION.

 

测试结果

 

 

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王小磊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值