- 浏览: 238770 次
- 性别:
- 来自: 上海
博客专栏
-
Java应用集锦
浏览量:23110
文章分类
最新评论
-
yipeng_666:
yipeng_666 写道楼主可以分享源码吗 , 感激不尽邮 ...
基于jquery框架dwz做的后台管理系统 -
yipeng_666:
楼主可以分享源码吗 , 感激不尽
基于jquery框架dwz做的后台管理系统 -
ughome:
楼主,能发个源码吗,我删除后刷新有问题,总是跳转到第一页。查询 ...
基于jquery框架dwz做的后台管理系统 -
ellie_it:
DWZ研究中,楼主可以分享源码学习下吗?万分感谢! 93020 ...
基于jquery框架dwz做的后台管理系统 -
hongshenghome:
前辈,dwz刚开始学,给我发份源码,万分感谢!!!!!,邮箱 ...
基于jquery框架dwz做的后台管理系统
下面的这段代码仅仅支持excel2003,要同时支持2007和2003的excel请看后半部分!!
经常使用exlce的操作,以前工作使用的jxl,现在工作又使用poi.还好以前总结过,轻松搞定.这里再次把代码贴出来,可以直接使用.
package poi; import java.util.List; /** * 测试poi的工具类. * */ public class PoiUtil { public static void main(String[] args) { String fileName = "D:\\工作\\开发需求\\测试2.xls"; //参数1:文件名 //参数2:要读取的多个sheet的index //参数3:是否在遇到第一个空行时停止往下读取 List<String[][]> strs1 = ExcelReader.readAllExcel(fileName, new String[]{"3","1","2"}, true); for (int i = 0; i < strs1.size(); i++) { System.out.println(getString2Array(strs1.get(i))); } } public static String getString2Array(String[][] str) { StringBuffer buf = new StringBuffer("["); //System.out.println("行数:" + str.length); //System.out.println("列数:" + str[0].length); int len1 = str.length; int len2 = str[0].length; for (int i = 0; i < len1; i++) { for (int j = 0; j < len2; j++) { buf.append(str[i][j]); if (j != len2 - 1) { buf.append(","); } else { buf.append("\n"); } } } buf.append("]"); return buf.toString(); } }
ExcelReader.java(仅对2003的excel操作有效!)
package poi; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.List; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFDateUtil; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; public class ExcelReader { /** * 工作簿 */ private HSSFWorkbook workbook; /** * 日志记录 */ private Log log = LogFactory.getLog("logger"); /** * excel表 */ private HSSFSheet sheet; /** * excel文件流 */ private FileInputStream fis; /** * 消息 */ private StringBuffer msg = null; public ExcelReader(File exl) throws IOException { fis = new FileInputStream(exl); workbook = new HSSFWorkbook(fis); msg = new StringBuffer(); } public ExcelReader(String exlFileName) throws IOException { File file = new File(exlFileName); fis = new FileInputStream(file); workbook = new HSSFWorkbook(fis); msg = new StringBuffer(); } public ExcelReader(InputStream input) throws IOException { workbook = new HSSFWorkbook(input); msg = new StringBuffer(); } public void destory() { try { msg = null; if(fis!=null) fis.close(); } catch (Exception ex) { log.error("ExcelReader-destory", ex); msg.append(ex.getMessage()); } } public boolean setCurrentSheet(int num) { if (workbook != null && num < workbook.getNumberOfFonts()) { try { sheet = workbook.getSheetAt(num); return true; } catch (NullPointerException e) { log.error("ExcelReader-setCurrentSheet", e); } } return false; } /** * 可以看到根据下面的五个参数确定了一个excel文件页面里面的一个矩形区域。 * * @param sheetNum * 文件的页面 * @param firstRowNum * 第一行的行数 * @param lastRowNum * 最后一行的行数 * @param firstColIndex * 第一列的列数 * @param lastColIndex * 最后一列的列数 * @return */ public String[][] getSheetAsTable(int sheetNum, int firstRowNum, int lastRowNum, int firstColIndex, int lastColIndex) { String[][] cells = null; if (setCurrentSheet(sheetNum)) { cells = new String[lastRowNum - firstRowNum + 1][lastColIndex - firstColIndex + 1]; int row = 0; for (int c1 = firstRowNum; c1 <= lastRowNum; c1++) { for (int c2 = firstColIndex; c2 <= lastColIndex; c2++) { try { cells[c1][c2] = getCellAsStringByIndex(c1, c2); } catch (Exception e) { log.error("ExcelReader-getSheetAsTable", e); cells[c1][c2] = ""; } } } } return cells; } /** * 返回指定位置的单元格 * * @param rowId * 设置单元格的行 * @param colId * 设置单元格的列 * @return */ public String getCellAsStringByIndex(int rowId, int colId) { String cellStr = ""; if (sheet != null && rowId < sheet.getLastRowNum() + 1) { try { HSSFRow row = sheet.getRow(rowId); if (row != null) { if (colId < row.getLastCellNum()) { HSSFCell cell = row.getCell((short) colId); if (cell != null) { try { switch (cell.getCellType()) { case 0: {// CELL_TYPE_NUMERIC if (HSSFDateUtil.isCellDateFormatted(cell)) { Date d= HSSFDateUtil.getJavaDate( cell.getNumericCellValue()); SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd"); cellStr = df.format(d); }else{ cellStr =Double.toString(cell.getNumericCellValue());
} break; } case 1: {// CELL_TYPE_STRING cellStr = cell.getStringCellValue(); break; } case 2: { String formula = cell.getCellFormula(); if (formula.indexOf("DATE(") >= 0) { Date d= HSSFDateUtil.getJavaDate( cell.getNumericCellValue()); SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd"); cellStr = df.format(d); } else if (formula.indexOf("SUM(") >= 0) { cellStr = Double.toString(cell .getNumericCellValue()); }else if (formula.indexOf("SIN(") >= 0) { cellStr = Double.toString(cell .getNumericCellValue()); } else { cellStr = cell.getStringCellValue(); } break; } case 4: { cellStr = Boolean.toString(cell.getBooleanCellValue()); break; } default: { cellStr = new String(""); } if (cellStr == null) { cellStr = ""; } } } catch (Exception e) { log.error("ExcelReader-getCellAsStringByIndex", e); cellStr = ""; } } } } } catch (Exception e) { log.error("ExcelReader-getCellAsStringByIndex", e); cellStr = ""; } } return cellStr; } /** * 返回指定sheet,指定行,指定列的单元格内容. * @param sheetNum * @param rowindex * @param colIndex * @return */ public String getCellAsStringByIndex(int sheetNum,int rowindex,int colIndex) { if(setCurrentSheet(sheetNum)){ return getCellAsStringByIndex(rowindex,colIndex); } return ""; } public void emptyCell(HSSFCell cell){ System.out.println(cell.getCellType()); } public String getErrorMessage() { return msg.toString(); } /** * 返回当前的页面 * @return */ public HSSFSheet getSheet() { return sheet; } /** * 返回当前的工作簿 * @return */ public HSSFWorkbook getWorkbook() { return workbook; } /** * * @param fileName * 要读取的excel文件名 * @param sheetNum * 要读取的表单的数目 * @param row * 要读取的单元格行数 * @param col * 要读取的单元格列数 * @return */ public static String readExcel(String fileName, String sheetNum, String row, String col) { try { ExcelReader excelRd = new ExcelReader(fileName); excelRd.setCurrentSheet(new Integer(sheetNum).intValue() - 1); return excelRd.getCellAsStringByIndex( (new Integer(row).intValue() - 1), (new Integer(col).intValue() - 1)); } catch (Exception e) { e.printStackTrace(); return "出现异常,可能是文件未找到!"; } } /** * 读取excel文件的一个表格里面的基本信息:最大行数 * * @param fileName * 文件名 * @param sheetNum * 要读取的表单的数目 * @return */ public static String readRowInfo(String fileName, String sheetNum) { try { ExcelReader excelRd = new ExcelReader(fileName); excelRd.setCurrentSheet(new Integer(sheetNum).intValue() - 1); HSSFSheet sheet = excelRd.getSheet(); int rowNum = sheet.getLastRowNum() + 1; return new Integer(rowNum).toString(); } catch (Exception e) { e.printStackTrace(); return "检查输入的文件是否存在或者页面不存在!"; } } /** * 读取excel中某一个表单的某一行的最大列数 * * @param fileName * 文件名 * @param sheetNum * 表单的数目 * @param row * 行数 * @return */ public static String readColInfo(String fileName, String sheetNum, String row) { ExcelReader excelRd; HSSFSheet sheet; HSSFRow rowNum; int colNum; try { excelRd = new ExcelReader(fileName); excelRd.setCurrentSheet(new Integer(sheetNum).intValue() - 1); sheet = excelRd.getSheet(); rowNum = sheet.getRow(new Integer(row).intValue()); colNum = rowNum.getLastCellNum(); return new Integer(colNum).toString(); } catch (Exception e) { e.printStackTrace(); return "检查输入的文件是否存在!"; } } /** * 获取文件的工作簿的数目 * * @param fileName * 文件名 * @return */ public static String readSheetInfo(String fileName) { ExcelReader excelRd; HSSFWorkbook workbook; int sheetNum; try { excelRd = new ExcelReader(fileName); workbook = excelRd.getWorkbook(); sheetNum = workbook.getNumberOfSheets(); return new Integer(sheetNum).toString(); } catch (Exception e) { e.printStackTrace(); return "检查输入的文件是否存在!"; } } /** * 返回指定文件的页面的全部数据 * * @param fileName * 文件名 * @param sheetNum * 文件的表数 * @return String[][] */ public static String[][] readAllExcel(String fileName, String sheetNum) { return readAllExcel(fileName,sheetNum,false); } public static List<String[][]> readAllExcel(String fileName, String[] sheetNums) { return readAllExcel(fileName,sheetNums,false); } public static List<String[][]> readAllExcel(String fileName, String[] sheetNums, boolean returnMeetFirstNullRow) { ExcelReader excelRd; try { excelRd = new ExcelReader(fileName); return readAllExcel(excelRd, sheetNums, returnMeetFirstNullRow); } catch (Exception e) { e.printStackTrace(); return null; } } /** * 返回指定文件的页面的全部数据,并指定是否在第一行遇到null的时候自动停止继续往下搜索 * @param fileName * @param sheetNum * @param returnFirstNullRow * 遇到第一个空行自动停止继续往下搜索. * @return */ public static String[][] readAllExcel(String fileName, String sheetNum, boolean returnMeetFirstNullRow) { ExcelReader excelRd; try { excelRd = new ExcelReader(fileName); return readAllExcel(excelRd, sheetNum, returnMeetFirstNullRow); } catch (Exception e) { e.printStackTrace(); return null; } } /** * 返回指定文件的页面的全部数据 * @param input * @param sheetNum * @return */ public static String[][] readAllExcel(InputStream input, String sheetNum) { return readAllExcel(input,sheetNum,false); } /** * 私有方法:返回指定excel中的指定sheet内容. * @param excelRd * @param sheetNum * @param returnMeetFirstNullRow * @return */ private static String[][] readAllExcel(ExcelReader excelRd, String sheetNum, boolean returnMeetFirstNullRow) { String[] sheetNums = new String[]{sheetNum}; List<String[][]> ans = readAllExcel(excelRd,sheetNums,returnMeetFirstNullRow); return ans.get(0); } /** * 一次返回多个sheet的内容. * @param excelRd * @param sheetNums * @param returnMeetFirstNullRow * @return */ private static List<String[][]> readAllExcel(ExcelReader excelRd, String[] sheetNums, boolean returnMeetFirstNullRow) { //如果遇到第一个空行自动返回,调用下面的方法. List<String[][]> ans = new ArrayList<String[][]>(); int sheetId; HSSFSheet sheet; int maxRowNum; HSSFRow row; int maxColNum; String[][] result; try { for(int i=sheetNums.length-1;i>=0;i--){ result = new String[][] {{}}; sheetId = new Integer(sheetNums[i]).intValue() - 1; excelRd.setCurrentSheet(sheetId); sheet = excelRd.getSheet(); //如果设置了要遇到第一个空行就自动返回,就计算maxRowNum! if (returnMeetFirstNullRow) { maxRowNum = 0; row = null; // 得到从0行开始的第一个非空行数. for (;; maxRowNum++) { row = sheet.getRow(maxRowNum); if (row == null) { if (maxRowNum != 0) maxRowNum--; break; } } } //否则直接取全部的excel的行数 else { maxRowNum = sheet.getLastRowNum(); } if(maxRowNum!=0){ // 得到第一行的列数. row = sheet.getRow(0); maxColNum = row.getLastCellNum(); result = excelRd.getSheetAsTable(sheetId, 0, maxRowNum, 0, maxColNum - 1); } ans.add(result); } excelRd.destory(); return ans; } catch (Exception e) { e.printStackTrace(); return null; } } /** * 返回指定文件的页面的全部数据 * @param input * @param sheetNum * @param returnMeetFirstNullRow 是否遇到空行直接返回 * @return */ public static String[][] readAllExcel(InputStream input, String sheetNum, boolean returnMeetFirstNullRow) { ExcelReader excelRd; try { excelRd = new ExcelReader(input); return readAllExcel(excelRd, sheetNum, returnMeetFirstNullRow); } catch (Exception e) { e.printStackTrace(); return null; } } /** * 返回全部的指定sheet中的exlce内容. * @param input * @param sheetNums * @return */ public static List<String[][]> readAllExcel(InputStream input, String[] sheetNums) { return readAllExcel(input,sheetNums,false); } /** * 返回全部的指定sheet中的exlce内容. * @param input * @param sheetNums sheet字符串数组 * @param returnMeetFirstNullRow * @return */ public static List<String[][]> readAllExcel(InputStream input, String[] sheetNums, boolean returnMeetFirstNullRow) { ExcelReader excelRd; try { excelRd = new ExcelReader(input); return readAllExcel(excelRd, sheetNums, returnMeetFirstNullRow); } catch (Exception e) { e.printStackTrace(); return null; } } }
ExcelWrite.java
package poi; import java.beans.Introspector; import java.beans.PropertyDescriptor; import java.io.FileInputStream; import java.io.FileOutputStream; import java.util.List; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFCellStyle; import org.apache.poi.hssf.usermodel.HSSFFont; 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.hssf.util.HSSFColor; public class ExcelWrite { /** * 工作簿 */ private HSSFWorkbook workbook; /** * 日志记录 */ private Log log = LogFactory.getLog("logger"); /** * excel表 */ private HSSFSheet sheet; /** * excel文件流 */ private FileInputStream fis; /** * 消息 */ private StringBuffer msg = null; public ExcelWrite() { } /** * 从一个javaBean的集合向目标文件写数据 * @param data 一个装有javaBean的list * @param targetFile 目标excel文件 */ public String setSheetFromTable(List data, String targetFile) { try { HSSFWorkbook targetWorkbook = new HSSFWorkbook(); FileOutputStream fout = new FileOutputStream(targetFile,true); setDataToWorksheet(data, targetWorkbook, 0); targetWorkbook.write(fout); fout.flush(); fout.close(); return "ok"; } catch (Exception e) { log.error("出现异常", e); return ""; } } /** * 将list的数据放进excel的一个工作表中去。 * @param data 数据的来源list,是一个来自于数据库的装满了javabean的list * @param workbook 目的excel工作簿 * @param sheetNum 目的excel工作簿的表格要填写数据的页码 */ public void setDataToWorksheet(List data,HSSFWorkbook workbook,int sheetNum) { HSSFRow title = null; HSSFSheet sheet = null; try{ if(data.size()<1) { return ; } sheet = workbook.createSheet(); //下面设置cell的文字格式 font = workbook.createFont(); font.setFontName(HSSFFont.FONT_ARIAL); font.setUnderline((byte)1); font.setColor(HSSFColor.BLUE.index); //下面设置标题行的样式 titleStyle = workbook.createCellStyle(); titleStyle.setBorderBottom((short)1); titleStyle.setBorderLeft((short)1); titleStyle.setBorderRight((short)1); titleStyle.setBorderTop((short)1); titleStyle.setFont(font); titleStyle.setFillForegroundColor(HSSFColor.LIGHT_CORNFLOWER_BLUE.index); titleStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND); //取list中的第一个数据,进行属性名称的读取,准备放到excel表格中的第一行 Object aData = data.get(0); PropertyDescriptor[] props = Introspector.getBeanInfo( aData.getClass(), Object.class).getPropertyDescriptors(); //在表格的第一行建立一个数据行,用来放置这些属性的名称 title = sheet.createRow(0); //设置行高.注意值设置的很大。。 title.setHeight((short)500); for(short temp = 0; temp < props.length; temp++) { HSSFCell cell = title.createCell(temp); cell.setCellStyle(titleStyle); cell.setCellType(HSSFCell.CELL_TYPE_STRING); cell.setCellValue(props[temp].getShortDescription()); //设置各个列的宽度 sheet.setColumnWidth((short)temp, (short)5000); } for(int temp = 0;temp<data.size();temp++) { //实际的数据是开始从第二行开始进行传递的 HSSFRow row = sheet.createRow(temp+1); //取出javabean对象里面的各个属性的值 Object obj = data.get(temp); String values[] = getPropertyOfBean(obj); for(short cellNum=0;cellNum<values.length;cellNum++){ HSSFCell cell = row.createCell(cellNum); cell.setCellType(HSSFCell.CELL_TYPE_STRING); cell.setCellValue(values[cellNum]); } } }catch(Exception e) { log.error("出现bug",e); } } HSSFFont font = null; HSSFCellStyle titleStyle = null; /** * 设置excel表格的样式 * */ private void setStyle() { } /** * 根据一个javabean对象,返回这个对象的属性值集合,使用到反射机制。 * @return */ private String[] getPropertyOfBean(Object obj) { String[] result = null; try { PropertyDescriptor[] props = Introspector.getBeanInfo( obj.getClass(), Object.class).getPropertyDescriptors(); result = new String[props.length]; for (int temp = 0; temp < props.length; temp++) { try { result[temp] = props[temp].getReadMethod().invoke(obj) .toString(); } catch (Exception e) { log.error("出现异常", e); return null; } } } catch (Exception e1) { log.error("出现异常", e1); return null; } return result; } }
同时支持excel2003和excel2007的java类:
对excel2003和excel2007使用的java类是不一样的,对于2003使用的java类前缀一般为HSSF,例如HSSFWorkbook,HSSFCell等,而对于2007前缀是XSSF,例如XSSFWorkbook类等.
下面的这个类创建一个workBook对象,并根据excel文件自动进行判断需要实例化2003的excel解析类还是2007的excel的解析类:
package poi; import java.io.IOException; import java.io.InputStream; import java.io.PushbackInputStream; import org.apache.poi.POIXMLDocument; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.openxml4j.exceptions.InvalidFormatException; import org.apache.poi.openxml4j.opc.OPCPackage; import org.apache.poi.poifs.filesystem.POIFSFileSystem; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class WorkbookFactory { /** * Creates an HSSFWorkbook from the given POIFSFileSystem */ public static Workbook create(POIFSFileSystem fs) throws IOException { return new HSSFWorkbook(fs); } /** * Creates an XSSFWorkbook from the given OOXML Package */ public static Workbook create(OPCPackage pkg) throws IOException { return new XSSFWorkbook(pkg); } public static Workbook create(InputStream inp) throws IOException, InvalidFormatException { if(! inp.markSupported()) { inp = new PushbackInputStream(inp, 8); } if(POIFSFileSystem.hasPOIFSHeader(inp)) { return new HSSFWorkbook(inp); } if(POIXMLDocument.hasOOXMLHeader(inp)) { return new XSSFWorkbook(OPCPackage.open(inp)); } throw new IllegalArgumentException("Your InputStream was neither an OLE2 stream, nor an OOXML stream"); } } |
然后在调用生成workbook对象的时候,一律使用超类型即可,不要再使用HSSFWorkBook或者XSSFWorkBook的类型就行了!
例如下面的例子:ExcelReader.java,将其中的所有的构造函数中修改使用上面的create方法创建返回workBook对象即可!并且去掉所有前缀含有HSSF的类名即可!!
public ExcelReader(File exl) throws IOException { fis = new FileInputStream(exl); workbook = WorkbookFactory .create(fis); msg = new StringBuffer(); } public ExcelReader(String exlFileName) throws IOException { File file = new File(exlFileName); fis = new FileInputStream(file); workbook = WorkbookFactory .create(fis); msg = new StringBuffer(); } public ExcelReader(InputStream input) throws IOException { workbook =WorkbookFactory .create(fis); msg = new StringBuffer(); } |
在实践中,遇到了这样的一个异常:
java.lang.NegativeArraySizeException
at org.apache.poi.hssf.record.SSTDeserializer.readStringRemainder(SSTDeserializer.java:335)
at org.apache.poi.hssf.record.SSTDeserializer.processContinueRecord(SSTDeserializer.java:320)
at org.apache.poi.hssf.record.SSTRecord.processContinueRecord(SSTRecord.java:539)
at org.apache.poi.hssf.record.RecordFactory.createRecords(RecordFactory.java:216)
at org.apache.poi.hssf.usermodel.HSSFWorkbook.<init>(HSSFWorkbook.java:181)
at org.apache.poi.hssf.usermodel.HSSFWorkbook.<init>(HSSFWorkbook.java:228)
at org.apache.poi.hssf.usermodel.HSSFWorkbook.<init>(HSSFWorkbook.java:209)
找了很久,结果换成使用最新的poi包,以及修改使用上面的create()创建新的workBook对象就可以了(后来不改这个类也可以,仅仅换包就行了),有点奇怪,不知道怎么引起的...
发表评论
-
test
2018-02-01 15:19 0testtesttesttest -
spring中使用AOP进行日志记录[含代码]
2017-09-13 15:14 788spring的IOC和AOP是说的最烂的东西,尤其是后者, ... -
关于java web开发中的很多小问题集锦
2017-05-11 11:24 21641、导出excel文件,文件名的中文问题 public ... -
自定义java类重写hashcode和equals方法
2014-12-24 15:34 12781.何时需要重写equals() 当一个类有自 ... -
java的普通类重写hashcode和equals方法
2014-12-24 15:33 0class AddServe { public Stri ... -
解决问题
2013-11-18 22:54 1431启动tomcat的时候,报错如下: java 写道 严 ... -
强烈推荐一个简单而实用的数据库连接池工程
2013-07-15 23:53 1129接触过很多的数据库连接池,有d3p0,druid,都比较nb ... -
自己写的一个jedis操作模板类
2013-07-15 23:28 1427jedis是java的redis客户端程序,在spring下 ... -
打算写一个关于股票的开源小玩意
2013-03-08 23:44 0目标: 1.锻炼自己的编码能力,组织代码的能力 2.为 ... -
java应用集锦9:httpclient4.2.2的几个常用方法,登录之后访问页面问题,下载文件
2012-11-16 16:03 19973转账注明出处:http://renjie120.iteye. ... -
java应用集锦7:日期函数 double精度问题 list和数组等
2010-07-20 17:51 2454转载请注明出处: http://renjie120.itey ... -
java应用集锦6:字符串base64加密解密 MD5加密
2010-07-20 16:56 5641转载请注明出处: http://renjie120.it ... -
java应用集锦5:缓存管理 单例模式 ThreadLocal
2010-07-20 12:06 6505转载请注明出处: http://renjie120.it ... -
java应用集锦4:保存大对象 上传显示进度条
2010-07-20 11:20 3549转载请注明出处: http://renjie120.it ... -
java应用集锦3:正则表达式 excel操作之jxl
2010-07-13 17:20 3367转载请注明出处: http://renjie120.it ... -
java应用集锦1:序列化 操作xml 常见IO
2010-07-12 19:42 2108转载请注明出处: http://renjie120.it ... -
java应用集锦2:反射
2010-07-07 17:52 1940在项目中多处使用到反射方法,jdk为1.5.现总结如下: 1 ... -
制作可以执行的jar包
2010-06-08 13:41 1245今天试了一下制作可执行的Jar文件的方法。 具体如下: 首 ... -
Cannot load JDBC driver class 'oracle.jdbc.driver.OracleDriver'的解决办法
2010-04-29 11:55 8787exception javax.servlet. ...
相关推荐
Java 使用Apache POI库操作Excel 2007文件详解 在Java开发中,处理Excel文件是一项常见的任务,特别是对于数据分析、数据导入导出或报表生成等场景。Apache POI是一个流行的开源库,它允许开发者读写Microsoft ...
Java POI 的主要特点是可以在 Java 应用程序中读取、写入和操作 Office 文件。 2. Java POI 的组成 Java POI 由多个组件组成,每个组件负责处理不同的 Office 文件格式。以下是 Java POI 的主要组件: * POIFS ...
Apache POI是一个流行的库,它允许开发者使用Java来读取、写入和修改Microsoft Office格式的文件,包括Excel(.xlsx, .xls)。在本项目中,我们结合了POI库和XML技术来实现Excel数据的验证与导入数据库。 首先,...
java使用poi进行excel2003、excel2007导入,返回List[]>,实测可用 xbean-2.2.0.jar包 与 xmlbeans-2.3.0.jar包冲突 需删除xbean-2.2.0.jar包
Apache POI是一个开源项目,提供了丰富的API,使得Java开发者能够轻松地与MS Office格式交互,包括XLS(Excel 97-2003)和XLSX(Excel 2007及以后的版本)。 标题中的"java通过poi操作excel jar包"指的是使用Apache...
标题提到的“POI导入excel大数据处理”是指利用Apache POI进行大量Excel数据的导入操作,同时它兼容Excel 2003(.xls格式)和2007以上版本(.xlsx格式)的文件。 POI库的主要优点包括: 1. **多格式支持**:不仅...
Java的Apache POI库是一个强大的工具,用于读取、创建和修改Microsoft Office格式的文件,尤其是Excel(.xlsx)文档。在本示例中,我们将深入探讨如何利用POI库来生成Excel中的图表曲线,这对于数据可视化和报告生成...
为更方便的使用POI的API来操作Excel(2003)文件,对POI中针对Excel文件的读写进行了简单封装。此类中包含以下功能: 1.根据模板创建Excel文件 2.获取及更新Excel文件内容 3.创建、复制Sheet 4.设置Sheet名称 ... ...
Java POI 是一个开源项目,...通过以上步骤和知识点,你可以使用Java POI库高效地进行Excel操作,无论是读取现有数据还是创建新的Excel文件。记得参考官方文档和示例代码,这将帮助你更好地理解和运用这个强大的库。
以下是关于使用Java POI进行Excel操作的关键知识点: 1. **Apache POI介绍**: Apache POI是一个开源项目,它提供了API来处理Microsoft的文件格式,如Word(.doc),PowerPoint(.ppt)和Excel(.xls或.xlsx)。在...
通过这样的封装,开发者可以在Java应用程序中方便地进行Excel的读写操作,无需关心具体实现细节,提高了代码的可维护性和可读性。在实际开发中,可以根据项目需求进一步定制工具类,例如增加样式设置、公式处理等...
java使用POI导出 Excel+图片工具类 ,里面含有poi jar包,只调用接口即可直接保存Excel。使用的时候需先把数据封装,具体包装需根据实际导出数据进行处理。文件demo中只提供包装格式。
Java 使用 Apache POI 操作 Excel 是一种常见的数据处理方式,特别是在大数据分析、报表生成和数据导入导出等场景中。Apache POI 是一个开源库,它允许 Java 开发者读写 Microsoft Office 格式,包括 Excel(.xlsx ...
最后,`poi-excelant-3.15-beta1.jar`是为了支持Apache Ant构建工具而设计的,它允许你在Ant脚本中直接使用POI进行Excel文件的处理。 使用POI导出Excel的基本步骤如下: 1. 创建`Workbook`对象,这代表一个Excel...
Java POI项目由Apache软件基金会维护,支持读取和写入Microsoft Office的多种文件格式,如XLS(Excel 97-2003)、XLSX(Excel 2007以上版本)以及Word、PowerPoint等。对于Excel,POI提供了一个高级用户模型(HSSF)...
在Java世界中,Poi是解析和操作这些文件的首选工具,尤其在数据导入导出、自动化测试、数据分析等领域应用广泛。 Excel文件通常以.XLS或.XLSX格式存在,其中.XLS是早期版本的二进制格式,而.XLSX则是基于Open XML...
下面将详细介绍如何使用Java POI对Excel进行导入和导出。 首先,导入必要的POI库。在Maven项目中,你需要在pom.xml文件中添加以下依赖: ```xml <groupId>org.apache.poi <artifactId>poi <version>4.1.2 ...
【描述】:本教程将详细介绍如何使用Apache POI库在JAVA环境中操作Excel文件,包括创建、读取和修改Excel数据。 【标签】:JAVA操作EXCEL教程,POI 【正文】: Apache POI是一个开源的Java库,专门用于处理...
【JAVA使用POI操作Excel详解】 Apache POI 是一个开源的Java库,它允许程序员创建、修改和显示Microsoft Office格式的文件,特别是Excel。在Java中,POI库提供了读取和写入Excel文件的强大功能,包括对2003(.xls)...
标题 "POI 生成EXCEL2007【含例子】" 涉及到的知识点主要集中在Apache POI库的使用上,这是一个强大的Java API,用于读取、写入和修改Microsoft Office格式的文件,特别是Excel文件。在这个场景中,重点是创建和操作...