java 中读取execl文件是必要功能,下面说下几种读取方式


1.jxl   (支持2003 不支持 2007  貌似最新版支持)

  1. /** 
  2.   * 规则设置的模板导入 
  3.   * @param file 
  4.   * @param exportDefindColum 
  5.   * @param exportDefindRemark 
  6.   * @param exportDefineid 
  7.   * @return 
  8.   * @throws Exception 
  9.   */ 
  10.  public List readSmProfitRuleExcel(File file,String[] defineColums,String[] defineRemarks,String[] defineids) throws Exception{ 
  11.   Workbook book = null; 
  12.   Cell cell = null; 
  13.   try { 
  14.    WorkbookSettings setting = new WorkbookSettings();    
  15.    java.util.Locale locale = new java.util.Locale("zh","CN");    
  16.    setting.setLocale(locale); 
  17.    setting.setEncoding("ISO-8859-1"); 
  18.    book = Workbook.getWorkbook(file, setting); 
  19.   } catch (Exception e2) { 
  20.    throw new Exception("Excel文件" + file.getName() + "读取出错。"); 
  21.   } 
  22.   List list = new ArrayList(); 
  23.   try { 
  24.    Sheet sheet = book.getSheet(0); 
  25.    int rows=sheet.getRows(); 
  26.    int columns=sheet.getColumns(); 
  27.    if(rows==0){ 
  28.     throw new Exception("Excel文件" + file.getName() + "无任何内容,禁止导入。"); 
  29.    } 
  30.    if(columns!=defineColums.length+1){ 
  31.     System.out.println("取出execl"+columns+"行,实际取出"+defineColums+1+"行"); 
  32.     throw new Exception("Excel文件" + file.getName() + "列头与模板列头不符 ,禁止导入 (如修改了规则,需存档重新生成模板再导入)。"); 
  33.    } 
  34.    for (int i = 0; i < defineids.length; i++) { 
  35.     String head = defineRemarks[i]+"-"+defineColums[i].substring(defineColums[i].indexOf(":")+1); 
  36.     if(!sheet.getCell(i,0).getContents().equals(head)){ 
  37.      System.out.println("取出execl列头"+sheet.getCell(i,0).getContents()+",实际取出"+head+"不匹配"); 
  38.      throw new Exception("Excel文件" + file.getName() + "列头与模板列头不符 ,禁止导入 (如修改了规则,需存档重新生成模板再导入)。"); 
  39.     } 
  40.    } 
  41.     
  42.    for (int i = 1; i < rows; i++) { 
  43.     for (int j = 0; j < columns; j++) { 
  44.      String content=sheet.getCell(j,i).getContents().trim(); 
  45.      if(content.equals("")){ 
  46.       throw new Exception("Excel文件" + file.getName() + "第"+(i+1)+"行,第"+(j+1)+"列存在空数据,禁止导入"); 
  47.      } 
  48.      Map<String, String> map = new HashMap<String, String>(); 
  49.      if(j>defineids.length-1){ 
  50.       map.put("defineid", "-1"); 
  51.      }else{ 
  52.       map.put("defineid", defineids[j]); 
  53.      } 
  54.      map.put("linenum",(i+1)+""); 
  55.      map.put("value", content); 
  56.      list.add(map); 
  57.     } 
  58.    } 
  59.    book.close(); 
  60.   } catch (Exception e) { 
  61.    book.close(); 
  62.    throw new Exception(e.getMessage()); 
  63.   } 
  64.   return list; 
  65.  }



附:

