利用java操作Excel文件

               

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

一.读取Excel文件内容

java 代码
  1. /**读取Excel文件的内容  
  2.    
  3.  * @param file  待读取的文件  
  4.    
  5.  * @return  
  6.    
  7.  */  
  8.    
  9. public static String readExcel(File file){   
  10.    
  11.     StringBuffer sb = new StringBuffer();   
  12.    
  13.        
  14.    
  15.     Workbook wb = null;   
  16.    
  17.     try {   
  18.    
  19.         //构造Workbook(工作薄)对象   
  20.    
  21.         wb=Workbook.getWorkbook(file);   
  22.    
  23.     } catch (BiffException e) {   
  24.    
  25.         e.printStackTrace();   
  26.    
  27.     } catch (IOException e) {   
  28.    
  29.         e.printStackTrace();   
  30.    
  31.     }   
  32.    
  33.        
  34.    
  35.     if(wb==null)   
  36.    
  37.         return null;   
  38.    
  39.        
  40.    
  41.     //获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了   
  42.    
  43.     Sheet[] sheet = wb.getSheets();   
  44.    
  45.        
  46.    
  47.     if(sheet!=null&&sheet.length>0){   
  48.    
  49.         //对每个工作表进行循环   
  50.    
  51.         for(int i=0;i
  52.    
  53.             //得到当前工作表的行数   
  54.    
  55.             int rowNum = sheet[i].getRows();   
  56.    
  57.             for(int j=0;j
  58.    
  59.                 //得到当前行的所有单元格   
  60.    
  61.                 Cell[] cells = sheet[i].getRow(j);   
  62.    
  63.                 if(cells!=null&&cells.length>0){   
  64.    
  65.                     //对每个单元格进行循环   
  66.    
  67.                     for(int k=0;k
  68.    
  69.                         //读取当前单元格的值   
  70.    
  71.                         String cellValue = cells[k].getContents();   
  72.    
  73.                         sb.append(cellValue+"/t");   
  74.    
  75.                     }   
  76.    
  77.                 }   
  78.    
  79.                 sb.append("/r/n");   
  80.    
  81.             }   
  82.    
  83.             sb.append("/r/n");   
  84.    
  85.         }   
  86.    
  87.     }   
  88.    
  89.     //最后关闭资源,释放内存   
  90.    
  91.     wb.close();   
  92.    
  93.     return sb.toString();   
  94.    
  95. }  

二.写入Excel文件

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

java 代码
  1. /**生成一个Excel文件  
  2.    
  3.      * @param fileName  要生成的Excel文件名  
  4.    
  5.      */  
  6.    
  7.     public static void writeExcel(String fileName){   
  8.    
  9.         WritableWorkbook wwb = null;   
  10.    
  11.         try {   
  12.    
  13.             //首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象   
  14.    
  15.             wwb = Workbook.createWorkbook(new File(fileName));   
  16.    
  17.         } catch (IOException e) {   
  18.    
  19.             e.printStackTrace();   
  20.    
  21.         }   
  22.    
  23.         if(wwb!=null){   
  24.    
  25.             //创建一个可写入的工作表   
  26.    
  27.             //Workbook的createSheet方法有两个参数,第一个是工作表的名称,第二个是工作表在工作薄中的位置   
  28.    
  29.             WritableSheet ws = wwb.createSheet("sheet1"0);   
  30.    
  31.                
  32.    
  33.             //下面开始添加单元格   
  34.    
  35.             for(int i=0;i<10;i++){   
  36.    
  37.                 for(int j=0;j<5;j++){   
  38.    
  39.                     //这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行   
  40.    
  41.                     Label labelC = new Label(j, i, "这是第"+(i+1)+"行,第"+(j+1)+"列");   
  42.    
  43.                     try {   
  44.    
  45.                         //将生成的单元格添加到工作表中   
  46.    
  47.                         ws.addCell(labelC);   
  48.    
  49.                     } catch (RowsExceededException e) {   
  50.    
  51.                         e.printStackTrace();   
  52.    
  53.                     } catch (WriteException e) {   
  54.    
  55.                         e.printStackTrace();   
  56.    
  57.                     }   
  58.    
  59.   
  60.    
  61.                 }   
  62.    
  63.             }   
  64.    
  65.   
  66.    
  67.             try {   
  68.    
  69.                 //从内存中写入文件中   
  70.    
  71.                 wwb.write();   
  72.    
  73.                 //关闭资源,释放内存   
  74.    
  75.                 wwb.close();   
  76.    
  77.             } catch (IOException e) {   
  78.    
  79.                 e.printStackTrace();   
  80.    
  81.             } catch (WriteException e) {   
  82.    
  83.                 e.printStackTrace();   
  84.    
  85.             }   
  86.    
  87.         }   
  88.    
  89.     }   

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

