Java 读取excel文件

这篇具有很好参考价值的文章主要介绍了Java 读取excel文件。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

导入:

先导入依赖:

<!-- 文件上传 -->
<dependency>
    <groupId>org.apache.httpcomponents</groupId>
    <artifactId>httpmime</artifactId>
	<version>4.5.7</version>
</dependency>
<!-- JSON -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.41</version>
</dependency>
<!-- POI -->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>3.16</version>
</dependency>

1、获取想要上传excel文件的路径

2、获得路径后,通过路径定位生成数据流,使用FileInputStream方法读取路径对应文件的原始字节流。

//根据路径生成 FileInputStream字节流
FileInputStream inputStream = new FileInputStream(new File(fileName));

3、使用ExcelUtils工具类读取 字节流 + 路径。

//通过ExcelUtils工具将Excel数据存入到list中,工具代码下面细讲,这一步读取Excel已经完成了,如果不想进行插入数据库操作,可以直接拿着list用啦。
List<List<Object>> list = ExcelUtils.getListByExcel(inputStream,fileName);

4、ExcelUtils工具类对数据进行处理,因为表格有行和列,所以处理完数据使用二维集合List<List>对数据进行存储。

ExcelUtils类讲解:

public class ExcelUtils {
    private final static String excel2003L =".xls";    //2003- 版本的excel
    private final static String excel2007U =".xlsx";  //2007版本
 
    /**
     * @Description:获取IO流中的数据,组装成List<List<Object>>对象
     * @param in,fileName
     * @return
     * @throws
     */
    public static List<List<Object>> getListByExcel(InputStream in, String fileName) throws Exception{
        List<List<Object>> list = null;
        //创建Excel工作薄
        Workbook work = getWorkbook(in,fileName);
        if(null == work){
            throw new Exception("创建Excel工作薄为空!");
        }
        Sheet sheet = null;  //页数
        Row row = null;  //行数
        Cell cell = null;  //列数
 
        list = new ArrayList<List<Object>>();
        //遍历Excel中所有的sheet
        for (int i = 0; i < work.getNumberOfSheets(); i++) {
            sheet = work.getSheetAt(i);
            if(sheet==null){continue;}
 
            //遍历当前sheet中的所有行
            for (int j = sheet.getFirstRowNum(); j <= sheet.getLastRowNum(); j++) {
                row = sheet.getRow(j);
                if(row==null){continue;}
 
                //遍历所有的列
                List<Object> li = new ArrayList<Object>();
                for (int y = row.getFirstCellNum(); y < row.getLastCellNum(); y++) {
                    cell = row.getCell(y);
                    li.add(getValue(cell));
                }
                list.add(li);
            }
        }
 
        return list;
 
    }
 
    /**
     * @Description:根据文件后缀,自适应上传文件的版本
     * @param inStr,fileName
     * @return
     * @throws Exception
     */
    public static  Workbook getWorkbook(InputStream inStr,String fileName) throws Exception{
        Workbook wb = null;
        String fileType = fileName.substring(fileName.lastIndexOf("."));
        if(excel2003L.equals(fileType)){
            wb = new HSSFWorkbook(inStr);  //2003-
        }else if(excel2007U.equals(fileType)){
            wb = new XSSFWorkbook(inStr);  //2007+
        }else{
            throw new Exception("解析的文件格式有误!");
        }
        return wb;
    }
 
    /**
     * @Description:对表格中数值进行格式化
     * @param cell
     * @return
     */
    //解决excel类型问题,获得数值
    public static String getValue(Cell cell) {
        String value = "";
        if(null==cell){
            return value;
        }
        switch (cell.getCellType()) {
            //数值型
            case NUMERIC:
                if (DateUtil.isCellDateFormatted(cell)) {
                    //如果是date类型则 ,获取该cell的date值
                    Date date = DateUtil.getJavaDate(cell.getNumericCellValue());
                    SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
                    value = format.format(date);;
                }else {// 纯数字
                    BigDecimal big=new BigDecimal(cell.getNumericCellValue());
                    value = big.toString();
                    //解决1234.0  去掉后面的.0
                    if(null!=value&&!"".equals(value.trim())){
                        String[] item = value.split("[.]");
                        if(1<item.length&&"0".equals(item[1])){
                            value=item[0];
                        }
                    }
                }
                break;
            //字符串类型
            case STRING:
                value = cell.getStringCellValue();
                break;
            // 公式类型
            case FORMULA:
                //读公式计算值
                value = String.valueOf(cell.getNumericCellValue());
                if (value.equals("NaN")) {// 如果获取的数据值为非法值,则转换为获取字符串
                    value = cell.getStringCellValue();
                }
                break;
            // 布尔类型
            case BOOLEAN:
                value = " "+ cell.getBooleanCellValue();
                break;
            default:
                value = cell.getStringCellValue();
        }
        if("null".endsWith(value.trim())){
            value="";
        }
        return value;
    }
}

