excel表格的特殊需求引发的Java思考
前言:
前些天遇到了这样的一个需求,将下图:

将表格中货号-前面部分一致的行合成一行,并且将第二行,第三行的价格添加到第一行中为价格二,价格三。如图:

接到这样的需求,我的第一感觉是直接手动合并(暗暗再想这也太简单了),然后我看了总记录数我放弃了,决定在网上找找excel的操作方法,找了一会没发现,心想不能浪费太多时间,不如自己动手丰衣足食,可能也是小弟(刚刚说老汉被批评了)比较愚昧,毕竟没怎么学过excel,望有会的大神留言,也当学习了。好了废话不多说了,接下来让我们来看看如何实现的吧。
首先想要实现此功能需要将读入excel表格,我这里使用的是HSSFWorkbook,因为用的是03版,如果想要兼容07版可以访问此博客http://www.cnblogs.com/yejg1212/p/3969822.html,我这就不多做介绍。想要读入文件我们首先是要得到这个文件流,即:
InputStream is = new FileInputStream("C://jlo.xls");
然后利用HSSFWorkbook读取,首先读取sheet,找到自己想要的sheet,获取循环所有行得到每列的值,如下:
HSSFWorkbook hssfWorkbook = new HSSFWorkbook(is);
HashMap<String, String> map = new HashMap<>();
// 循环工作表Sheet
for (int numSheet = 0; numSheet < hssfWorkbook.getNumberOfSheets(); numSheet++) {
HSSFSheet hssfSheet = hssfWorkbook.getSheetAt(numSheet);
if (hssfSheet == null) {
continue;
}
// 循环行Row
for (int rowNum = 1; rowNum <= hssfSheet.getLastRowNum(); rowNum++) {
HSSFRow hssfRow = hssfSheet.getRow(rowNum);
if (hssfRow == null) {
continue;
}
}
}
我这里为了更好的保存的,所以我建了一个实体类用于保存所获得值,写着写着突然停了,蒙了,我该如何将货号一样的内容拼接成一个实体类中了,想了想用数据库肯定不合适,太影响性能,所以机智的我选择了全局变量,类似于缓存,因为根据本excel显示规则,最多有三个会相同,而其他内容都是一致,所以只需要将相同的每一行的价格记录下来,保存到HashMap集合中,将其全部保存至最后一个实体model中,并且将其放入用于缓存的全局变量hashMap中,最后将其hashMap中所有value值即是处理后实体进行循环写入一个excel中,哇,就这么完成了。有点简单的,比在网上找excel操作并且还找不到感觉要快。接下来就是读取excel的具体代码实现:
/**
* 读取xls文件内容
*
* @throws IOException
* 输入/输出(i/o)异常
*/
private void readXls() throws IOException {
InputStream is = new FileInputStream("C://jlo.xls");
HSSFWorkbook hssfWorkbook = new HSSFWorkbook(is);
HashMap<String, String> map = new HashMap<>();
// 循环工作表Sheet
for (int numSheet = 0; numSheet < hssfWorkbook.getNumberOfSheets(); numSheet++) {
HSSFSheet hssfSheet = hssfWorkbook.getSheetAt(numSheet);
if (hssfSheet == null) {
continue;
}
// 循环行Row
for (int rowNum = 1; rowNum <= hssfSheet.getLastRowNum(); rowNum++) {
HSSFRow hssfRow = hssfSheet.getRow(rowNum);
if (hssfRow == null) {
continue;
}
XlsDto xld = new XlsDto();
xld.setSmiles(getValue(hssfRow.getCell(0)));
xld.setHuoHao(getValue(hssfRow.getCell(1)).substring(0,getValue(hssfRow.getCell(1)).indexOf("-")));
xld.seteName(getValue(hssfRow.getCell(2)));
xld.setcName(getValue(hssfRow.getCell(3)));
xld.setCas(getValue(hssfRow.getCell(4)));
xld.setHuoDate(getValue(hssfRow.getCell(5)));
xld.setPurity(getValue(hssfRow.getCell(6)));
xld.setKunCun(getValue(hssfRow.getCell(7)));
xld.setIsCreate(getValue(hssfRow.getCell(8)));
xld.setaCost(getValue(hssfRow.getCell(9)));
xld.setxType(getValue(hssfRow.getCell(1)).substring(0,getValue(hssfRow.getCell(1)).indexOf("-")));
if(StringUtils.isNotBlank(getValue(hssfRow.getCell(1)))){
if(!map.containsKey(xld.getxType())){
String cost = getValue(hssfRow.getCell(9));
//insertX(xld);
hashMap.put(xld.getxType(), xld);
map.put(xld.getxType(), "1");
map.put(xld.getxType()+"1", cost);
}else{
//String xType = getValue(hssfRow.getCell(1)).substring(0,getValue(hssfRow.getCell(1)).indexOf("-"));
if("1".equals(map.get(xld.getxType()))){
String cost = getValue(hssfRow.getCell(9));
xld.setaCost(map.get(xld.getxType()+"1"));
xld.setbCost(cost);
hashMap.put(xld.getxType(), xld);
//updateX(xType, cost,1);
map.put(xld.getxType(), "2");
map.put(xld.getxType()+"2", cost);
}else{
String cost = getValue(hssfRow.getCell(9));
xld.setaCost(map.get(xld.getxType()+"1"));
xld.setbCost(map.get(xld.getxType()+"2"));
xld.seteCost(cost);
hashMap.put(xld.getxType(), xld);
//updateX(xType, cost,2);
map.put(xld.getxType(), "3");
}
} }
}
}
}
处理完成之后,将其再次导入给excel,实现如下:
/**
*
* @param xls
* XlsDto实体类的一个对象
* @throws Exception
* 在导入Excel的过程中抛出异常
*/
public static void xlsDto2Excel(List<XlsDto> xls) throws Exception {
// 获取总列数
int CountColumnNum = xls.size();
// 创建Excel文档
HSSFWorkbook hwb = new HSSFWorkbook();
XlsDto xlsDto = null;
// sheet 对应一个工作页
HSSFSheet sheet = hwb.createSheet("sheet1");
HSSFRow firstrow = sheet.createRow(0); // // 下标为0的行开始
HSSFCell[] firstcell = new HSSFCell[CountColumnNum];
String[] names = new String[12];
names[0] = "SMILES";
names[1] = "货号";
names[2] = "产品名称(英文";
names[3] = "产品名称(中文";
names[4] = "CAS号";
names[5] = "货期(天)";
names[6] = "纯度";
names[7] = "库存";
names[8] = "是否可定制";
names[9] = "包装/价格1";
names[10] = "包装/价格2";
names[11] = "包装/价格3";
for (int j = 0; j < 12; j++) {
firstcell[j] = firstrow.createCell(j);
firstcell[j].setCellValue(new HSSFRichTextString(names[j]));
}
for (int i = 0; i < xls.size(); i++) {
// 创建一行
HSSFRow row = sheet.createRow(i + 1);
// 得到要插入的每一条记录
xlsDto = xls.get(i);
// 在一行内循环
HSSFCell xh = row.createCell(0);
xh.setCellValue(xlsDto.getSmiles());
HSSFCell xm = row.createCell(1);
xm.setCellValue(xlsDto.getHuoHao());
HSSFCell yxsmc = row.createCell(2);
yxsmc.setCellValue(xlsDto.geteName());
HSSFCell kcm = row.createCell(3);
kcm.setCellValue(xlsDto.getcName());
HSSFCell cj = row.createCell(4);
cj.setCellValue(xlsDto.getCas());
HSSFCell hd = row.createCell(5);
hd.setCellValue(xlsDto.getHuoDate());
HSSFCell purity = row.createCell(6);
purity.setCellValue(xlsDto.getPurity());
HSSFCell kuncun = row.createCell(7);
kuncun.setCellValue(xlsDto.getKunCun());
HSSFCell isc = row.createCell(8);
isc.setCellValue(xlsDto.getIsCreate());
HSSFCell ac = row.createCell(9);
ac.setCellValue(xlsDto.getaCost());
HSSFCell bc = row.createCell(10);
bc.setCellValue(xlsDto.getbCost());
HSSFCell ec = row.createCell(11);
ec.setCellValue(xlsDto.geteCost()); }
// 创建文件输出流,准备输出电子表格
OutputStream out = new FileOutputStream("C://jlol.xls");
hwb.write(out);
out.close();
System.out.println("数据库导出成功");
}
完美的解决了这个比较特殊而又不特殊的需求,代码提供仅供互相大家学习,欢迎访问提点不足之处。
excel表格的特殊需求引发的Java思考的更多相关文章
- java 操作Excel表格
对于Excel表格的解析.生成,java在 org.apache.poi 包中已经封装好了,使用比较简单. 解析Excel: 首先将File文件转成InputStream InputStream in ...
- java中使用poi导出excel表格数据并且可以手动修改导出路径
在我们开发项目中,很多时候会提出这样的需求:将前端的某某数据以excel表格导出,今天就给大家写一个简单的模板. 这里我们选择使用poi导出excel: 第一步:导入需要的jar包到 lib 文件夹下
- Java导出数据行写入到Excel表格:基于Apache POI
Java导出数据行写入到Excel表格:基于Apache POI import java.io.File; import java.io.FileOutputStream; import org.ap ...
- java连接MongoDB查询导出为excel表格
背景 因为项目需求.每一个星期须要统计每一个公众号7天的訪问数,月底就须要统计一个月的訪问数,40多个公众号.每次手动统计都须要花费1个小时,总之是一项无技术耗时耗神的手工活. 于是.想写个程序来统计 ...
- 使用java程序jxl操作Excel表格
在实际开发中企业办公系统都会涉及到一个打印报表的功能,也许你的需求就是把web前端展示的员工信息以Excel表格形式打印出来 ,那么具体怎么操作下面我来实现一下 首先我们使用的是 java的jxl技术 ...
- java解析导入excel表格转为实体类javabean,根据实体类中的中文名称
最近公司需求解析excel,一开始使用poi做的挺好的,后来直接上了几十万条数据的excel文件,内存直接溢出了,网上查到apache poi还提供了专门处理海量数据的方法,使用sax解析,果然用了内 ...
- 使用Java操作Excel表格
目录 一.配置第三方库 二.使用Apache POI API 1. 打开Excel文件 2. 选择对应的sheet 3. Sheet接口的基本使用 3.1 获取开头行和结束行 3.2 获取Row对象 ...
- Java JTable 表格 获取存储路径,文件名 ,导出excel表格
在做计量泵上位机软件时,需要将下位机传上来的数据,存入MYSQL数据库,显示在java 上位机界面上,并能导出至电脑指定位置. 选择存储路径和文件名: // 处理另存文件的菜单 public void ...
- java导出excel表格
java导出excel表格: 1.导入jar包 <dependency> <groupId>org.apache.poi</groupId> <artifac ...
随机推荐
- html中的图片、css、js等路径加载问题
网页文件的存取路径有3种:物理路径.绝对路径和相对路径. 物理路径就是你的文件放在主机上的具体位置,例如:D:\\image\\1.jpg 这种格式,该方法可以很快确定出你的文件,但是在网页显示路径基 ...
- pho
PDO(PHP Data Object) 是PHP 5新出来的东西,在PHP 6都要出来的时候,PHP 6只默认使用PDO来处理数据库,将把所有的数据库扩展移到了PECL,那么默认就是没有了我们喜爱的 ...
- TcpView 查看端口的小工具(推荐)
介绍: TCPView是一个Windows程序,将显示你的详细清单的所有TCP和UDP端点在您的系统,包括拥有进程名称,远程地址和状态的TCP连接. 打开下面的链接就可以下载了. https://te ...
- php传输大数据大文件时候php.ini相关设置
post_max_size which is directly related to the POST size---针对采用post上传的,大文件,此项为关键 upload_max_filesize ...
- 【转】amCharts,一款值得推荐的Flash charts图组件
今天无意中看到一个利用Flash生成chart图的工具:amCharts,我一开始就觉得这些chart图非常眼熟,它的显示样式跟监控宝的是完全一样的,我通过查看网页的源文件,才知道原来监控宝就是用的这 ...
- Java Dwr3实现消息推送步骤详解
DWR包含两个主要的部分:允许JavaScript从WEB服务器上一个遵循了AJAX原则的Servlet中获取数据.另外一方面一个JavaScript库可以帮助网站开发人员轻松地利用获取的数据来动态改 ...
- UWP_小说在线阅读器:功能要求与技术要求
学了WP开发也有一年了,也没做过什么软件的.17年进发UWP,锻炼自己一下.做一个开源的小说阅读器吧. 既然开发一个软件.所以要设计一下吧. 功能要求: 可能要用到的技术,这个吗,这就是遇到问题在解决 ...
- python unicode 转中文 遇到的问题 爬去网页中遇到编码的问题
How do convert unicode escape sequences to unicode characters in a python string 爬去网页中遇到编码的问题 Python ...
- html5、css3及响应式设计入门
一.响应式设计的定义 将三种已有的开发技巧(弹性网格布局.弹性图片.媒体和媒体查询)整合起来,命名为响应式网页设计.真正的响应式设计方法不仅仅只是根据视口大小改变网页布局.相反,它是要从整体上颠覆我们 ...
- YII 1.0 (7) 登录信息调取 session使用
登陆信息调取 Yii::app()->user->name,调取登陆的session信息 登录时 调用了 $LoginForm->login() 这个方法上面就能够取到登录的用户名 ...