博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java读取Excel的内容
阅读量:6210 次
发布时间:2019-06-21

本文共 5862 字,大约阅读时间需要 19 分钟。

hot3.png

借助于apache的poi.jar完成Excel内容的读取

package com.util;import java.io.BufferedInputStream;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.IOException;import java.text.DecimalFormat;import java.text.SimpleDateFormat;import java.util.ArrayList;import java.util.Arrays;import java.util.Date;import java.util.List;import org.apache.poi.hssf.usermodel.HSSFCell;import org.apache.poi.hssf.usermodel.HSSFDateUtil;import org.apache.poi.hssf.usermodel.HSSFRow;import org.apache.poi.hssf.usermodel.HSSFSheet;import org.apache.poi.hssf.usermodel.HSSFWorkbook;import org.apache.poi.poifs.filesystem.POIFSFileSystem;public class ExcelOperate {        public static void main(String[] args) throws Exception {        File file = new File("E:\\ExcelDemo.xls");        String[][] result = getData(file, 1);        int rowLength = result.length;        for (int i = 0; i < rowLength; i++) {            for (int j = 0; j < result[i].length; j++) {                System.out.print(result[i][j] + "\t\t");            }            System.out.println();        }    }    /**     *      * 读取Excel的内容,第一维数组存储的是一行中格列的值,二维数组存储的是多少个行     *      * @param file 读取数据的源Excel     *      * @param ignoreRows 读取数据忽略的行数,比喻行头不需要读入 忽略的行数为1     *      * @return 读出的Excel中数据的内容     *      * @throws FileNotFoundException     *      * @throws IOException     */    public static String[][] getData(File file, int ignoreRows)    throws FileNotFoundException, IOException {        List
 result = new ArrayList
();        int rowSize = 0;        BufferedInputStream in = new BufferedInputStream(new FileInputStream(file));        // 打开HSSFWorkbook        POIFSFileSystem fs = new POIFSFileSystem(in);        HSSFWorkbook wb = new HSSFWorkbook(fs);        HSSFCell cell = null;        for (int sheetIndex = 0; sheetIndex < wb.getNumberOfSheets(); sheetIndex++) {            HSSFSheet st = wb.getSheetAt(sheetIndex);            // 第一行为标题,设置的数值为1则不取            for (int rowIndex = ignoreRows; rowIndex <= st.getLastRowNum(); rowIndex++) {                HSSFRow row = st.getRow(rowIndex);                if (row == null) {                    continue;                }                                int tempRowSize = row.getLastCellNum() + 1;                if (tempRowSize > rowSize) {                    rowSize = tempRowSize;                }                String[] values = new String[rowSize];                Arrays.fill(values, "");                boolean hasValue = false;                for (short columnIndex = 0; columnIndex <= row.getLastCellNum(); columnIndex++) {                    String value = "";                    cell = row.getCell(columnIndex);                    if (cell != null) {                        // 新的poi已经删除了setEncoding方法                        // cell.setEncoding(HSSFCell.ENCODING_UTF_16);                        switch (cell.getCellType()) {                            case HSSFCell.CELL_TYPE_STRING:                                value = cell.getStringCellValue();                                break;                            case HSSFCell.CELL_TYPE_NUMERIC:                                if (HSSFDateUtil.isCellDateFormatted(cell)) {                                    Date date = cell.getDateCellValue();                                    if (date != null) {                                        value = new SimpleDateFormat("yyyy-MM-dd").format(date);                                    } else {                                        value = "";                                    }                                } else {                                    value = new DecimalFormat("0").format(cell.getNumericCellValue());                                }                                break;                            case HSSFCell.CELL_TYPE_FORMULA:                                // 导入时如果为公式生成的数据则无值                                if (!cell.getStringCellValue().equals("")) {                                    value = cell.getStringCellValue();                                } else {                                    value = cell.getNumericCellValue() + "";                                }                                break;                            case HSSFCell.CELL_TYPE_BLANK:                                break;                            case HSSFCell.CELL_TYPE_ERROR:                                value = "";                                break;                            case HSSFCell.CELL_TYPE_BOOLEAN:                                value = (cell.getBooleanCellValue() == true ? "Y" : "N");                                break;                            default:                                value = "";                        }                    }                    if (columnIndex == 0 && value.trim().equals("")) {                        break;                    }                                        values[columnIndex] = rightTrim(value);                    hasValue = true;                }                if (hasValue) {                    result.add(values);                }            }        }        in.close();        String[][] returnArray = new String[result.size()][rowSize];        for (int i = 0; i < returnArray.length; i++) {            returnArray[i] = (String[]) result.get(i);        }        return returnArray;    }    /**     *      * 去掉字符串右边的空格     *      * @param str 要处理的字符串     *      * @return 处理后的字符串     */    public static String rightTrim(String str) {        if (str == null) {            return "";        }        int length = str.length();                for (int i = length - 1; i >= 0; i--) {            if (str.charAt(i) != 0x20) {                break;            }            length--;        }        return str.substring(0, length);    }}

转载于:https://my.oschina.net/discussjava/blog/220219

你可能感兴趣的文章
JavaWeb 项目与系统时间相差 8 个小时的问题
查看>>
mybatis关于mysql、oracle主键自增长
查看>>
5种做法,将使您的代码更好
查看>>
set names 命令在mysql中除了应付乱码还能做什么?
查看>>
CSS 定位之 z-index 问题分析
查看>>
HDOJ 2023 求平均成绩
查看>>
将usb 声卡集成到android4.0上
查看>>
Netty那点事(二)Netty中的buffer
查看>>
Magento通过命令行刷新索引(index)
查看>>
linux自学_shell理论基础
查看>>
Hive编译及部署
查看>>
从输入 URL 到页面加载完的过程中都发生了什么事情 —— 网络优化篇
查看>>
域控制器上安装杀毒软件
查看>>
关于v8的编译
查看>>
为Bash和VIM配置一个美观奢华的状态提示栏
查看>>
linux下tar.gz、tar、bz2、zip等解压缩、压缩命令小结
查看>>
Hive SemanticException:Expression not in GROUP BY
查看>>
oracle中delete drop truncate的用法和区别
查看>>
走出一条光明路--1远远大于0
查看>>
mysql 5.5安装
查看>>