2.poi (apache 下的开源项目   03,07都支持)

  1. package com.dadi.oa.util.poi;
  2. import java.io.File;
  3. import java.io.FileInputStream;
  4. import java.io.InputStream;
  5. import java.util.ArrayList;
  6. import java.util.HashMap;
  7. import java.util.List;
  8. import org.apache.commons.logging.Log;
  9. import org.apache.commons.logging.LogFactory;
  10. import org.apache.poi.hssf.usermodel.HSSFCell;
  11. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  12. import org.apache.poi.ss.usermodel.Cell;
  13. import org.apache.poi.ss.usermodel.Row;
  14. import org.apache.poi.ss.usermodel.Sheet;
  15. import org.apache.poi.ss.usermodel.Workbook;
  16. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  17. import com.dadi.oa.util.StringUtil;
  18. /**
  19. * poi 读取 </br>
  20. * 1.execl兼容 03,07 <br/>
  21. * 2.构造方法需传入标准 <br/>
  22. * 3.对应的标准可以在checkReadStandard()扩展 <br/>
  23. *
  24. * @author ao.ouyang
  25. */
  26. public class ExeclReader {
  27. private final Log logger = LogFactory.getLog(this.getClass());
  28. /**
  29. * 数据Map集合 dataMap ,默认标准Map keys :<br/>
  30. * rowNum : 行号 <br/>
  31. * ColumnNum : 列号 <br/>
  32. * val : String类型值
  33. */
  34. private List dataMap = new ArrayList();
  35. //读取标准,定义新的标准可以在检查标准方法中拓展
  36. private String readStandard;
  37. private File readFile;
  38. private Workbook wb;
  39. private Sheet st;
  40. private Row row;
  41. //抽取文本工具
  42. private ExeclExtractor extractor;
  43. /**
  44. * ExeclReader
  45. * @param readItem 读取的execl
  46. * @param readStandards 无标准 Null
  47. */
  48. public ExeclReader(File readFile,String readStandards) throws Exception{
  49. this.readFile = readFile;
  50. this.readStandard = readStandard;
  51. readExecl();
  52. }
  53. private void readExecl() throws Exception{
  54. InputStream inputStream = new FileInputStream(readFile);
  55. try {
  56. if(readFile.getAbsolutePath().endsWith("xlsx")){
  57. wb=new XSSFWorkbook(inputStream);
  58. //实例化抽取工具
  59. extractor = new XSSFExeclExtractor((XSSFWorkbook)wb);
  60. }else{
  61. wb=new HSSFWorkbook(inputStream);
  62. extractor = new HSSFExeclExtractor((HSSFWorkbook)wb);
  63. }
  64. extractor.setFormulasNotResults(true);
  65. extractor.setIncludeCellComments(true);
  66. } catch (Exception e) {
  67. e.printStackTrace();
  68. throw new Exception("EXECL文件读取失败,请检查文件!");
  69. }
  70. st=wb.getSheetAt(0);
  71. //检查标准
  72. checkReadStandard();
  73. }
  74. /**
  75. * 检查标准
  76. * @throws Exception
  77. */
  78. private void checkReadStandard() throws Exception{
  79. if(StringUtil.isEmptyString(readStandard)){ //默认标准,无操作,读取execl数据
  80. readExeclToMapList();
  81. }
  82. }
  83. /**
  84. * 读取execl数据 封装数据
  85. * @throws Exception
  86. */
  87. private void readExeclToMapList() throws Exception{
  88. logger.info("============ExeclReader.readExeclToMapList() begin===========");
  89. try {
  90. for (int i = st.getFirstRowNum(); i <= st.getLastRowNum(); i++) {
  91. row=st.getRow(i);
  92. List<HashMap<String, String>> rowMap = new ArrayList<HashMap<String,String>>();
  93. for (int j = row.getFirstCellNum(); j < row.getLastCellNum(); j++) {
  94. HashMap<String,String> cellMap = new HashMap<String, String>();
  95. cellMap.put("rowNum", String.valueOf(i+1));
  96. cellMap.put("ColumnNum", String.valueOf(j+1));
  97. Cell cell = row.getCell(j) ;
  98. cellMap.put("val",extractor.getText(cell));
  99. rowMap.add(cellMap);
  100. }
  101. dataMap.add(rowMap);
  102. }
  103. } catch (Exception e) {
  104. e.printStackTrace();
  105. throw new Exception("读取execl 数据异常,请检查!!!");
  106. }
  107. logger.info("============ExeclReader.readExeclToMapList() end===========");
  108. }
  109. /**
  110. * 返回头数据
  111. * @return
  112. */
  113. public List getHeaderData(){
  114. return (List) dataMap.get(0);
  115. }
  116. /**
  117. * 返回底部数据
  118. * @return
  119. */
  120. public List getBottomData(){
  121. return (List) dataMap.get(dataMap.size()-1);
  122. }
  123. /**
  124. * 返回指定行的数据
  125. * @param columnIndex
  126. * @return
  127. */
  128. public List getRowData(int rowIndex){
  129. if(rowIndex<0){
  130. return getHeaderData();
  131. }else if(rowIndex > dataMap.size()){
  132. return getBottomData();
  133. }else{
  134. return (List) dataMap.get(rowIndex-1);
  135. }
  136. }
  137. /**
  138. * 获取指定列数据
  139. * @return
  140. */
  141. public List getcolumnData(int coloumIndex){
  142. if(coloumIndex > getColumnNum()){
  143. coloumIndex = getColumnNum();
  144. }else if(coloumIndex < 1){
  145. coloumIndex = 1;
  146. }else{
  147. coloumIndex = coloumIndex-1;
  148. }
  149. List columnData = new ArrayList();
  150. for (int i = 0; i < dataMap.size(); i++) {
  151. List rowData = (List) dataMap.get(i);
  152. for (int j = 0; j < rowData.size(); j++) {
  153. if(i==coloumIndex){
  154. columnData.add(rowData.get(j));
  155. }
  156. }
  157. }
  158. return columnData;
  159. }
  160. /**
  161. * 返回行总数
  162. * @return
  163. */
  164. public int getRowCount(){
  165. return st.getLastRowNum();
  166. //return st.getPhysicalNumberOfRows();
  167. }
  168. /**
  169. * 返回列总数
  170. * @return
  171. */
  172. public int getColumnNum(){
  173. return st.getRow(st.getFirstRowNum()).getLastCellNum();
  174. /* row= st.getRow(0);
  175. return row.getPhysicalNumberOfCells();*/
  176. }
  177. /**
  178. * 返回数据总数
  179. * @return
  180. */
  181. public int getDataCount(){
  182. return getRowCount() * getColumnNum();
  183. }
  184. /**
  185. * 返回数据总数 不含头
  186. * @return
  187. */
  188. public int getNotHeaderDataCount(){
  189. return getRowCount()-1 * getColumnNum();
  190. }
  191. public List getDataMap() {
  192. return dataMap;
  193. }
  194. public void setDataMap(List dataMap) {
  195. this.dataMap = dataMap;
  196. }
  197. }