5、已经获取到了Excel表格中所有的数据,包含所有的行和列,都在List<List>中,这一步所有的数据获取完了

6、有了数据,要将数据存储到数据库。

7、需要创建数据库字段的实体类,使用@Excel注解将表格和数据库字段名一一对应

@Data
@TableName("t_student")//数据库名字
public class Student{
 
        @TableId(type = IdType.AUTO)
        @Excel(name = "序号", cellType = Excel.ColumnType.NUMERIC)
        private Long id;
 
        @Excel(name = "学生ID")
        private Long id;
 
        @Excel(name = "名称")
        private String name;
 
        @Excel(name = "性别")
        private String sex;
 
        @Excel(name = "年龄")
        private String age;
 
      
        
}

8、通过双重 for循环遍历List<List>,内层List为列,外层List为行,如下图将第一行数据单独拿出来,作为判断字段,如果实体类等@Excel注解属性和Excel表格第一行名字相同,对实体类进行set赋值

//定义Excel第一行的属性
List<Object> firstRows = null;
//获取第一行属性 放入firstRows中。
if(list != null && list.size() > 0){
	firstRows = list.get(0);
}
//遍历除第一行以外的Excel表格中的值
for (int i = 1; i < list.size(); i++) {
    //rows是某一行,i = 1 为第二行,	i = 2 为第三行
    List<Object> rows = list.get(i);
    //数据库数据的实体类
    Student student =new student();
    //遍历这一行所有的值
    for (int j = 0; j < rows.size(); j++){
    //某一行的某一列 j为列的坐标    
    String cellVal = (String) rows.get(j);
     //对实体类进行赋值,使用setFieldValueByFieldName方法,下面详细讲代码
    TestExcel.setFieldValueByFieldName(questionBank, firstRows.get(j).toString().trim(), 	 cellVal);
                    }
 
                }
     // 使用spring插入到数据库
     questionBankService.save(questionBank);
            }

9、从第二行开始,每遍历完一行,将获得一个实体类对象,因为是结合数据库写的实体类,通过springboot可以直接插入数据库。

public class TestExcel {
 
    /**
     * 用反射方法,获取列名,比较,为属性赋值
     * @param object
     * @param fieldName
     * @param val
     */
    public static void setFieldValueByFieldName(Object object, String fieldName, Object val) {
        try {
            //通过反射获取所有实体类所有定义的方法,object为数据库实体类
            Field[] fields = object.getClass().getDeclaredFields();
            //遍历fields
            for (int i = 0; i < fields.length; i++) {
                Field field = fields[i];
                //读取注释,如@Excel(name = "科目")
                Excel annotation = field.getAnnotation(Excel.class);
                //因为private类型,所有要设置允许
                field.setAccessible(true);
                //annotation.name() 注解里的属性,如果annotation没写注解,读取原始名字如subject
                if(annotation == null){
                    if(fieldName.equals(field.getName())){
                        if(field.getType() == Integer.class){
                            field.set(object, Integer.valueOf(val.toString()));
                        }else if(field.getType() == Long.class){
                            field.set(object, Long.valueOf(val.toString()));
                        }else {
                            field.set(object, val);
                        }
                        return;
                    }  
                }else {//设置了注解,并且表格里的Excel字段值和注解的name值相同,则为相应字段赋值
                    if(fieldName.equals(annotation.name())){
                        //进行类型判断,因为实体类中变量类型不同。
                        if(field.getType() == Integer.class){
                            field.set(object, Integer.valueOf(val.toString()));
                        }else if(field.getType() == Long.class){
                            field.set(object, Long.valueOf(val.toString()));
                        }else {
                            field.set(object, val);
                        }
                        return;
                    }
                }
 
            }
        }catch (Exception e){
            e.printStackTrace();
        }
    }
 
}

六、通用读取excel工具类 文章来源地址https://www.toymoban.com/news/detail-758568.html

package com.ssm;
 
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
import org.apache.poi.hssf.usermodel.HSSFCell;
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.ss.usermodel.CellType;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
 
public class ReadExcel {
	
