JavaScript获取Excel表格的列序号和列名

目录
  • 1、常量和进制转换方法
  • 2、获取列名
  • 3、获取列序号
  • 4、使用

前言:

在处理Excel文件时,通常要获取xx列的数据,这就要求先找到列序号(从0开始)。

下面将介绍从列名获取列序号从列序号或获取列名的方法,当中将涉及到10进制和k进制的互转。

1、常量和进制转换方法

//列名元素集
const COL_ABC = ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z" ];
/**
 * 十进制的数化为k进制的数【返回数组的index=0位置是最高位】(取k取余法)
 * @num 10进制数
 * @k k
 * @returns k进制数序列
 */
function ckqy(num,k) {
    let y = [];
    while (num > 0) {
        let s = Math.floor(num / k);
        let _y = num % k;
        //console.log(num + " ÷ " + k + " = " + s + " ··· " + _y);
        if (s == 0)
        {
            y.push(num);
            num = 0;
        }
        else
        {
            y.push(_y);
            num = s;
        }
    }
    return y.reverse();
}

/**
 * k进制的数化为十进制的数(乘幂相加法)
 * @kArray k进制数序列
 * @k k
 * @returns 十进制的数
 */
function kTo10(kArray,k){
    let v10=0;
    let kArrayLen=kArray.length;
    for(let ind=0; ind<kArrayLen; ind++){
        v10 += kArray[ind] * Math.pow(k,kArrayLen - 1 - ind);
    }
    return v10;
}

2、获取列名

现在计算出列序号的26进制数序列,然后在列名元素集中找到相应的元素,进行拼接。

/**
 * 获取列名
 * @colIndex 列序号(从0开始)
 * @returns 列名
 */
function getColName(colIndex)
{
    if(colIndex < 0){
        return '';
    }
    let colNames =[];
    // 等于0 和 大于25 的 colIndex
    let isAdd1 = colIndex > 25 || colIndex < 1 ;
    //10进制转26进制
    let kArray = ckqy(colIndex + (isAdd1 ? 1: 0), 26);
    for (let i = 0; i < kArray.length; i++)
    {
        colNames.push(COL_ABC[ kArray[i]- (isAdd1 ? 1: 0) ] || '');
    }
    return colNames.join('');
}

3、获取列序号

/**
 * 获取列名对应ABC数据序号
 * @colIndex 列序号(从0开始)
 * @returns
 */
function getABCIndex(colName){
    let kArray = [];
    let colNames=colName.split('');
    for(let ind=0;ind <colNames.length;ind++){
        let k = COL_ABC.indexOf(colNames[ind]);
        if(k > -1){
            kArray.push(k);
        }
    }
    return kArray;
}
/**
 * 获取列序号
 * @colIndex 列名
 * @returns 列序号(从0开始)
 */
function getColIndex(colName)
{
    if(!colName){
        return -1;
    }
    // colName 转 COL_ABC 序号
    let kArray = getABCIndex(colName);
    let kArrayLen=kArray.length;
    if(kArrayLen==0){
        return -1;
    }
    let colIndex =0;
    for(let ind=0;ind <kArrayLen;ind++){
        let k = kArray[ind] + (  (kArrayLen-1)  == ind ? 0:1);
        let p =  kArrayLen-1-ind;
        //console.log(k+' * Math.pow(26,'+p+');');
        colIndex += k * Math.pow(26,p);
    }
    return colIndex;
}

4、使用

let _colName = 'ABC';
let colIndex=getColIndex(_colName);
console.log(colIndex);
let colName = getColName(colIndex);
console.log(colName);
console.log(_colName  == colName  );

