- 浏览: 193514 次
- 性别:
- 来自: 本溪
文章分类
最新评论
-
shouchun_w:
写的非常翔实!辛苦了!我在按照你的“扩展抓屏函数”(命令完全一 ...
Selenium循环测试,使用变量,抓屏 -
chenhailong:
わかる、ありがど
【转载】ようだ、みたいだの比較 -
mahengyang:
为什么用tomcat启动web工程时需要将用到的jar包都放在 ...
(tomcat中级)应用Tomcat的WebappClassLoader加载指定目录的jar文件 -
柏新星:
柏新星 写道create table Person (id i ...
derby+myBatis 入门 -
柏新星:
create table Person (id int pri ...
derby+myBatis 入门
本例用到以下Class,完成对Excel的基本读写。我用的Excel是2003
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.poifs.filesystem.POIFSFileSystem;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.IndexedColors;
package net.tianyu.study.poi; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.util.ArrayList; import java.util.List; 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.poifs.filesystem.POIFSFileSystem; import org.apache.poi.ss.usermodel.CellStyle; import org.apache.poi.ss.usermodel.IndexedColors; public class DiffXls { private static final String KEY_MARK = "key"; private static final String END_MARK = "end"; private static final String UPDATE_DATA_MARK = "Updated"; private static final int MAX_LINES = 3000; private HSSFWorkbook wb; private HSSFSheet sheet; private List<Integer> keyColumns = new ArrayList<Integer>(); private List<KeyData> orgKeyList = new ArrayList<KeyData>(); private int dataStartRow; private int dataEndColumn; private FileOutputStream out = null; private FileInputStream in = null; private short updateColor = IndexedColors.LIGHT_YELLOW.getIndex(); private short insertColor = IndexedColors.LIGHT_GREEN.getIndex(); private short deleteColor = IndexedColors.GREY_25_PERCENT.getIndex(); public void open(String inputFileName, String outputFileName) throws IOException { in = new FileInputStream(inputFileName); out = new FileOutputStream(outputFileName); POIFSFileSystem filein = new POIFSFileSystem(in); wb = new HSSFWorkbook(filein); sheet = wb.getSheetAt(0); } public void run() throws IOException { initKeyColumn(); initOrgKeyList(); initDataStartRow(); startDiff(); format(); wb.write(out); } public void close() throws IOException { out.close(); in.close(); } private void initKeyColumn() { HSSFRow markRow = sheet.getRow(0); for (int i = 0; i < MAX_LINES; i++) { HSSFCell cell = markRow.getCell(i); if (cell != null && KEY_MARK.equals(cell.getStringCellValue())) { keyColumns.add(i); System.out.println(i); } if (cell != null && END_MARK.equals(cell.getStringCellValue())) { dataEndColumn = i; System.out.println("dataEndColumn :" + dataEndColumn); break; } } } private void initOrgKeyList() { for (int i = 2; i < MAX_LINES; i++) { HSSFRow dataRow = sheet.getRow(i); if (dataRow == null) { break; } KeyData key = new KeyData(); key.setRow(i); for (Integer keyColumn : keyColumns) { HSSFCell cell = dataRow.getCell(keyColumn); if (cell != null) { if (cell.getCellType() == HSSFCell.CELL_TYPE_STRING) { key.addValue(cell.getStringCellValue()); } else if (cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC) { key.addValue(Double.toString(cell.getNumericCellValue())); } } } System.out.println(key.toString()); orgKeyList.add(key); } } private void format() { for (int i = 0; i < dataEndColumn; i++) { sheet.autoSizeColumn(i); int width = sheet.getColumnWidth(i); if (width > 256 * 100) { sheet.setColumnWidth(i, 256 * 100); } } } private void initDataStartRow() { for (int i = 1; i < MAX_LINES; i++) { HSSFRow dataRow = sheet.getRow(i); if (dataRow == null) { continue; } HSSFCell cell = dataRow.getCell(0); if (cell != null && cell.getCellType() == HSSFCell.CELL_TYPE_STRING && UPDATE_DATA_MARK.equals(cell.getStringCellValue())) { dataStartRow = i + 2; break; } if (cell != null && cell.getCellType() == HSSFCell.CELL_TYPE_STRING && END_MARK.equals(cell.getStringCellValue())) { break; } } System.out.println(dataStartRow); } private int matchKeyRow(KeyData key) { for (KeyData orgKey : orgKeyList) { if (orgKey.equals(key)) { orgKey.setHasSameData(true); return orgKey.getRow(); } } return 0; } private boolean isSameData(int orgRow, int targetRow) { boolean result = true; for (int i = 0; i < dataEndColumn; i++) { HSSFRow orgData = sheet.getRow(orgRow); HSSFRow targetData = sheet.getRow(targetRow); if (orgData == null || targetData == null) { result = false; } HSSFCell orgCell = orgData.getCell(i); HSSFCell targetCell = targetData.getCell(i); if (orgCell == null && targetCell == null) { continue; } if (orgCell == null && targetCell != null) { setCellColor(orgCell, updateColor); setCellColor(targetCell, updateColor); result = false; } if (targetCell == null && orgCell != null) { setCellColor(orgCell, updateColor); setCellColor(targetCell, updateColor); result = false; } if (orgCell.getCellType() != targetCell.getCellType()) { setCellColor(orgCell, updateColor); setCellColor(targetCell, updateColor); result = false; } if (orgCell.getCellType() == HSSFCell.CELL_TYPE_STRING) { if (!orgCell.getStringCellValue().equals(targetCell.getStringCellValue())) { setCellColor(orgCell, updateColor); setCellColor(targetCell, updateColor); result = false; } } if (orgCell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC) { if (orgCell.getNumericCellValue() != targetCell.getNumericCellValue()) { setCellColor(orgCell, updateColor); setCellColor(targetCell, updateColor); result = false; } } } return result; } private void startDiff() { for (int i = dataStartRow; i < MAX_LINES; i++) { HSSFRow dataRow = sheet.getRow(i); if (dataRow == null) { break; } HSSFCell cell = dataRow.getCell(0); if (cell != null && cell.getCellType() == HSSFCell.CELL_TYPE_STRING && END_MARK.equals(cell.getStringCellValue())) { break; } KeyData key = new KeyData(); key.setRow(i); for (Integer keyColumn : keyColumns) { cell = dataRow.getCell(keyColumn); if (cell != null) { if (cell.getCellType() == HSSFCell.CELL_TYPE_STRING) { key.addValue(cell.getStringCellValue()); } else if (cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC) { key.addValue(Double.toString(cell.getNumericCellValue())); } } } int orgRow = matchKeyRow(key); if (orgRow != 0) { System.out.println("updateRow : " + i + " orgRow : " + orgRow + " " + isSameData(i, orgRow)); } else { setRowColor(i, insertColor); } } setDeleteColor(); } private void setDeleteColor() { for (KeyData orgKey : orgKeyList) { if (!orgKey.isHasSameData()) { setRowColor(orgKey.getRow(), deleteColor); } } } private void setRowColor(int row, short color) { HSSFRow dataRow = sheet.getRow(row); for (int i = 0; i < dataEndColumn; i++) { HSSFCell cell = dataRow.getCell(i); if (cell == null) { cell = dataRow.createCell(i); } setCellColor(cell, color); } } private void setCellColor(HSSFCell cell, short color) { CellStyle style = wb.createCellStyle(); style.cloneStyleFrom(cell.getCellStyle()); style.setFillPattern(CellStyle.SOLID_FOREGROUND); style.setFillForegroundColor(color); style.setBorderBottom(CellStyle.BORDER_THIN); style.setBorderTop(CellStyle.BORDER_THIN); style.setBorderLeft(CellStyle.BORDER_THIN); style.setBorderRight(CellStyle.BORDER_THIN); cell.setCellStyle(style); } }
- java.zip (3.6 KB)
- 下载次数: 10
发表评论
-
WCF & WSDL
2014-07-16 09:25 600http://www.atmarkit. ... -
设定PNG的bKGD
2012-06-01 17:20 1033一,参考资料 PNG结构说明 http://home ... -
扩展ExtJS的【Ext.data.reader.Json】例子
2012-03-07 19:35 1917一,下面是扩展Class Ext.define('Dn ... -
Java合并PNG图像(保持背景透明)
2012-01-21 10:43 8138import java.awt.Graphics2D; im ... -
htmlcompressor介绍
2011-09-05 16:01 4178官网 : http://code.google.com/p/h ... -
(java入门)Velocity最简单例程
2011-08-26 06:51 1810一,前言 在编程中总会用到 “文本模板”+“数据” 来生 ... -
找出Web程序依赖的所有的JAR(中文)
2011-06-23 20:02 1020一,前言 开发Web应用程序时总会在lib目录下放很多J ... -
(java入门)创建SSL连接
2011-06-09 16:21 1546纯粹备忘录。 用Windows系统的证明书STORE ... -
Google的Mail地址簿的API的应用
2011-05-25 23:22 4301#前言 我用Gmail觉得地址簿操作不方便。幸好Goog ... -
gclog的分析方法
2011-04-21 19:17 1182一,概要 通过GC的LOG也能为判断内存泄漏提供些相关信 ... -
找出Web程序依赖的所有的JAR
2011-04-13 10:51 898■問題 WebAppを開発する際、Spring、Strut ... -
JConsole连接远程JVM的设定
2011-03-24 10:38 575■検測されたJVMのパラメータは、下記である。 -Dcom. ... -
derby+myBatis 入门
2010-10-15 13:00 37281, 下载derby, myBatis。 2, 设定DERB ... -
(java入门)用apache.poj读写Excel文件的例子(2)
2010-09-03 15:39 1174Excelファイル比較サンプル package net.ti ... -
Cobertura 笔记
2010-05-07 13:56 13351,从 http://cobertura.sourceforg ... -
(Struts2)OGNL笔记 # 的用法三
2010-03-30 20:37 862在行选择等计算中,用 #this 代表迭代中的当前对象 Ac ... -
(Struts2)OGNL笔记 # 的用法二
2010-03-30 20:11 768可以作成一个Map JSP <s:s ... -
(Struts2)OGNL笔记 # 的用法一
2010-03-30 19:49 732可以用#访问 Request, Session, Applic ... -
(java入门) MyLog
2009-09-07 23:47 932package net.dncsoft.test; ... -
(Axis2 入门) Sample JAX-WS 异步Client
2009-08-18 15:17 18171、binding.xml準備 <bindings ...
相关推荐
02.北大POJ题库使用指南.docx02.北大POJ题库使用指南.docx02.北大POJ题库使用指南.docx02.北大POJ题库使用指南.docx02.北大POJ题库使用指南.docx02.北大POJ题库使用指南.docx02.北大POJ题库使用指南.docx02.北大POJ...
POJ1048,加强版的约瑟夫问题 难度中等
北大POJ1004-Financial Management 解题报告+AC代码
NULL 博文链接:https://128kj.iteye.com/blog/1705139
用java的biginteger实现的poj1001,比较简单的方法
只是poj上的一条题目,对于理解后缀数组很有帮助.poj3261
C语言写的,通过了.我第一个POJ通过的文件,纪念一下.POJ上对于格式要求还真是紧啊!
POJ 1328 java做!雷达问题!java版本!AC答案~
北大poj JAVA源码
poj平台有关数据结构题的Java源码 1159 1276 2406 2502 2509 2513 2533 2778 3176
poj.grids.cn题型汇总 Dp状态设计与方程总结 1.不完全状态记录 <1>青蛙过河问题 利用区间dp 2.背包类问题 <1> 0-1背包,经典问题 无限背包,经典问题 判定性背包问题 带附属关系的背包问题 <5> + -1背包...
题目分类 目前网上最全的 PKU 的 网上所有的 分类总结 祝ACM 一路顺风
poj题目2775文件子目录源代码,递归经典题目,
...
北大POJ2002-Squares 解题报告+AC代码
POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类
poj 2785 4 Values whose Sum is 0 测试数据 解题报告: http://blog.csdn.net/qq7366020/article/details/8623208
用Java代码实现POJ(PKU)上题2494!
这是我个人写的POJ上2314题的Java实现,希望对喜欢ACM的人有帮助