附:


3.可使用 浏览器下的 ACTIVEX 空间读取 execl (ie浏览器)
附:

附件列表

java 读取execl文件的更多相关文章

  1. java分享第十六天( java读取properties文件的几种方法&java配置文件持久化:static块的作用)

     java读取properties文件的几种方法一.项目中经常会需要读取配置文件(properties文件),因此读取方法总结如下: 1.通过java.util.Properties读取Propert ...

  2. Java读取Excel文件的几种方法

    Java读取 Excel 文件的常用开源免费方法有以下几种: 1. JDBC-ODBC Excel Driver 2. jxl.jar 3. jcom.jar 4. poi.jar 简单介绍: 百度文 ...

  3. Java读取txt文件

    package com.loongtao.general.crawler.slave.utils; import java.io.BufferedReader; import java.io.File ...

  4. java 读取XML文件作为配置文件

    首先,贴上自己的实例: XML文件:NewFile.xml(该文件与src目录同级) <?xml version="1.0" encoding="UTF-8&quo ...

  5. java 读取TXT文件的方法

    java读取txt文件内容.可以作如下理解: 首先获得一个文件句柄.File file = new File(); file即为文件句柄.两人之间连通电话网络了.接下来可以开始打电话了. 通过这条线路 ...

  6. 用java读取properties文件--转

    今天为了通过java读取properties文件,google了很长时间,终于找到了.现在特记录之和大家一起分享.     下面直接贴出代码:java类 public class Mytest pub ...

  7. java读取xml文件报“org.xml.sax.SAXParseException: Premature end of file” .

    背景:java读取xml文件,xml文件内容只有“<?xml version="1.0" encoding="UTF-8"?>”一行 java读取该 ...

  8. java读取TXT文件的方法

    java读取txt文件内容.可以作如下理解: 首先获得一个文件句柄.File file = new File(); file即为文件句柄.两人之间连通电话网络了.接下来可以开始打电话了. 通过这条线路 ...

  9. java读取XML文件的四种方式

    java读取XML文件的四种方式 Xml代码 <?xml version="1.0" encoding="GB2312"?> <RESULT& ...

随机推荐

  1. 关于NHibernate中存在于Session中实例的3种状态的简单分析

    在使用NHibernate的时候.在Session中会有3种状态. 1. 瞬时状态 (Transient) 由 new 命令开辟内存空间的对象,也就是平时所熟悉的普通对象. 如: Student st ...

  2. org.apache.commons.lang.StringUtils中isEmpty和isBlank的区别

    public static boolean isEmpty(String str) 判断某字符串是否为空,为空的标准是str==null或str.length()==0 StringUtils.isE ...

  3. J2EE项目集成SAP的BO报表

    网上的方案: 每个用户在自己的J2EE系统的用户登陆的同时登陆bo系统,这做法的缺点是登陆bo速度慢,而且如果J2EE用户比较多的话会在bo服务器生成很多的token. 最佳方案(自己研究): 1.调 ...

  4. 搭建Hexo博客并部署到Github

    参考: http://www.jianshu.com/p/a67792d93682 http://jingyan.baidu.com/article/d8072ac47aca0fec95cefd2d. ...

  5. Web Service基础——基础概念

    1. Web Service基本概念 Web Service(Web服务)是一种远程调用技术,他的作用就是从远程系统中获取业务数据.具体来说,Web Service可以让你的网站使用其他网站的资源,比 ...

  6. HDUOJ----The Number Off of FFF

    The Number Off of FFF Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Ot ...

  7. 有效Log4j按指定级别定向输出日志到指定的输出文件地址配置Threshold,log4j中如何屏蔽父logger输出源rootlogger的additivity配置,log4j向多个文件记录日志

    log4j向多个文件记录日志 关键配置,指定想要的日志级别信息输出到指定的日志文件中: log4j.appender.errorLogger.Threshold=ERROR #扩展,可指定只在子类自己 ...

  8. Java虚拟机学习 - 垃圾收集器 (4)

    HotSpot JVM收集器 上面有7中收集器,分为两块,上面为新生代收集器,下面是老年代收集器.如果两个收集器之间存在连线,就说明它们可以搭配使用. Serial(串行GC)收集器 Serial收集 ...

  9. 如何恢复 Linux删除的文件

    原理及普通文件的恢复 要想恢复误删除的文件,必须清楚数据在磁盘上究竟是如何存储的,以及如何定位并恢复数据.本文从数据恢复的角度,着重介绍了 ext2 文件系统中使用的一些基本概念和重要数据结构,并通过 ...

  10. LeetCode总结 -- 一维数据合并篇

    合并是一维数据结构中非经常见的操作, 一般是排序, 分布式算法中的子操作. 这篇总结主要介绍LeetCode中关于合并的几个题目: Merge Two Sorted ListsMerge Sorted ...