	public List<Map<String,String>> readExcel(String filepath, String filename, int startrow, int startcol, int sheetnum) {
		List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
		String suffix = filename.substring(filename.lastIndexOf(".") + 1);
		if ("xls".equals(suffix)) {
			varList = readExcel2003(filepath, filename, startrow, startcol, sheetnum);
		} else if ("xlsx".equals(suffix)) {
			varList = readExcel2007(filepath, filename, startrow, startcol, sheetnum);
		} else {
			System.out.println("Only excel files with XLS or XLSX suffixes are allowed to be read!");
			return null;
		}
		return varList;
	}
    
 
   
    /**
	 * 读取2003Excel
	 * 
	 * @param filepath 文件路径
	 * @param filename 文件名,包括扩展名
	 * @param startrow 开始行号,索引从0开始
	 * @param startcol 开始列号,索引从0开始
	 * @param sheetnum 工作簿,索引从0开始
	 * @return
	 */
	public static List<Map<String,String>> readExcel2003(String filepath, String filename, int startrow, int startcol, int sheetnum) {
		List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
		try {
			File target = new File(filepath, filename);
			FileInputStream fis = new FileInputStream(target);
			HSSFWorkbook wb = new HSSFWorkbook(fis);
			fis.close();
			// sheet 从0开始
			HSSFSheet sheet = wb.getSheetAt(sheetnum);
			// 取得最后一行的行号
			int rowNum = sheet.getLastRowNum() + 1;
 
			HSSFRow rowTitle = sheet.getRow(0);
			// 标题行的最后一个单元格位置
			int cellTitleNum = rowTitle.getLastCellNum();
			String[] title = new String[cellTitleNum];
			for (int i = startcol; i < cellTitleNum; i++) {
				HSSFCell cell = rowTitle.getCell(Short.parseShort(i + ""));
				if (cell != null) {
					cell.setCellType(CellType.STRING);
					title[i] = cell.getStringCellValue();
				} else {
					title[i] = "";
				}
			}
 
			// 行循环开始
			for (int i = startrow + 1; i < rowNum; i++) {
				Map<String, String> varpd = new HashMap<String, String>();
				// 行
				HSSFRow row = sheet.getRow(i);
				// 列循环开始
				for (int j = startcol; j < cellTitleNum; j++) {
 
					HSSFCell cell = row.getCell(Short.parseShort(j + ""));
					String cellValue = "";
					if (cell != null) {
						// 把类型先设置为字符串类型
						cell.setCellType(CellType.STRING);
						cellValue = cell.getStringCellValue();
					}
					varpd.put(title[j], cellValue);
				}
				varList.add(varpd);
			}
			wb.close();
		} catch (Exception e) {
			System.out.println(e);
		}
		return varList;
	}
	
	/**
	 * 读取2007Excel
	 * 
	 * @param filepath 文件路径
	 * @param filename 文件名,包括扩展名
	 * @param startrow 开始行号,索引从0开始
	 * @param startcol 开始列号,索引从0开始
	 * @param sheetnum 工作簿,索引从0开始
	 * @return
	 */
	public List<Map<String,String>> readExcel2007(String filepath, String filename, int startrow, int startcol, int sheetnum) {
		List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
		try {
			File target = new File(filepath, filename);
			InputStream ins = new FileInputStream(target);
			XSSFWorkbook wb = new XSSFWorkbook(ins);
			ins.close();
			// 得到Excel工作表对象
			XSSFSheet sheet = wb.getSheetAt(sheetnum);
			// 取得最后一行的行号
			int rowNum = sheet.getLastRowNum() + 1;
 
			XSSFRow rowTitle = sheet.getRow(0);
			int cellTitleNum = rowTitle.getLastCellNum();
			String[] title = new String[cellTitleNum];
			for (int i = startcol; i < cellTitleNum; i++) {
				XSSFCell cell = rowTitle.getCell(Short.parseShort(i + ""));
				if (cell != null) {
					// 把类型先设置为字符串类型
					cell.setCellType(CellType.STRING);
					title[i] = cell.getStringCellValue();
				} else {
					title[i] = "";
				}
			}
 
			// 行循环开始
			for (int i = startrow + 1; i < rowNum; i++) {
				Map<String, String> varpd = new HashMap<String, String>();
				// 得到Excel工作表的行
				XSSFRow row = sheet.getRow(i);
				// 列循环开始
				for (int j = startcol; j < cellTitleNum; j++) {
					// 得到Excel工作表指定行的单元格
					XSSFCell cell = row.getCell(j);
					String cellValue = "";
					if (cell != null) {
						// 把类型先设置为字符串类型
						cell.setCellType(CellType.STRING);
						cellValue = cell.getStringCellValue();
					}
					varpd.put(title[j], cellValue);
				}
				varList.add(varpd);
			}
			wb.close();
		} catch (Exception e) {
			System.out.println(e);
		}
		return varList;
	}
    
    
    
    
    
    
    
    
    
}

