得到范围内的字母java_获取EXCEL中对应的列英文字母标识符(字母序列/列标题)(JAVA实现)...

本文介绍了一种Java实现获取Excel文件中指定列的字母标识符的方法,详细解析了计算过程和源码,适用于需要记录特定单元格异常情况的场景。通过等比数列求和公式计算出字母数量,再逐个求得每个字母,最终得到如'F7'这样的列标题。
摘要由CSDN通过智能技术生成

如果您有兴趣,可以继续阅读!

最近的一个专案中客户有这么一个需求:读取EXCEL档案的时候,需要做一些处理,但当处理某个单元格时如果发生异常需要记录是哪个单元格导致的异常,并且以列标题(字母+数字的)形式表示是哪个单元格 比如是 第7行第6列的单元格出错,则会记录 “F7 XXXX”.

我们都知道JAVA 中有很多工具类可以处理很多类型的文档,比如 Workbook 类。但我发现 该类并没有获取EXCEL中对应的列英文字母标题(字母序号/列标题)的方法 如果我要获取第7行第6列的单元格编号”F7″是行不通的,只能记录 “第7行第6列 XXX” 这样的信息,不直观。所以最后还是决定自己动手实现。目前最主要的任务就是获取 第N列对应的字母序列.

过程:因为字母是26位的,所以我第一印象采取的方式就是,类似10进制转16进制的方法。后来发现,这样行不通,总有些字母序列表示不出来. 最主要是因为 0 这个特殊的数字 0 和 00等同,假设 A代表0 那么 AA代表00 这样在数值上 A和AA相等,但在Excel中 A标识第一列 AA标识的是第27列。

后来我把这些字母序号写在纸上,发现了一个规律,他们都是以26n为一个区块,这样的话,我就看是否能采用类似计算文件系统偏移地址的方式来计算出来。后来成功了!

首先 确定字母有几位

A以0开始的,如果从1开始 则Z为26,给后面两位时计算带来麻烦

因为 A=0 时Z=25 A/26=0 Z/26=0 在一个范围内,

而A=1 时 Z=26 A/26=0 Z/26=1 在两个范围内。

然后我们以26n为一

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值