java 代码
  1. /**搜索某一个文件中是否包含某个关键字  
  2.    
  3.      * @param file  待搜索的文件  
  4.    
  5.      * @param keyWord  要搜索的关键字  
  6.    
  7.      * @return  
  8.    
  9.      */  
  10.    
  11.     public static boolean searchKeyWord(File file,String keyWord){   
  12.    
  13.         boolean res = false;   
  14.    
  15.            
  16.    
  17.         Workbook wb = null;   
  18.    
  19.         try {   
  20.    
  21.             //构造Workbook(工作薄)对象   
  22.    
  23.             wb=Workbook.getWorkbook(file);   
  24.    
  25.         } catch (BiffException e) {   
  26.    
  27.             return res;   
  28.    
  29.         } catch (IOException e) {   
  30.    
  31.             return res;   
  32.    
  33.         }   
  34.    
  35.            
  36.    
  37.         if(wb==null)   
  38.    
  39.             return res;   
  40.    
  41.            
  42.    
  43.         //获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了   
  44.    
  45.         Sheet[] sheet = wb.getSheets();   
  46.    
  47.            
  48.    
  49.         boolean breakSheet = false;   
  50.    
  51.            
  52.    
  53.         if(sheet!=null&&sheet.length>0){   
  54.    
  55.             //对每个工作表进行循环   
  56.    
  57.             for(int i=0;i
  58.    
  59.                 if(breakSheet)   
  60.    
  61.                     break;   
  62.    
  63.                    
  64.    
  65.                 //得到当前工作表的行数   
  66.    
  67.                 int rowNum = sheet[i].getRows();   
  68.    
  69.                    
  70.    
  71.                 boolean breakRow = false;   
  72.    
  73.                    
  74.    
  75.                 for(int j=0;j
  76.    
  77.                     if(breakRow)   
  78.    
  79.                         break;   
  80.    
  81.                     //得到当前行的所有单元格   
  82.    
  83.                     Cell[] cells = sheet[i].getRow(j);   
  84.    
  85.                     if(cells!=null&&cells.length>0){   
  86.    
  87.                         boolean breakCell = false;   
  88.    
  89.                         //对每个单元格进行循环   
  90.    
  91.                         for(int k=0;k
  92.    
  93.                             if(breakCell)   
  94.    
  95.                                 break;   
  96.    
  97.                             //读取当前单元格的值   
  98.    
  99.                             String cellValue = cells[k].getContents();   
  100.    
  101.                             if(cellValue==null)   
  102.    
  103.                                 continue;   
  104.    
  105.                             if(cellValue.contains(keyWord)){   
  106.    
  107.                                 res = true;   
  108.    
  109.                                 breakCell = true;   
  110.    
  111.                                 breakRow = true;   
  112.    
  113.                                 breakSheet = true;   
  114.    
  115.                             }   
  116.    
  117.                         }   
  118.    
  119.                     }   
  120.    
  121.                 }   
  122.    
  123.             }   
  124.    
  125.         }   
  126.    
  127.         //最后关闭资源,释放内存   
  128.    
  129.         wb.close();   
  130.    
  131.            
  132.    
  133.         return res;   
  134.    
  135.     }  

四.往Excel中插入图片图标

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

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

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

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

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

            

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

猜你喜欢

转载自blog.csdn.net/qq_43679507/article/details/87022872