`
tayuexiaotian
  • 浏览: 24888 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

POI读取Excel

阅读更多
package servlet;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
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;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
/**author:wx
* describe:Reads the Excel example
* */
public class ReadExcel extends HttpServlet {
    /**
     *
     */
    private static final long serialVersionUID = 1L;
    /**
     * Constructor of the object.
     */
    public ReadExcel() {
        super();
    }
    /**
     * Destruction of the servlet. <br>
     */
    public void destroy() {
        super.destroy(); // Just puts "destroy" string in log
        // Put your code here
    }
    /**
     * The doGet method of the servlet. <br>
     *
     * This method is called when a form has its tag value method equals to get.
     *
     * @param request
     *            the request send by the client to the server
     * @param response
     *            the response send by the server to the client
     * @throws ServletException
     *             if an error occurred
     * @throws IOException
     *             if an error occurred
     */
    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        doPost(request, response);
    }
    /**
     * The doPost method of the servlet. <br>
     *
     * This method is called when a form has its tag value method equals to
     * post.
     *
     * @param request
     *            the request send by the client to the server
     * @param response
     *            the response send by the server to the client
     * @throws ServletException
     *             if an error occurred
     * @throws IOException
     *             if an error occurred
     */
    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        response.setContentType("text/html;charset=gb2312");
        PrintWriter out = response.getWriter();
        String filePath = new String(request.getParameter("file").getBytes(
                "ISO-8859-1"), "gb2312");
       
        out.print("文件路径:"+filePath+"<br>");
        try {
            POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream(
                    filePath));
            // 创建工作簿
            HSSFWorkbook workBook = new HSSFWorkbook(fs);
            /**
             * 获得Excel中工作表个数
             */
            out.println("工作表个数 :"+workBook.getNumberOfSheets()+"<br>");
            for (int i = 0; i < workBook.getNumberOfSheets(); i++) {
               
                out.println("<font color='red'> "+i+" ***************工作表名称:"+workBook.getSheetName(i)+"  ************</font><br>");
                // 创建工作表
                HSSFSheet sheet = workBook.getSheetAt(i);
                int rows = sheet.getPhysicalNumberOfRows(); // 获得行数
                if (rows > 0) {
                    sheet.getMargin(HSSFSheet.TopMargin);
                    for (int j = 0; j < rows; j++) { // 行循环
                        HSSFRow row = sheet.getRow(j);
                        if (row != null) {
                            int cells = row.getLastCellNum();//获得列数
                            for (short k = 0; k < cells; k++) { // 列循环
                                HSSFCell cell = row.getCell(k);
                                // /////////////////////
                                if (cell != null) {
                                    String value = "";
                                    switch (cell.getCellType()) {
                                    case HSSFCell.CELL_TYPE_NUMERIC: // 数值型
                                         if (HSSFDateUtil.isCellDateFormatted(
                                         cell)) {
                                         //如果是date类型则 ,获取该cell的date值
                                         value = HSSFDateUtil.getJavaDate(
                                         cell.getNumericCellValue()).
                                         toString();
                                         out.println("第"+j+"行,第"+k+"列值:"+value+"<br>");
                                         }else{//纯数字
                                        
                                        value = String.valueOf(cell
                                                .getNumericCellValue());
                                        out.println("第"+j+"行,第"+k+"列值:"+value+"<br>");
                                         }
                                        break;
                                    /* 此行表示单元格的内容为string类型 */
                                    case HSSFCell.CELL_TYPE_STRING: // 字符串型
                                        value = cell.getRichStringCellValue()
                                                .toString();
                                        out.println("第"+j+"行,第"+k+"列值:"+value+"<br>");
                                        break;
                                    case HSSFCell.CELL_TYPE_FORMULA://公式型
                                        //读公式计算值
                                         value = String.valueOf(cell.getNumericCellValue());
                                         if(value.equals("NaN")){//如果获取的数据值为非法值,则转换为获取字符串
                                            
                                             value = cell.getRichStringCellValue().toString();
                                         }
                                         //cell.getCellFormula();读公式
                                         out.println("第"+j+"行,第"+k+"列值:"+value+"<br>");
                                    break;
                                    case HSSFCell.CELL_TYPE_BOOLEAN://布尔
                                         value = " "
                                         + cell.getBooleanCellValue();
                                         out.println("第"+j+"行,第"+k+"列值:"+value+"<br>");
                                     break;
                                    /* 此行表示该单元格值为空 */
                                    case HSSFCell.CELL_TYPE_BLANK: // 空值
                                        value = "";
                                        out.println("第"+j+"行,第"+k+"列值:"+value+"<br>");
                                        break;
                                    case HSSFCell.CELL_TYPE_ERROR: // 故障
                                        value = "";
                                        out.println("第"+j+"行,第"+k+"列值:"+value+"<br>");
                                        break;
                                    default:
                                        value = cell.getRichStringCellValue().toString();
                                    out.println("第"+j+"行,第"+k+"列值:"+value+"<br>");
                                    }
                                   
                                }
                            }
                        }
                    }
                }
            }
        } catch (Exception ex) {
            ex.printStackTrace();
        }
        out.print("<script>alert('解析完毕');</script>");
        out.flush();
        out.close();
    }
    /**
     * Initialization of the servlet. <br>
     *
     * @throws ServletException
     *             if an error occurs
     */
    public void init() throws ServletException {
        // Put your code here
    }
}
下面是前台jsp页面:

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
   
    <title>My JSP 'index.jsp' starting page</title>
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">   
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
    <!--
    <link rel="stylesheet" type="text/css" href="styles.css">
    -->
  </head>
 
  <body>
    This is my JSP page. <br>
    <form action="ReadExcel" method="post">
        上传附件:<input type="file" name="file"><br>
        <input type="submit" value="开始解析">
    </form>
    <br><br><br>
    <form action="ToExcel">
        <input type="submit" value="导出Excel">
    </form>
  </body>
</html>
分享到:
评论

相关推荐

    利用POI读取excel写入到word

    要实现"利用POI读取excel写入到word",我们需要以下步骤: 1. **准备环境**:首先,确保你的项目已经引入了Apache POI的依赖。在给定的压缩包中,"poi - 副本"可能是包含POI库的JAR文件,你需要将其添加到你的项目...

    poi读取excel文件

    Apache POI提供了丰富的API,可以实现对Excel文件的复杂操作,如合并单元格、设置样式、处理公式等。在Android开发中,这些功能同样适用,但需要注意资源管理,因为Android设备的内存有限。 总的来说,Apache POI是...

    poi读取excel并输出到jsp页面

    标题中的“poi读取excel并输出到jsp页面”是指使用Apache POI库来处理Microsoft Excel文件,并将数据在JavaServer Pages (JSP) 页面上显示的技术。Apache POI 是一个开源项目,它允许开发者创建、修改和显示MS ...

    android5使用poi读取excel

    android5使用poi读取excel,android5使用poi读取excel,android5使用poi读取excel,android5使用poi读取excel

    android POI 读取excel 精简jar

    Apache POI提供对Microsoft Office格式的全面支持,包括Excel的.xlsx格式。此精简版可能是为了减小Android应用的体积和提高性能,移除了不必要的部分,但仍保留了读取Excel文件的核心功能。 3. **aa-poi-ooxml-...

    poi读取excel文件实例(兼容excel2007)

    在“poi读取excel文件实例”中,我们将讨论如何使用Apache POI API来读取和操作Excel 2007文件。以下是一些关键知识点: 1. **创建工作簿对象**:首先,你需要通过`WorkbookFactory`类的`create()`方法打开或创建一...

    POI读取excel的内容.zip

    本教程将详细讲解如何使用Apache POI库来读取Excel文件的内容。 首先,为了在Java项目中使用Apache POI,我们需要通过Maven进行依赖管理。在`pom.xml`文件中添加以下依赖: ```xml &lt;groupId&gt;org.apache.poi ...

    poi读取Excel用到的jar包

    标题提到的“poi读取Excel用到的jar包”指的是在Java项目中使用POI库进行Excel操作所需引入的依赖文件。这些jar包在描述中给出,包括了以下几个: 1. poi-ooxml-schemas-3.8-beta5-20111217.jar:这个文件包含了...

    poi 读取excel小实例

    实现了JAVA 窗口,读取EXCEL文件,用poi读取EXCEL内容只是一个小例子

    apache POI 读取 Excel

    apache poi 读取 Excel 的 jar 包 博文链接:https://wxinpeng.iteye.com/blog/231895

    POI读取Excel带格式数据

    本篇将详细讲解如何使用Apache POI读取Excel文件中的带格式数据。 首先,理解Apache POI的基本架构至关重要。POI提供了HSSF(Horrible Spreadsheet Format)用于处理老版本的.xls文件,而XSSF用于处理较新的.xlsx...

    POI生成Excel POI操作Excel POI读取Excel POI类库

    **POI读取Excel** 读取Excel主要涉及以下步骤: 1. **打开Workbook**:通过 FileInputStream 读取Excel文件,然后创建Workbook对象。 2. **获取Sheet**:从Workbook中获取需要的Sheet。 3. **遍历Row和Cell**:...

    java POI读取excel文件数据

    在这个场景中,我们将详细探讨如何使用Java POI读取Excel文件中的数据,包括获取总行数、列数、单元格内容、合并单元格、行高、列宽以及图片等信息。 首先,确保在项目中已经引入了Apache POI的依赖库。如果你使用...

    poi读取excel并校验小例子

    在"poi读取excel并校验小例子"中,我们可能首先创建一个`XSSFWorkbook`实例来打开Excel文件,然后通过工作表索引获取对应的`XSSFSheet`对象。例如: ```java FileInputStream fis = new FileInputStream("example....

    poi读取excel2007和2003兼容工具例子

    在这个"poi读取excel2007和2003兼容工具例子"中,我们将探讨如何使用POI来读取不同版本的Excel文件,特别是Excel 2003(.xls)和Excel 2007及更高版本(.xlsx)。 1. **Apache POI库**:Apache POI是Apache软件基金...

    POI读取excel的例子

    POI读取excel的例子

    POI读取Excel合并单元格并储存

    本文将深入探讨如何使用Java的Apache POI库来读取Excel文件,并处理其中合并单元格的数据,同时将这些数据存储到实体类中以供后续使用。 Apache POI是一个强大的库,允许程序员使用Java来创建、修改和显示Microsoft...

    POI读取EXCEL教程

    在Java编程环境中,如果你需要读取或写入Excel文件,POI 提供了强大的支持。本教程将深入讲解如何使用POI的HSSF组件来处理Excel 97-2003格式的文件(BIFF8格式)。 一、Excel基础 Excel 97 文件格式,也被称作BIFF8...

    ExcelUtil借助反射和POI对Excel读取,省略了以往读取Excel的繁琐步骤

    本篇将详细讲解如何利用Java的开源库Apache POI,结合反射机制,通过ExcelUtil工具类简化Excel读取的过程。 Apache POI是一个强大的库,它允许Java程序员创建、修改和展示MS Office格式的文件,包括Excel。在传统的...

Global site tag (gtag.js) - Google Analytics