到此这篇关于JavaScript获取Excel表格的列序号和列名的文章就介绍到这了,更多相关JS获取Excel表格 内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Nodejs获取网络数据并生成Excel表格

    Nodejs的模版中有很多关于Excel表格的,这里我简单介绍一下我使用过的一个模块的使用. 首先,先安装Excel的模块: npm install node-xlsx 然后,在代码中引入模块: var xlsx = require('node-xlsx'); 最后,获取数据并写入Excel: var fs = require('fs'); var xlsx = require('node-xlsx'); var ajax = require('./ajax.js'); start(); fun

  • JS 巧妙获取剪贴板数据 Excel数据的粘贴

    另外的方法就是用flash了,它可以避开浏览器的安全限制,但是system类中只有set的方法,另外的clipboard类中倒是能访问到,但是似乎需要flash10的版本支持. 网上找了一圈,没啥发现.终于想到去看看google sheet是怎么干的. 发现google sheet实现了excel的纯文本的多数据格粘贴,没有安全限制的需要,没有使用flash.可能很多人都知道这种方法了,反正我一开始很惊讶的,但是无奈,google的js文件是处理过的,看起来太累了.然后又去找ZOHO sheet

  • JavaScript获取Excel表格的列序号和列名

    目录 1.常量和进制转换方法 2.获取列名 3.获取列序号 4.使用 前言: 在处理Excel文件时,通常要获取xx列的数据,这就要求先找到列序号(从0开始). 下面将介绍从列名获取列序号和从列序号或获取列名的方法,当中将涉及到10进制和k进制的互转. 1.常量和进制转换方法 //列名元素集 const COL_ABC = ["A", "B", "C", "D", "E", "F", &

  • jQuery实现获取table表格第一列值的方法

    本文实例讲述了jQuery实现获取table表格第一列值的方法.分享给大家供大家参考,具体如下: 先来看看运行效果截图: 完整代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" > <html xmlns="http://www.w3.or

  • JavaScript实现Excel表格效果

    本文实例为大家分享了JavaScript实现Excel表格效果的具体代码,供大家参考,具体内容如下 一.主要实现: 1.List item 2.输入内容时显示边框 3.鼠标点击文本框以外部分失去焦点 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <htm

  • JavaScript 自动在表格前面增加序号

    JavaScript 自动为表格增加序号 .index_tab{width:100%;border-collapse:collapse;border:1px solid #005892;margin:8px 0;} .index_tab td{line-height:35px;border:1px solid #005892;padding-left:4px;} tr.tr_top td{line-height:32px;border:none;background-color:#005892;

  • Java实现操作excel表格

    最近老师布置了个任务,用Java对excel后缀名为xlsx的文件进行简单的增,删,改,查操作:虽说是个简单的程序,可作为刚接触的我来说还是有些磕磕碰碰.不过好在还是完成了,进行一个简单的总结. 首先导入了一个poi.jar 网上有很多这个资源可以下载 XSSFSheet sheet=null; XSSFWorkbook book=null; 一:查  (查找本地指定位置的excel表格,在控制台输出) public void print_excel(){ //获取excel表格的行数 int

  • 零基础使用Python读写处理Excel表格的方法

    引 由于需要解决大批量Excel处理的事情,与其手工操作还不如写个简单的代码来处理,大致选了一下感觉还是Python最容易操作. 安装库Python环境 首先当然是配环境,不过选Python的一个重要原因就是Mac内是自带Python环境的,不需要额外的配置环境,省下了一笔工作,如果你用的是Windows系统,那就还需要配置一下Python的环境了,我Mac的Python版本是2.7. 第三方库 Python自己是不支持直接操作Excel的,但是Python强大之处就在于有大量好用的第三方库,这

  • android读取assets中Excel表格并显示

    本文实例为大家分享了android读取assets中Excel的具体代码,供大家参考,具体内容如下 1.在assets下放的excel表格,命名为excel.xls 2.添加读取excel需要的jar包"jxl.jar",assets是建在main级别目录下,建错地方找不到文件 3.读取excel中的文件 /*获取excel表格中的数据不能在主线程中调用 xlsName 为表格的名称 index 表示第几张表格 */ public ArrayList<ExcelBean>

  • Django上传excel表格并将数据写入数据库的详细步骤

    目录 前言: 一.上传文件: 二.解析 excel 导入数据库 前言: 最近公司领导要统计技术部门在各个业务条线花费的工时百分比,而 jira 当前的 Tempo 插件只能统计个人工时.于是就写了个报表工具,将 jira 中导出的个人工时excel表格 导入数据库,在后端处理各个业务工时占比.后来研究了 jira 的 API 文档 ,放弃了之前的思路,直接调用 jira API 处理数据 ,这个先不谈.这篇博客主要介绍 Django 上传文件,然后解析 excel 导入数据库. 一.上传文件:

  • Java实现批量导入excel表格数据到数据库中的方法

    本文实例讲述了Java实现批量导入excel表格数据到数据库中的方法.分享给大家供大家参考,具体如下: 1.创建导入抽象类 package com.gcloud.common.excel; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.PrintStream; import java.sql.SQLException;

  • JAVA使用POI获取Excel的列数与行数

    前言 报表输出是Java应用开发中经常涉及的内容,而一般的报表往往缺乏通用性,不方便用户进行个性化编辑.Java程序由于其跨平台特性,不能直接操纵Excel.因此,本文探讨一下POI视线Java程序进行Excel中列数和行数的读取. 方法如下 //获取指定行,索引从0开始 hssfRow=hssfSheet.getRow(1); //获取指定列,索引从0开始 hssfCell=hssfRow.getCell((short)6); //获取总行数 //int rowNum=hssfSheet.ge

随机推荐