使用POI操作Excel文件(一)

针对使用POI操作Excel文件,可以参考:《POI读取EXCEL教程》http://julycn.javaeye.com/blog/107341

下面为在struts1.x下使用POI读取上传的Excel文件中的内容。见意:刚接触POI的读者可以看看,否则就可以免了。

大概过程如下:在浏览器端上传文件——>使用struts api读取上传的文件——>使上传的文件转换为InputStream——>通过InputSteam得到HSSFWorkbook——>通过HSSFWorkbook得到HSSFSheet ——>通过HSSFSheet 得到HSSFRow——>再通过HSSFRow 得到HSSFCell——>最后得到单元格中的值

为了方便阅读全部代码如下,完整代码见我的资源:http://download.csdn.net/source/765509

  1. //UploadForm.java
  2. import org.apache.struts.action.ActionForm;
  3. import org.apache.struts.upload.FormFile;
  4. public class UploadForm extends ActionForm {
  5.     private FormFile file;
  6.     public FormFile getFile() {
  7.         return file;
  8.     }
  9.     public void setFile(FormFile file) {
  10.         this.file = file;
  11.     }   
  12. }
  1. //UploadAction.java
  2. import java.io.InputStream;
  3. import java.util.ArrayList;
  4. import javax.servlet.http.HttpServletRequest;
  5. import javax.servlet.http.HttpServletResponse;
  6. import org.apache.poi.hssf.usermodel.HSSFCell;
  7. import org.apache.poi.hssf.usermodel.HSSFRow;
  8. import org.apache.poi.hssf.usermodel.HSSFSheet;
  9. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  10. import org.apache.struts.action.Action;
  11. import org.apache.struts.action.ActionForm;
  12. import org.apache.struts.action.ActionForward;
  13. import org.apache.struts.action.ActionMapping;
  14. import org.apache.struts.upload.FormFile;
  15. public class UploadAction extends Action {
  16.     @Override
  17.     public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception {
  18.         
  19.         UploadForm uploadForm=(UploadForm)form;
  20.         FormFile file=uploadForm.getFile(); 
  21.         //get the InputStream
  22.         InputStream is=file.getInputStream();
  23.         //get the Workbook
  24.         HSSFWorkbook wb=new HSSFWorkbook(is);
  25.         //get the sheet
  26.         HSSFSheet sheet=wb.getSheet("employeelist");
  27.         for(int i=0;i<sheet.getLastRowNum();i++)
  28.         {   
  29.             //get row 
  30.             HSSFRow row = sheet.getRow(i);          
  31.             for(int j=0;j<row.getLastCellNum();j++){
  32.                 //get cell
  33.                 HSSFCell cell=row.getCell((short)j);    
  34.                 /* here  get String type ,if there are other types in your sheet ,
  35.                 you can use other Cell's API,such as cell.getBooleanCellValue();
  36.                 cell.getDateCellValue();cell.getNumericCellValue();
  37.                 */
  38.                 System.out.println(i+"/"+j+" : "+cell.getStringCellValue());
  39.             }           
  40.         }       
  41.         return mapping.findForward("success");
  42.     }
  43.     
  44. }

  1. <!--Upload.jsp-->
  2. <%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>
  3. <%
  4. String path = request.getContextPath();
  5. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
  6. %>
  7. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  8. <html>
  9.   <head>
  10.     <base href="<%=basePath%>">
  11.     
  12.     <title>Upload</title>
  13.     
  14.     <meta http-equiv="pragma" content="no-cache">
  15.     <meta http-equiv="cache-control" content="no-cache">
  16.     <meta http-equiv="expires" content="0">    
  17.     <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  18.     <meta http-equiv="description" content="This is my page">
  19.     <!--
  20.     <link rel="stylesheet" type="text/css" href="styles.css">
  21.     -->
  22.   </head>
  23.   
  24.   <body>
  25.     <br>
  26.     <br>
  27.     <br>
  28.     <br>
  29.     <center>
  30.     <form action="upload.do" method="post" enctype="multipart/form-data">
  31.         Please upload your file : <input type="file" name="file">
  32.         <input type="submit" name="Submit" value="Submit">  
  33.       </form>
  34.     </center>
  35.     <br>
  36.     <br>
  37.     <br>
  38.     <br>
  39.   </body>
  40. </html>

下面为配置文件:web.xml和struts-config.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app version="2.4" 
  3.     xmlns="http://java.sun.com/xml/ns/j2ee" 
  4.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  5.     xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee 
  6.     http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
  7.     <servlet>
  8.         <servlet-name>action</servlet-name>
  9.         <servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
  10.         <init-param>
  11.             <param-name>cofig</param-name>
  12.             <param-value>/WEB-INF/struts-config.xml</param-value>
  13.         </init-param>
  14.         <load-on-startup>0</load-on-startup>
  15.     </servlet>
  16.     <servlet-mapping>
  17.         <servlet-name>action</servlet-name>
  18.         <url-pattern>*.do</url-pattern>
  19.     </servlet-mapping>
  20. </web-app>
  1. <?xml version="1.0" encoding="ISO-8859-1" ?>
  2. <!DOCTYPE struts-config PUBLIC
  3.           "-//Apache Software Foundation//DTD Struts Configuration 1.3//EN"
  4.           "http://struts.apache.org/dtds/struts-config_1_3.dtd">
  5. <struts-config>
  6.     <form-beans>   
  7.         <form-bean name="uploadForm" type="UploadForm"></form-bean>
  8.     </form-beans>
  9.     <action-mappings>   
  10.         <action path="/upload" name="uploadForm" type="UploadAction">
  11.             <forward name="success" path="/upload.jsp"></forward>
  12.         </action>
  13.     </action-mappings>
  14. </struts-config>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值