indexToExcelColumn = (index)=>{
// 自然数
if (typeof index !== 'number') return false;
if (Number.isNaN( index )) return false;
if ( (1 / index) < 0 ) return false;
if (index < 0) return false;
// 调整为正确的数值
var arr26 = index.toString(26).split('');
var arr = arr26.map(x=>(x.charCodeAt()<='9'.charCodeAt() && x.charCodeAt()>='0'.charCodeAt())?(x.charCodeAt()-'0'.charCodeAt()):(x.charCodeAt()-'a'.charCodeAt()+10));
// Excel列名大于一位时,第一位于后面位的计算方式不一样,需要减少1
if(arr.length>1) arr[0] --;
return arr.map(x=>String.fromCharCode(x+'A'.charCodeAt())).join('');
}
【JavaScript】自然数转Excel列名
最新推荐文章于 2024-04-01 22:45:00 发布
本文介绍了一种将数字索引转换为Excel列名的算法实现。该算法首先验证输入是否为有效正整数,然后将其转换为26进制表示,并据此生成对应的Excel列名。适用于需要进行列索引转换的场景。

2050

被折叠的 条评论
为什么被折叠?



