Java excel的列号与数字的转换

本文介绍了一个使用Java实现的Excel列号与数字相互转换的代码示例。作者通过提供两个方法ITransformation和CTransformation,实现了数字到字母列号以及字母列号到数字的转换,便于在处理Excel数据时进行列号的操作。
摘要由CSDN通过智能技术生成

起因:

        这件事的起因是我们老大让我整excel,由于我要用vba对excel进行操作,而我又完全不懂vba,写的代码和一坨屎一样,要一下一下的写,所以每次在哪里数列号就很心累。所以想要写一个列号和数字相互转换的demo。

        原文请看这里:(21条消息) Excel 的字母列号与数字互转思路与 Java 实现_pansong291PS的博客-CSDN博客


代码:

package com.demo.controller;


import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.Locale;


/**
 * 方法说明: 用于excel列的计算
 * @version v1.0
 * @author liangalong
 * @date 2022-07-13 10:21
* */
@RestController
@RequestMapping("/ICT")
public class ICTransformation {

    @PostMapping("/getICT")
    public String getICT(String s){
        String s1 = "";
        try {
            Integer i = Integer.valueOf(s);
            s1 = ITransformation(i);
        }catch (Exception e){
            s1 = CTransformation(s);
        }
        return s1;
    }


    /**
     * 方法说明: 数字转列号
     * @param integer
     * @return java.lang.String
     * @version v1.0
     * @author liangalong
     * @date 2022-07-13 17:13*/
    public String ITransformation(Integer integer){
        int len = 0, power = 1, pre = 0;
        for (; pre < integer; pre += power) {
            power *= 26;
            len++;
        }
        char[] excelNum = new char[len];
        integer -= pre - power;
        integer--;
        for (int i = 0; i < len; i++) {
            power /= 26;
            excelNum[i] = (char) (integer / power + 'A');
            integer %= power;
        }
        return String.valueOf(excelNum);
    }


    /**
     * 方法说明: 列号转数字
     * @param s
     * @return java.lang.String
     * @version v1.0
     * @author liangalong
     * @date 2022-07-13 17:14*/
    public String CTransformation(String s){
        char[] chars = s.toUpperCase(Locale.ROOT).toCharArray();
        int i = 0;
        for (char c : chars) {
            i = i * 26 + (c - 'A' + 1);
        }
        return String.valueOf(i);
    }
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值