把数字转换成excel的列号

今天在用POI生成Excel,写了一个从数字到excel列号的转换方法,记录下来
[code]
public static String int2Column(final int column)
{
int col = column + 1;
int system = 26;
char[] digArr = new char[100];
int ind = 0;
while (col > 0)
{
int mod = col % system;
if (mod == 0) mod = system;
digArr[ind++] = dig2Char(mod);
col = (col - 1) / 26;
}
StringBuffer bf = new StringBuffer(ind);
for (int i = ind - 1; i >= 0; i--)
{
bf.append(digArr[i]);
}
return bf.toString();
}


private static char dig2Char(final int dig)
{
int acs = dig - 1 + 'A';
return (char)acs;
}
[/code]
在 Java 中实现 Excel 数字相互转换,可通过以下方式: ### 数字 Excel 是基于 26 进制的表示,A 对应 1,B 对应 2,以此类推,AA 对应 27 等。可以从右到左遍历字符串,将每个字符转换为对应的数字,并根据其位置计算权重,最后累加得到对应的数字。示例代码如下: ```java public class ExcelColumnConverter { public static int columnTitleToNumber(String columnTitle) { int result = 0; for (int i = 0; i < columnTitle.length(); i++) { char c = columnTitle.charAt(i); result = result * 26 + (c - 'A' + 1); } return result; } public static void main(String[] args) { String columnTitle = "AB"; int number = columnTitleToNumber(columnTitle); System.out.println(" " + columnTitle + " 对应的数字是: " + number); } } ``` ### 数字数字转换可以使用取模和除法运算。每次对 26 取模得到当前位对应的字符,然后将数字除以 26 继续处理。示例代码如下: ```java public class ExcelColumnConverter { public static String numberToColumnTitle(int num) { StringBuilder result = new StringBuilder(); while (num > 0) { num--; // 调整为 0 开始的索引 char c = (char) (num % 26 + 'A'); result.insert(0, c); num /= 26; } return result.toString(); } public static void main(String[] args) { int number = 28; String columnTitle = numberToColumnTitle(number); System.out.println("数字 " + number + " 对应的是: " + columnTitle); } } ``` 另外,也可以使用递归的方式实现数字,如以下代码: ```java public class ExcelColumnConverter { public static String transNumber(int num, String result) { if (num == 0) { return result; } int pre = num / 26; // 取商 int res = num % 26; // 取余数 if (res != 0) { result = (char) (res + 'A' - 1) + result; } else { result = 'Z' + result; pre = pre - 1; } return transNumber(pre, result); } public static String numberToColumnTitle(int num) { return transNumber(num, ""); } public static void main(String[] args) { int number = 28; String columnTitle = numberToColumnTitle(number); System.out.println("数字 " + number + " 对应的是: " + columnTitle); } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值