Servlet+POI导入Excel文件

Servlet+poi导入
ps:相关jar包在文末给出免费获取地址

页面:

<form action="/web05_import/importExcel2" method="post" enctype="multipart/form-data">
		上传文件:<br> <input type="file" " name="excel"
			id="impFile"> <br> <input type="submit" value="导入">
	</form>

工具类:

ParseExcel.java

package util;

import java.io.IOException;
import java.io.InputStream;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFDataFormat;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class ParseExcel {

	/*
	 * 解析文件的方法
	 * imputStream 文件输入流,要解析的Excel文件输入流
	 * suffix 文件后缀名,xls或xlsx,代码决定使用什么方式解析Excel
	 * startRow 从第几行开始读取数据
	 * List<String[]>集合中的一个元素对应一行解析的数据,元素为字符串数组类型数组中的每个元素对应一列数据。
	 * */
	public List<String[]> parseExcel(InputStream inputStream,String suffix,int startRow) throws IOException{
		// 1. 定义excel对象变量
				Workbook workbook = null;
				
				// 2. 判断后缀.决定使用的解析方式. 决定如何创建具体的对象
				if("xls".equals(suffix)){
					// 2003
					workbook = new HSSFWorkbook(inputStream);
				}else if("xlsx".equals(suffix)){
					// 2007
					workbook = new XSSFWorkbook(inputStream);
				}else{
					// 未知内容
					return null;
				}
				
				// 获取工作表  excel分为若干个表. sheet
				Sheet sheet = workbook.getSheetAt(0);
				
				if(sheet == null){
					return null;
				}
				
				// 获取表格中最后一行的行号
				int lastRowNum = sheet.getLastRowNum();
				
				// 最后一行的行号大于startRow
				if(lastRowNum <= startRow){
					return null;
				}
				
				
				List<String[]> result = new ArrayList<String[]>();
				
				// 定义行变量和单元格变量
				Row row = null;
				Cell cell = null;
				// 循环读取
				for(int rowNum = startRow; rowNum <= lastRowNum; rowNum++){
					row = sheet.getRow(rowNum);
					// 获取当前行的第一列和最后一列的标记
					short firstCellNum = row.getFirstCellNum();
					short lastCellNum = row.getLastCellNum();
					if(lastCellNum != 0){
						String[] rowArray = new String[lastCellNum];
						for(int cellNum = firstCellNum; cellNum < lastCellNum; cellNum++){
							cell = row.getCell(cellNum);
							// 判断单元格是否有数据
							if(cell == null){
								rowArray[cellNum] = null;
							}else{
								rowArray[cellNum] = parseCell(cell);
							}
						}
						result.add(rowArray);
					}
				}
				
				return result;
	}
	
	/**
	 * 解析单元格
	 * @return String 单元格数据
	 */
	private String parseCell(Cell cell){
		String cellStr = null;
		
		// 判断单元格的类型
		switch(cell.getCellType()){
			case HSSFCell.CELL_TYPE_STRING :
				// 字符串类型单元格
				cellStr = cell.getRichStringCellValue().toString();
				break;
			case HSSFCell.CELL_TYPE_BLANK : 
				// 空数据, 标准数据
				cellStr = "";
				break;
			case HSSFCell.CELL_TYPE_NUMERIC :
				// 数学类型. 数学类型包含日期,时间,数字
				// 判断日期[年月日2016-11-17 | 时分10:00]类型
				if(HSSFDateUtil.isCellDateFormatted(cell)){
					// 判断具体类型, 是日期还是时间
					SimpleDateFormat sdf = null;
					if(cell.getCellType() == HSSFDataFormat.getBuiltinFormat("h:mm")){
						// 时间
						sdf = new SimpleDateFormat("HH:mm");
					}else{
						// 日期
						sdf = new SimpleDateFormat("yyyy-MM-dd");
					}
					Date temp = cell.getDateCellValue();
					cellStr = sdf.format(temp);
				}else{
					// 数字
					double temp = cell.getNumericCellValue();
					// 数学格式化工具
					DecimalFormat format = new DecimalFormat();
					// 查看单元格中的具体样式类型
					String formatStr = cell.getCellStyle().getDataFormatString();
					if(formatStr.equals("General")){
						// 定义格式化正则. 使用具体有效数据进行个时候.且只保留有效数据.
						format.applyPattern("#");
					}
					cellStr = format.format(temp);
				}
				break;
			default : 
				cellStr = "";
		}
		
		return cellStr;
	}
}

Servlet:

ImportExcel2.java

package servlet;

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Arrays;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;

import util.ParseExcel;
@MultipartConfig
public class ImportExcel2 extends HttpServlet{
	public void doGet(HttpServletRequest request,HttpServletResponse response) 
			throws ServletException,IOException {
		doPost(request , response);
	}
	
	protected void doPost(HttpServletRequest request,HttpServletResponse response)
			throws ServletException,IOException{
		request.setCharacterEncoding("UTF-8");
		//文件上传
        //首先要在Servlet上用 @MultipartConfig 标识支持文件上传
        //获取part对象 参数为name属性的值
        Part part = request.getPart("excel");
        //Servlet3没有提供直接获取文件名的方法,需要从请求头中解析出来
        //获取文件名
        String fileName = getFileName(part);
        
        //获取数据的流
        InputStream inputStream = part.getInputStream();
        System.out.println("获取到流");
	     ParseExcel parser = new ParseExcel();
	     
	     String[] suffix = fileName.split("\\.");
	     int startRow = 1;
	     String s = suffix[1];
	     
	     List<String[]> result = parser.parseExcel(inputStream, s, startRow);
	     //result里的数据即为excel文件中的数据
	     for(String[] ss : result){
	    	 System.out.println(Arrays.toString(ss));
	     }
	}
	
	private String getFileName(Part part) {
		String head = part.getHeader("Content-Disposition");
		String fileName = head.substring(head.indexOf("filename=\"") + 10,
				head.lastIndexOf("\""));
		return fileName;
	}
}

web.xml

<servlet>
  	<servlet-name>importExcel2</servlet-name>
  	<servlet-class>servlet.ImportExcel2</servlet-class>
  </servlet>
  <servlet-mapping>
  	<servlet-name>importExcel2</servlet-name>
  	<url-pattern>/importExcel2</url-pattern>
  </servlet-mapping>

相关jar包:
在这里插入图片描述

jar包获取地址:免费jar包获取

excel模板:(一行标题)
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值