到了这里,关于Java 读取excel文件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • C# 读取Execl文件3种方法

    1.1C#提供的数据连接有哪些         对于不同的.net数据提供者,ADO.NET采用不同的Connection对象连接数据库。这些Connection对我们屏蔽了具体的实现细节,并提供了一种统一的实现方法。 Connection类有四种:SqlConnection,OleDbConnection,OdbcConnection和OracleConnection。 Sqlconnetcion类的对

    2024年02月07日
    浏览(40)
  • Python 创建或读取 Excel 文件

    Excel是一种常用的电子表格软件,广泛应用于金融、商业和教育等领域。它提供了强大的数据处理和分析功能,可进行各种计算和公式运算,并能创建各种类型的图表和可视化数据。Excel的灵活性使其成为处理和管理数据的重要工具。本文将介绍如何使用  Spire.XLS for Python  通

    2024年02月10日
    浏览(40)
  • 【python】Excel文件的读取操作

     输出结果: 需要注意的是,我用的xlrd版本是 1.2.0,不是最新版本的,最新版本可能不支持读取xlsx,所以才会出现读取xlsx文件报错的情况,自行降版本试下  输出结果:  使用pandas模块读取Excel文件时,可能会报:ImportError: Missing optional dependency \\\'openpyxl\\\'. Use pip or conda to ins

    2024年02月13日
    浏览(43)
  • Java 读取 Excel 表格—— Easy Excel 基本使用

    确定表头:建立对象,和表头形成映射关系。 不确定表头:每一行数据映射为 MapString, Object ,比如用户自己上传的表格。 监听器:先创建监听器、在读取文件时绑定监听器。单独抽离处理逻辑,代码清晰易于维护;一条一条处理,适用于数据量大的场景。 同步读:无需创建

    2024年01月21日
    浏览(46)
  • java读取excel中的数据

    首先导入相关的依赖: 测试代码: 数据打印到控制台的效果:

    2024年02月06日
    浏览(41)
  • java读取Excel导入去除空行

    问题: 在Java读取Excel导入操作时, sheet.getLastRowNum()会统计带有格式的空白行,导致获取的最大行数不准确,数据导入失败。 解决: 在操作过程中删除存在样式的空白行 可通过将空白行(内容为空,但是存在样式)进行sheet.removeRow删除后 再调用getLastRowNum()进行行数统计,getAcc

    2024年02月15日
    浏览(43)
  • Python读取写入数据到Excel文件

    【Linux干货教程】Ubuntu Linux 换源详细教程 大家好,我是洲洲,欢迎关注,一个爱听周杰伦的程序员。关注公众号【程序员洲洲】即可获得10G学习资料、面试笔记、大厂独家学习体系路线等…还可以加入技术交流群欢迎大家在CSDN后台私信我! Hello,各位看官老爷们好,洲洲已

    2024年02月12日
    浏览(82)
  • 如何使用 Java 灵活读取 Excel 内容?

    在日常工作和学习中,我们经常需要从 Excel 文件中读取数据。对于少量数据,手动复制和粘贴可能是可行的,但是对于大量的数据,这种方法会变得非常低效。在这种情况下,使用 Java 程序自动读取 Excel 文件中的数据将是更好的选择。 本教程将介绍如何使用 Java 程序读取

    2024年02月07日
    浏览(38)
  • JAVA 读取jar包中excel模板

    1、在resources路径下,新建report文件夹,放入excel模板 2、配置文件中的目录,分隔符使用 / 3、使用getResourceAsStream()读取

    2024年02月11日
    浏览(38)
  • 【python读取excel文件保存为矩阵形式】

    python实现对excel表格不同文件形式的读取 我最近在用 pycharm 读取excel数据出现几个莫名其妙的问题, 我解决问题之后,觉得还是把这些坑都写清楚,方便 python 的初学者。  用xlrd库读取.xls文件  用库openpyxl读取.xlsx文件  \\\'.xls文件的读取\\\' \\\'.xlsx文件的读取\\\' 

    2024年02月13日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包