Java读取Excel并解析文本(并格式化输出)-阿里云开发者社区

开发者社区> 茶花盛开> 正文

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

简介:
+关注继续查看

说明

最近在做一个比较小型的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. 虽然不知道这么做有什么后果,可是成功了

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
硬解析和物理读取与软解析和逻辑读取
参考:http://www.cnblogs.com/chinhr/archive/2009/03/14/1412100.html 001 预备知识 ·Recursive Calls:有时为了执行用户发出的一条SQL语句,Oracle必须执行额外的语句。
633 0
Java解析(读取)Json数据
以前看过书上说,XML是web service间传输信息的标准格式吧,就看了看XML。最近在做个网站,又说是有了JSON,第一回听说就看了看,总结总结一下。 1.JSON介绍   JSON比XML简单,主要体现在传输相同信息的情况下,文件的大小不同。
1506 0
Java Poi创建与读取Excel
Apache POI 下载 创建Excel表 public class Test { /** 存储路径 */ private static String path = "E:/Student.
702 0
IOS开发专题---转化解析JSON格式为字符格式(原生类库解析)
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.
591 0
【论坛精华帖整理】ELF文件格式解析
本文由dreamice在论坛所发,CU技术文章整理,供大家参考学习,转载请注明出处,谢谢。 1 Executable and Linkable Format(ELF)初稿,图请参考ELF_Format手册 1.1 Preface ELF-可执行链接格式最初是由UNIX系统实验室(USL)作为应用程序二进制接口(ABI)开发和发行。
687 0
poi读取excel模板,填充内容并导出,支持导出2007支持公式自动计算
/** * 版权所有(C) 2016 * @author www.xiongge.club * @date 2016-12-7 上午10:03:29 */ package xlsx; /** * @ClassName: CreateExcel * @Description: TODO() * @author www.xiongge.club *
2008 0
C#读取Excel表格中数据并返回datatable
在软件开发的过程中,经常用到从excel表格中读取数据作为数据源,以下整理了一个有效的读取excel表格的方法。   DataTable GetDataTable(string tableName,string leftTopCel,string rightbutCel) ...
1035 0
Windows下记事本编辑的Shell脚本放到Linux下执行出错,格式问题(/bin/bash^M: bad interpreter: 没有那个文件或目录)
错误:   /bin/bash^M: bad interpreter: 没有那个文件或目录   解决方案: 运行脚本时出现了这样一个错误,打开之后并没有找到所谓的^M,查了之后才知道原来是文件格式的问题,也就是linux和windows之间的不完全兼容。
775 0
Java Poi 创建与读取Excel
Poi 包下载 创建实体Java Bean--Student public class Student { private int id; private String name; private int age; ...
798 0
+关注
茶花盛开
web前端新手群291851189
218
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载