Java用jxl对表格的数值进行比对

发布于:2023-01-04 ⋅ 阅读:(166) ⋅ 点赞:(0)

首先我们有两张表格表格
可以看到里面的数据有的是不一样的,接下来我们就要对照这两个图表里面的编号。
注意:jxl只能对照.xls的表格,如果你的表格是.xlsx的去表格中另存为该格式的表格就行了。

import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

public class findExecl {

    /**
     * 查找execl第一列数据是否相同
     *
     * @param filename
     * @return
     * @throws BiffException
     * @throws IOException
     */
    public static List<String> find(String filename) throws BiffException, IOException {
        // 1、构造excel文件输入流对象
        //这里我把表格放在D盘的目录下方便我们查表
        String sFilePath = "D:/" + filename + ".xls";
        InputStream is = new FileInputStream(sFilePath);
        // 2、声明工作簿对象
        Workbook rwb = Workbook.getWorkbook(is);
        // 3、获得工作簿的个数,对应于一个excel中的工作表个数
        rwb.getNumberOfSheets();
        // 只能查看第一页数据下标0
        Sheet oFirstSheet = rwb.getSheet(0);
        int rows = oFirstSheet.getRows();
        // 获取工作表中的总行数,因为我们只需要查看第一列,就不需要在循环所有列
        //int columns = oFirstSheet.getColumns();
        // 获取工作表中的总列数
        List<String> list = new ArrayList<String>();
        for (int i = 0; i < rows; i++) {
            for (int j = 0; j < 1; j++) {
                // 需要注意的是这里的getCell方法的参数,第一个是指定第几列,第二个参数才是指定第几行
                Cell oCell = oFirstSheet.getCell(0, i);
                // 将账号里面的字母都转成小写
                String contents = oCell.getContents();
                list.add(contents.toLowerCase());
            }
        }
        return list;

    }

    public static void main(String[] args) throws BiffException, IOException {
        //这里输入需要对比的两表格的名称
        List<String> man1 = findExecl.find("人员名单1");
        List<String> man2 = findExecl.find("人员名单2");
        int o = 0;
        System.out.print("相同的账号有");
        for (int i = 0; i < man1.size(); i++) {
            String s = man1.get(i);
            for (int j = 0; j < man2.size(); j++) {
                String s1 = man2.get(j);
                if (s.equals(s1)) {
                    o++;
                    System.out.print(s1 + "\t");
                }
            }
        }
        System.out.println("\n表一的账号有" + man1.size() + "个");
        System.out.println("表二的帐号有" + man2.size() + "个");
        System.out.println("两个表之间账号相同的有" + o + "个");

    }

}

运行后就可以了

总结:
优点:能快速对比两个表之间的数据,在平时统计中可以用得到。
缺点:只能对比第一页的第一行数据。如果表格有很多页,还得把表格的所有数据合并到一起进行对比。

本文含有隐藏内容,请 开通VIP 后查看

网站公告

今日签到

点亮在社区的每一天
去签到