java实现对excel文件的处理合并单元格的操作

 更新时间:2021年07月24日 09:18:34   作者:奈若何er  
这篇文章主要介绍了java实现对excel文件的处理合并单元格的操作,开头给大家介绍了依赖引入代码,表格操作的核心代码,代码超级简单,需要的朋友可以参考下

一、依赖引入

<dependency>
	<groupId>net.sourceforge.jexcelapi</groupId>
	<artifactId>jxl</artifactId>
	<version>2.6.12</version>
</dependency>

二、表格操作

1、读取xls文件

测试文件为:

在这里插入图片描述

代码:

public void test() throws IOException, BiffException {
        // 1、获取文件,创建workbook
        File file = new File("D:/test/自动化监测数据上传模板20210525.xls");
        Workbook workbook = Workbook.getWorkbook(file);
        // 2.获取第一个工作表
        Sheet sheet = workbook.getSheet(0);
        // 3.获取表中数据
        Range[] rangecell = sheet.getMergedCells();

        System.out.println("行:" + sheet.getRows());
        System.out.println("列:" + sheet.getColumns());
        for (int i = 0; i < sheet.getRows(); i++) {
            for (int j = 0; j < sheet.getColumns(); j++) {
                Cell cell = sheet.getCell(j, i);
                String contents = cell.getContents();
                System.out.print(contents + " ");
            }
            System.out.println();
        }
        workbook.close();
    }

输出结果(注意合并单元格处,需要特殊处理):

在这里插入图片描述

改造代码如下:

public void test() throws IOException, BiffException {
        // 1、获取文件,创建workbook
        File file = new File("D:/test/自动化监测数据上传模板20210525.xls");
        Workbook workbook = Workbook.getWorkbook(file);
        // 2.获取第一个工作表
        Sheet sheet = workbook.getSheet(0);
        // 3.获取表中数据
        // 返回合并单元格数据
        Range[] rangecell = sheet.getMergedCells();
        System.out.println("行:" + sheet.getRows());
        System.out.println("列:" + sheet.getColumns());
        for (int i = 0; i < sheet.getRows(); i++) {
            for (int j = 0; j < sheet.getColumns(); j++) {
                Cell cell = sheet.getCell(j, i);
                String contents = cell.getContents();
                // 判断当前单元格,是否为合并单元格
                for (Range r : rangecell) {
                    if (i > r.getTopLeft().getRow() && 
                    i <= r.getBottomRight().getRow() && 
                    j >= r.getTopLeft().getColumn() && 
                    j <= r.getBottomRight().getColumn()) {
                        contents = sheet.getCell(r.getTopLeft().getColumn(), r.getTopLeft().getRow()).getContents();
                    }
                }
                System.out.print(contents + " ");
            }
            System.out.println();
        }
        workbook.close();
    }

结果:

在这里插入图片描述

到此这篇关于java实现对excel文件的处理合并单元格的文章就介绍到这了,更多相关java excel文件合并单元格内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot使用Flyway进行数据库管理的操作方法

    SpringBoot使用Flyway进行数据库管理的操作方法

    Flyway是一个开源的数据库版本管理工具,并且极力主张“约定大于配置”,简单、专注、强大。接下来通过本文给大家介绍SpringBoot使用Flyway进行数据库管理的方法,感兴趣的朋友一起看看吧
    2021-09-09
  • Java中的异常处理之try-catch使用详解

    Java中的异常处理之try-catch使用详解

    这篇文章主要介绍了Java中的异常处理之try-catch使用的相关资料,包括异常的概念、try-catch语句的基本结构、使用示例、多个catch块的使用、try-catch-finally的执行顺序、try-with-resources语句以及总结,需要的朋友可以参考下
    2024-12-12
  • java设计模式之委派模式原理分析

    java设计模式之委派模式原理分析

    这篇文章主要介绍了java设计模式之委派模式原理分析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • Spring AOP + 注解实现统一注解功能

    Spring AOP + 注解实现统一注解功能

    本文我们通过Spring AOP和Java的自定义注解来实现日志的插入功能,非常不错,具有一定的参考借鉴价值,需要的朋友一起看看吧
    2018-05-05
  • Spring Boot实现登录验证码功能的案例详解

    Spring Boot实现登录验证码功能的案例详解

    验证码的作用可以有效防止其他人对某一个特定的注册用户用特定的程序暴力破解方式进行不断的登录尝试,接下来通过本文给大家介绍Spring Boot实现登录验证码功能,需要的朋友可以参考下
    2022-08-08
  • 举例解析Java的图像缓冲技术的使用

    举例解析Java的图像缓冲技术的使用

    这篇文章主要介绍了Java的图像缓冲技术的使用,使用到了Java的awt.image包,需要的朋友可以参考下
    2015-10-10
  • Java开发中解决Js的跨域问题过程解析

    Java开发中解决Js的跨域问题过程解析

    这篇文章主要介绍了Java开发中解决Js的跨域问题过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • SpringBoot响应Json数据乱码通过配置的解决

    SpringBoot响应Json数据乱码通过配置的解决

    这篇文章主要介绍了SpringBoot响应Json数据乱码通过配置的解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

    SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

    本文介绍了如何在单体SpringBoot项目中通过手动实现过滤器或拦截器来注入traceId,以追踪整个请求的日志链路,通过使用MDC和配置日志格式,可以在日志中包含traceId,便于问题排查,同时,还在返回的包装类中注入traceId,以便用户反馈问题,感兴趣的朋友一起看看吧
    2025-02-02
  • 详解Java的Hibernate框架中的缓存与二级缓存

    详解Java的Hibernate框架中的缓存与二级缓存

    这篇文章主要介绍了Java的Hibernate框架中的缓存与二级缓存,Hibernate是Java的SSH三大web开发框架之一,需要的朋友可以参考下
    2015-12-12

最新评论