Java读取Excel并解析文本(并格式化输出)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介:

说明

最近在做一个比较小型的Java网站,需要批量导入注册用户.用户的信息写在一张excel表格里面.

所以就需要读取excel.所以就记录下遇到的问题,以及以后查看.

594100049d50b299387d

相关技术

使用的POI解析Excel需要使用的jar包

59430001e41b00b117a6

注(使用的maven.我就添加了右边的两个依赖就可以了)

分析

解析Excel首先就要解析Excel的结构.然后用面向对象的思想分析一下

593f0004405db6aeb35b

这是一个excel文件.下面我们就来分析一下如果让你写这个poi框架,那么你会怎么设计.

1. 首先要有一个对象表示这整个Excel文件.

2. 可是这个excel文件中有好多页.Sheet1, Sheet2等等,所以我们还需要一个对象表示页.

3. 在页中,有行,所以还需要一个对象表示行.

4. 在行中,最后细分到格cell.

5. 格cell中数据还有好多类型.有字符串,数字,时间等等.

如果你想学习Java可以来这个Q群,首先是220,中间是142,最后是906,里面可以学习和交流,也有资料可以下载。

POI中的对象与excel对象的对应

excel文件就有多种类型了.后缀有 xls 与 xlsx

594100049d4cd3979fc1

所以对于不同类型的文件,就需要使用不同的poi中的对象了.

1. 如果你要解析的是xls文件

59430001e4192efbd38c

从代码不难发现,这里的处理逻辑是

1>. 先用inputstream获取excel文件的io流

2>. 然后创建一个内存中的excel文件HSSFWorkbook类型对象.这个对象表示了整个excel文件.

3>. 对这个excel文件的每页做循环处理

4>. 对每页中的每行做循环处理.

5>. 对每行中的每个单元格做做处理,获取这个单元格的值.

6>. 把这行的结果添加到一个List数组中.

7>. 把每行的结果添加到最后的总结果中.

8>. 解析完以后就获取了一个List< List < String > > 类型的对象了.

2. 如果你要处理xlsx类型的文件则

593e0002572783c33090

和上面一样,我就不说了.

存在的问题

其实有时候我们希望得到的数据就是excel中的数据,可是最后发现结果不理想

如果你的excel中的数据是数字,你会发现java中对应的变成了科学计数法的.

所以在获取值的时候就要做一些特殊处理.

这样就能保证获取的值是我想要的值.

网上的做法是对于数值类型的数据格式化,获取自己想要的结果.

其实也没有那么麻烦.我在做的时候突然想到了一种处理解决方案.供参考

我们看一下poi中对于的toString()方法

593f0004405f9d58eeb7

593f0004405eadf161f7

593f0004405c0e4a649b

该方法是poi的方法,从源码中我们可以发现,该处理流程是

1. 获取单元格的类型

2. 根据类型格式化数据并输出.这不一下子就造成了很多不是我们想要的.

所以我们就要改造一下这个方法例如这样

我的做法是这样的

1. 对于不熟悉的类型,或者为空则返回”” 控制串.

2.如果是数字,则修改单元格类型为String,然后返回String.这样就保证数字不被格式化了.

3. 虽然不知道这么做有什么后果,可是成功了

相关文章
|
15天前
|
缓存 Java 应用服务中间件
Java虚拟线程探究与性能解析
本文主要介绍了阿里云在Java-虚拟-线程任务中的新进展和技术细节。
|
12天前
|
设计模式 安全 Java
Java 编程中的设计模式:单例模式的深度解析
【9月更文挑战第22天】在Java的世界里,单例模式就像是一位老练的舞者,轻盈地穿梭在对象创建的舞台上。它确保了一个类仅有一个实例,并提供全局访问点。这不仅仅是代码优雅的体现,更是资源管理的高手。我们将一起探索单例模式的奥秘,从基础实现到高级应用,再到它与现代Java版本的舞蹈,让我们揭开单例模式的面纱,一探究竟。
23 11
|
6天前
|
存储 算法 Java
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
本文介绍了 JVM 的内存区域划分、类加载过程及垃圾回收机制。内存区域包括程序计数器、堆、栈和元数据区,每个区域存储不同类型的数据。类加载过程涉及加载、验证、准备、解析和初始化五个步骤。垃圾回收机制主要在堆内存进行,通过可达性分析识别垃圾对象,并采用标记-清除、复制和标记-整理等算法进行回收。此外,还介绍了 CMS 和 G1 等垃圾回收器的特点。
18 0
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
|
12天前
|
缓存 负载均衡 Dubbo
Dubbo技术深度解析及其在Java中的实战应用
Dubbo是一款由阿里巴巴开源的高性能、轻量级的Java分布式服务框架,它致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。
39 6
|
9天前
|
监控 算法 Java
深入解析Java中的垃圾回收机制
本文旨在全面解析Java的垃圾回收机制,探讨其工作原理、常见算法以及在实际开发中的应用。通过对这一重要主题的深入分析,希望帮助读者更好地理解Java虚拟机(JVM)如何管理内存,从而编写出更高效、稳定的Java应用程序。
|
9天前
|
Java 开发者
Java中的异常处理机制深度解析
在Java编程中,异常处理是保证程序稳定性和健壮性的重要手段。本文将深入探讨Java的异常处理机制,包括异常的分类、捕获与处理、自定义异常以及一些最佳实践。通过详细讲解和代码示例,帮助读者更好地理解和应用这一机制,提升代码质量。
12 1
|
18天前
|
Java 程序员 开发者
Java中的异常处理机制深度解析
本文旨在深入探讨Java中异常处理的核心概念与实际应用,通过剖析异常的本质、分类、捕获及处理方法,揭示其在程序设计中的关键作用。不同于常规摘要,本文将直接切入主题,以简明扼要的方式概述异常处理的重要性及其在Java编程中的应用策略,引导读者快速把握异常处理的精髓。
|
17天前
|
安全 Java 开发者
Java并发编程中的锁机制解析
本文深入探讨了Java中用于管理多线程同步的关键工具——锁机制。通过分析synchronized关键字和ReentrantLock类等核心概念,揭示了它们在构建线程安全应用中的重要性。同时,文章还讨论了锁机制的高级特性,如公平性、类锁和对象锁的区别,以及锁的优化技术如锁粗化和锁消除。此外,指出了在高并发环境下锁竞争可能导致的问题,并提出了减少锁持有时间和使用无锁编程等策略来优化性能的建议。最后,强调了理解和正确使用Java锁机制对于开发高效、可靠并发应用程序的重要性。
16 3
|
20天前
|
存储 监控 算法
Java中的内存管理与垃圾回收机制解析
本文深入探讨了Java编程语言中的内存管理策略和垃圾回收机制。首先介绍了Java内存模型的基本概念,包括堆、栈以及方法区的划分和各自的功能。进一步详细阐述了垃圾回收的基本原理、常见算法(如标记-清除、复制、标记-整理等),以及如何通过JVM参数调优垃圾回收器的性能。此外,还讨论了Java 9引入的接口变化对垃圾回收的影响,以及如何通过Shenandoah等现代垃圾回收器提升应用性能。最后,提供了一些编写高效Java代码的实践建议,帮助开发者更好地理解和管理Java应用的内存使用。
|
10天前
|
分布式计算 Java API
深入解析Java中的Lambda表达式及其应用
本文将深入探讨Java中Lambda表达式的定义、优势及其在实际编程中的应用。通过具体示例,帮助读者更好地理解和使用这一强大的编程工具。

推荐镜像

更多
下一篇
无影云桌面