`
hbcui1984
  • 浏览: 149309 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

利用java操作Excel文件

    博客分类:
  • java
阅读更多

利用java操作Excel文件

        很久以来都想研究一下利用java操作Excel的方法,今天没事,就稍微了解了一下,特总结一下。利用java操作Excel,有个开源的东东-jxl.jar,可以到http://sourceforge.net/project/showfiles.php?group_id=79926下载。

一.读取Excel文件内容

java 代码
  1. /**读取Excel文件的内容  
  2.  * @param file  待读取的文件  
  3.  * @return  
  4.  */  
  5. public static String readExcel(File file){   
  6.     StringBuffer sb = new StringBuffer();   
  7.        
  8.     Workbook wb = null;   
  9.     try {   
  10.         //构造Workbook(工作薄)对象   
  11.         wb=Workbook.getWorkbook(file);   
  12.     } catch (BiffException e) {   
  13.         e.printStackTrace();   
  14.     } catch (IOException e) {   
  15.         e.printStackTrace();   
  16.     }   
  17.        
  18.     if(wb==null)   
  19.         return null;   
  20.        
  21.     //获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了   
  22.     Sheet[] sheet = wb.getSheets();   
  23.        
  24.     if(sheet!=null&&sheet.length>0){   
  25.         //对每个工作表进行循环   
  26.         for(int i=0;i
  27.             //得到当前工作表的行数   
  28.             int rowNum = sheet[i].getRows();   
  29.             for(int j=0;j
  30.                 //得到当前行的所有单元格   
  31.                 Cell[] cells = sheet[i].getRow(j);   
  32.                 if(cells!=null&&cells.length>0){   
  33.                     //对每个单元格进行循环   
  34.                     for(int k=0;k
  35.                         //读取当前单元格的值   
  36.                         String cellValue = cells[k].getContents();   
  37.                         sb.append(cellValue+"\t");   
  38.                     }   
  39.                 }   
  40.                 sb.append("\r\n");   
  41.             }   
  42.             sb.append("\r\n");   
  43.         }   
  44.     }   
  45.     //最后关闭资源,释放内存   
  46.     wb.close();   
  47.     return sb.toString();   
  48. }  

二.写入Excel文件

这里有很多格式了,比如文本内容加粗,加上某些颜色等,可以参考jxl的api,同时还推荐一篇不错的文章:http://www.ibm.com/developerworks/cn/java/l-javaExcel/?ca=j-t10

java 代码
  1. /**生成一个Excel文件  
  2.      * @param fileName  要生成的Excel文件名  
  3.      */  
  4.     public static void writeExcel(String fileName){   
  5.         WritableWorkbook wwb = null;   
  6.         try {   
  7.             //首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象   
  8.             wwb = Workbook.createWorkbook(new File(fileName));   
  9.         } catch (IOException e) {   
  10.             e.printStackTrace();   
  11.         }   
  12.         if(wwb!=null){   
  13.             //创建一个可写入的工作表   
  14.             //Workbook的createSheet方法有两个参数,第一个是工作表的名称,第二个是工作表在工作薄中的位置   
  15.             WritableSheet ws = wwb.createSheet("sheet1"0);   
  16.                
  17.             //下面开始添加单元格   
  18.             for(int i=0;i<10;i++){   
  19.                 for(int j=0;j<5;j++){   
  20.                     //这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行   
  21.                     Label labelC = new Label(j, i, "这是第"+(i+1)+"行,第"+(j+1)+"列");   
  22.                     try {   
  23.                         //将生成的单元格添加到工作表中   
  24.                         ws.addCell(labelC);   
  25.                     } catch (RowsExceededException e) {   
  26.                         e.printStackTrace();   
  27.                     } catch (WriteException e) {   
  28.                         e.printStackTrace();   
  29.                     }   
  30.   
  31.                 }   
  32.             }   
  33.   
  34.             try {   
  35.                 //从内存中写入文件中   
  36.                 wwb.write();   
  37.                 //关闭资源,释放内存   
  38.                 wwb.close();   
  39.             } catch (IOException e) {   
  40.                 e.printStackTrace();   
  41.             } catch (WriteException e) {   
  42.                 e.printStackTrace();   
  43.             }   
  44.         }   
  45.     }   

三.在一个Excel文件中查找是否包含某一个关键字

java 代码
  1. /**搜索某一个文件中是否包含某个关键字  
  2.      * @param file  待搜索的文件  
  3.      * @param keyWord  要搜索的关键字  
  4.      * @return  
  5.      */  
  6.     public static boolean searchKeyWord(File file,String keyWord){   
  7.         boolean res = false;   
  8.            
  9.         Workbook wb = null;   
  10.         try {   
  11.             //构造Workbook(工作薄)对象   
  12.             wb=Workbook.getWorkbook(file);   
  13.         } catch (BiffException e) {   
  14.             return res;   
  15.         } catch (IOException e) {   
  16.             return res;   
  17.         }   
  18.            
  19.         if(wb==null)   
  20.             return res;   
  21.            
  22.         //获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了   
  23.         Sheet[] sheet = wb.getSheets();   
  24.            
  25.         boolean breakSheet = false;   
  26.            
  27.         if(sheet!=null&&sheet.length>0){   
  28.             //对每个工作表进行循环   
  29.             for(int i=0;i
  30.                 if(breakSheet)   
  31.                     break;   
  32.                    
  33.                 //得到当前工作表的行数   
  34.                 int rowNum = sheet[i].getRows();   
  35.                    
  36.                 boolean breakRow = false;   
  37.                    
  38.                 for(int j=0;j
  39.                     if(breakRow)   
  40.                         break;   
  41.                     //得到当前行的所有单元格   
  42.                     Cell[] cells = sheet[i].getRow(j);   
  43.                     if(cells!=null&&cells.length>0){   
  44.                         boolean breakCell = false;   
  45.                         //对每个单元格进行循环   
  46.                         for(int k=0;k
  47.                             if(breakCell)   
  48.                                 break;   
  49.                             //读取当前单元格的值   
  50.                             String cellValue = cells[k].getContents();   
  51.                             if(cellValue==null)   
  52.                                 continue;   
  53.                             if(cellValue.contains(keyWord)){   
  54.                                 res = true;   
  55.                                 breakCell = true;   
  56.                                 breakRow = true;   
  57.                                 breakSheet = true;   
  58.                             }   
  59.                         }   
  60.                     }   
  61.                 }   
  62.             }   
  63.         }   
  64.         //最后关闭资源,释放内存   
  65.         wb.close();   
  66.            
  67.         return res;   
  68.     }  

四.往Excel中插入图片图标

插入图片的实现很容易,参看以下代码:

java 代码
  1. /**往Excel中插入图片  
  2.  * @param dataSheet  待插入的工作表  
  3.  * @param col 图片从该列开始  
  4.  * @param row 图片从该行开始  
  5.  * @param width 图片所占的列数  
  6.  * @param height 图片所占的行数  
  7.  * @param imgFile 要插入的图片文件  
  8.  */  
  9. public static void insertImg(WritableSheet dataSheet, int col, int row, int width,   
  10.         int height, File imgFile){   
  11.     WritableImage img = new WritableImage(col, row, width, height, imgFile);   
  12.     dataSheet.addImage(img);   
  13. }   

以上代码的注释已经很清楚了,大概也就不用再解释了,我们可以用如下程序验证:

java 代码
  1.     try {   
  2.         //创建一个工作薄   
  3. WritableWorkbook workbook = Workbook.createWorkbook(new File("D:/test1.xls"));   
  4. //待插入的工作表   
  5. WritableSheet imgSheet = workbook.createSheet("Images",0);   
  6. //要插入的图片文件   
  7. File imgFile = new File("D:/1.png");   
  8. //图片插入到第二行第一个单元格,长宽各占六个单元格   
  9. insertImg(imgSheet,0,1,6,6,imgFile);   
  10. workbook.write();   
  11. workbook.close();   
  12.  catch (IOException e) {   
  13. e.printStackTrace();   
  14.  catch (WriteException e) {   
  15. e.printStackTrace();   

 但是jxl只支持png格式的图片,jpg格式和gif格式都不支持

五.插入页眉页脚

一般的页眉页脚都分为三个部分,左,中,右三部分,利用如下代码可实现插入页眉页脚

java 代码
  1. /**向Excel中加入页眉页脚  
  2.  * @param dataSheet 待加入页眉的工作表  
  3.  * @param left  
  4.  * @param center  
  5.  * @param right  
  6.  */  
  7. public static void setHeader(WritableSheet dataSheet,String left,String center,String right){   
  8.     HeaderFooter hf = new HeaderFooter();   
  9.     hf.getLeft().append(left);   
  10.     hf.getCentre().append(center);   
  11.     hf.getRight().append(right);   
  12.     //加入页眉   
  13.     dataSheet.getSettings().setHeader(hf);   
  14.     //加入页脚   
  15.     //dataSheet.getSettings().setFooter(hf);   
  16. }  

我们可以用如下代码测试该方法:

java 代码
  1.     try {   
  2.         //创建一个工作薄   
  3.     WritableWorkbook workbook = Workbook.createWorkbook(new File("D:/test1.xls"));   
  4.     //待插入的工作表   
  5.     WritableSheet dataSheet = workbook.createSheet("加入页眉",0);   
  6.     ExcelUtils.setHeader(dataSheet, "chb""2007-03-06""第1页,共3页");   
  7.     workbook.write();   
  8.     workbook.close();   
  9. catch (IOException e) {   
  10.     e.printStackTrace();   
  11. catch (WriteException e) {   
  12.     e.printStackTrace();   
  13. }   
  14.   }   
分享到:
评论
41 楼 copier8 2012-07-12  
很详细,试试!
40 楼 h819 2007-04-01  
楼主,学习笔记很详细啊
收藏了
谢谢
39 楼 过河卒 2007-03-15  
收了 挺好 正好用到 3Q
38 楼 cskysnew 2007-03-12  
提示,Date和label类型不一样,需要加入format。
37 楼 hbcui1984 2007-03-09  
代码有了一些新的更新,加入了插入页眉页脚的代码
36 楼 ShingU 2007-03-09  
以前只知道POI,现在可以多一个选择了。:)
35 楼 linxi1105 2007-03-09  
我们开发的软件就是做作图软件,有组件我们还有开发的必要吗!客户的数据就在Excel里面。
34 楼 hgq0011 2007-03-08  
linxi1105 写道
hgq0011 写道
linxi1105 写道
jxl和poi在数据量比较大(测试过9000多行,60多列)的情况下报内存溢出是就不行了,不知道各位是如何解决的?

实际使用的报表会用到那么多的数据吗?
这样生成了,那会不会很慢?
还是不要拿那么多的数据吧



      我们目的不是最后要显示报表,而是要将提取出来的数据画成图形。而且我们遇到的还有比我提到的更大的文件。问题一直解决不了,最后只能将excel文件转成txt文件进行读取。


为什么不用专门的把数据转换成图形的组件呢?偏偏要倒入到Excel中,然后在操作呢?
33 楼 linxi1105 2007-03-08  
hgq0011 写道
linxi1105 写道
jxl和poi在数据量比较大(测试过9000多行,60多列)的情况下报内存溢出是就不行了,不知道各位是如何解决的?

实际使用的报表会用到那么多的数据吗?
这样生成了,那会不会很慢?
还是不要拿那么多的数据吧



      我们目的不是最后要显示报表,而是要将提取出来的数据画成图形。而且我们遇到的还有比我提到的更大的文件。问题一直解决不了,最后只能将excel文件转成txt文件进行读取。
32 楼 qingjian 2007-03-08  
hbcui1984 写道
qingjian 写道
想问一下lz在写excel文件的时候数据量过大的话jvm会内存溢出请教一下还有什么好的方法能解决

我的想法是,可以将文件分割,先生成一个小文件1.xls,然后将后续内容写入一个新的文件中2.xls,然后再将2.xls的内容复制到1.xls的后边
这只是我的想法,还没模拟过特别大的文件,没有真正实践过

我们这边数据库大概千万条以上  excel文件有一定限制大小的并不能无穷大!
31 楼 Peter_Pan 2007-03-08  
还是支持POI多一点。
30 楼 hgq0011 2007-03-07  
linxi1105 写道
jxl和poi在数据量比较大(测试过9000多行,60多列)的情况下报内存溢出是就不行了,不知道各位是如何解决的?

实际使用的报表会用到那么多的数据吗?
这样生成了,那会不会很慢?
还是不要拿那么多的数据吧
29 楼 linxi1105 2007-03-07  
jxl和poi在数据量比较大(测试过9000多行,60多列)的情况下报内存溢出是就不行了,不知道各位是如何解决的?
28 楼 ming500 2007-03-06  
整理的很好了,收藏。谢谢。
27 楼 hbcui1984 2007-03-06  
sssina 写道
我觉得关闭I/O流这一段,还是应该放在finally块里面比较稳妥一点,不知楼主意下如何呢???

嗯,是的,关闭IO流的操作确实应该放在finally块里,谢谢提醒!
26 楼 yangbo9229 2007-03-06  
very easy ! i can do it !
25 楼 sssina 2007-03-04  
我觉得关闭I/O流这一段,还是应该放在finally块里面比较稳妥一点,不知楼主意下如何呢???
24 楼 hbcui1984 2007-03-03  
beauty9235 写道
for(int i=0;i 
            //得到当前工作表的行数    
            int rowNum = sheet[i].getRows();    
            for(int j=0;j 

老大你的代码是不有问题哦???作附件让人下载嘛

这个公式编辑确实有问题,我已经把源码上传了
23 楼 glassprogrammer 2007-03-03  
POI无法处理带格式的页眉页脚(指稳定版, 最新的alpha版本不知道是不是会好点), 而 jxl 好象在处理日期类型的单元格上有些问题(和时区有关, 好象 jxl 没有处理时区), 所以我们的一个库就把这两个东西都用上了, 呼呼
22 楼 jvincent 2007-03-02  
收藏一下...不过不太清楚和POI相比,哪个的效率更高一些

相关推荐

Global site tag (gtag.js) - Google Analytics