springMVC的导入导出操作

导出:

第一步:首先在前台发送一个请求,请求地址发送为@requestmapping的value

window.location.href="exportexcel.action"
第二步:后台接收请求并进行导出的操作(未使用工具类)

//    导出
    @RequestMapping("exportexcel")
    public void exportexcel(HttpServletResponse response) {
        OutputStream oStream = null;
        
        try {
//            创建工作簿
            HSSFWorkbook wb = new HSSFWorkbook();
//            创建sheet
            HSSFSheet sheet = wb.createSheet("列表");
//            创建表头
            HSSFRow row = sheet.createRow(0);
            //创建单元格
            HSSFCell cell = row.createCell(0);
            cell.setCellValue("用户名");
            HSSFCell cell1 = row.createCell(1);
            cell1.setCellValue("密码");
            HSSFCell cell2 = row.createCell(2);
            cell2.setCellValue("真实姓名");
            HSSFCell cell3 = row.createCell(3);
            cell3.setCellValue("手机号");
            User user = new User();
            List<User> list = userService.getUserList(user);
            System.out.println(list);
            for(int i=0;i<list.size();i++){
                User us = list.get(i);
                //创建表头
                HSSFRow lrow = sheet.createRow(i+1);
                //创建单元格
                HSSFCell lcell = lrow.createCell(0);
                lcell.setCellValue(us.getUser_name());
                HSSFCell lcell1 = lrow.createCell(1);
                lcell1.setCellValue(us.getPassword());
                HSSFCell lcell2 = lrow.createCell(2);
                lcell2.setCellValue(us.getName());
                HSSFCell lcell3 = lrow.createCell(3);
                lcell3.setCellValue(us.getPhone());
            }
            //根据response获取输出流
            response.setContentType("application/force-download"); // 设置下载类型
            response.setHeader("Content-Disposition","attachment;filename=sxlb.xls"); // 设置文件的名称
            oStream = response.getOutputStream(); // 输出流
            //把工作薄写入到输出流
            wb.write(oStream);
            
        } catch (Exception e) {
            // TODO: handle exception
            try {
                oStream.close();
            } catch (IOException e1) {
                e1.printStackTrace();
            }
            e.printStackTrace();
        }
        
    }
这样一来,导出就大功告成了

导入:

第一步:首先在jsp界面写一个form表单,一个文件标签(注意form表单一定要设置enctype="multipart/form-data",并且传送方式为post)

<form  enctype="multipart/form-data" method="post" action="importexcel.action">
    <input type="file">
</form>
第二步:提供一个我写的工具类,已经测试过大家可以放心使用,导入导出都可以使用

public class ExcelUtils {
    public static void main(String[] args) throws Exception {
//        List<User> list = new ArrayList<User>();
//        for (int i=0;i<10;i++) {
//            User us = new User();
//            us.setName("张三"+i);
//            us.setPhone(i+"11111111111");
//            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
//            us.setCreate_time(sdf.format(new Date()));
//            us.setUser_name(i+"wawerer@123123.com");
//            list.add(us);
//        }
//        String columnNames[] = {"姓名","电话","时间","邮箱"};
//        String columns[] = {"name","phone","create_time","user_name"};
//        exportExcelByList("D:\\wang.xls", list, columnNames, columns, "用户信息");
        String[][] mm = readexcell("D:\\wang.xls",1);
        System.out.println(123);
    }
    /**
     * 读取excel
     * @param filepath 文件路径
     * @param startrow 读取的开始行
     * @Result 返回一个二维数组(第一维放的是行,第二维放的是列表)
     * @throws Exception
     */
    public static String[][] readexcell(String filepath,int startrow) throws Exception{
        // 判断文件是否存在
        File file = new File(filepath);
        if (!file.exists()) {
            throw new IOException("文件" + filepath + "W不存在!");
        }
        //获取sheet
        Sheet sheet = getSheet(filepath);
        String[][] content = getData(startrow, sheet);
        return content;
    }
    /**
     * 读取excel
     * @param filepath 文件路径
     * @param startrow 读取的开始行
     * @Result 返回一个二维数组(第一维放的是行,第二维放的是列表)
     * @throws Exception
     */
    public static String[][] readexcellByInput(InputStream is,String fileName,int startrow) throws Exception{
        //文件后缀
        String extension = fileName.lastIndexOf(".") == -1 ? "" : fileName.substring(fileName.lastIndexOf("."));
        //获取sheet
        Sheet sheet = null;
        if (".xls".equals(extension)) {//2003
            //获取工作薄
            POIFSFileSystem fs = new POIFSFileSystem(is);
            sheet =  new HSSFWorkbook(fs).getSheetAt(0);
        } else if (".xlsx".equals(extension) || ".xlsm".equals(extension)) {
            sheet =  new XSSFWorkbook(is).getSheetAt(0);
        } else {
            throw new IOException("文件(" + fileName + "),无法识别!");
        }
        //获取表单数据
        String[][] content = getData(startrow, sheet);
        return content;
    }
    /**
     * 获取表单数据
     * wangyue
     * @param startrow
     * @param sheet
     * @return
     * 2018年4月26日下午2:25:43
     */
    private static String[][] getData(int startrow, Sheet sheet) {
        // 得到总行数
        int rowNum = sheet.getLastRowNum()+1;
        // 根据第一行获取列数
        Row row = sheet.getRow(0);
        //获取总列数
        int colNum = row.getPhysicalNumberOfCells();
        //根据行列创建二维数组
        String[][] content = new String[rowNum-startrow][colNum];
        String[] cols = null;
        //通过循环,给二维数组赋值
        for (int i = startrow; i < rowNum; i++) {
            row = sheet.getRow(i);
            cols = new String[colNum];
            for (int j = 0; j < colNum; j++) {
                //获取每个单元格的值
                cols[j] = getCellValue(row.getCell(j));
                //把单元格的值存入二维数组
                content[i - startrow][j] =cols[j];
            }
        }
        return content;
    }
    
 
 
    /**
     * 根据表名获取第一个sheet
     * @param path d:\\1213.xml
     * @return 2003-HSSFWorkbook  2007-XSSFWorkbook
     * @throws Exception 
     */
    public static Sheet getSheet(String file) throws Exception {
        //文件后缀
        String extension = file.lastIndexOf(".") == -1 ? "" : file.substring(file.lastIndexOf("."));
        //创建输入流
        InputStream is = new FileInputStream(file);
        if (".xls".equals(extension)) {//2003
            //获取工作薄
            POIFSFileSystem fs = new POIFSFileSystem(is);
            return new HSSFWorkbook(fs).getSheetAt(0);
        } else if (".xlsx".equals(extension) || ".xlsm".equals(extension)) {
            return new XSSFWorkbook(is).getSheetAt(0);
        } else {
            throw new IOException("文件(" + file + "),无法识别!");
        }
    }
      /**
     * 功能:获取单元格的值
     */
    private static String getCellValue(Cell cell) {
        Object result = "";
        if (cell != null) {
            switch (cell.getCellType()) {
            case Cell.CELL_TYPE_STRING:
                result = cell.getStringCellValue();
                break;
            case Cell.CELL_TYPE_NUMERIC:
             // 在excel里,日期也是数字,在此要进行判断 
                if(HSSFDateUtil.isCellDateFormatted(cell)){
                    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                     Date date = cell.getDateCellValue();  
                     result =  sdf.format(date); 
                }else{
                    DecimalFormat df=new DecimalFormat("#"); 
                    result=df.format(cell.getNumericCellValue());
                }
                break;
            case Cell.CELL_TYPE_BOOLEAN:
                result = cell.getBooleanCellValue();
                break;
            case Cell.CELL_TYPE_FORMULA:
                result = cell.getCellFormula();
                break;
            case Cell.CELL_TYPE_ERROR:
                result = cell.getErrorCellValue();
                break;
            case Cell.CELL_TYPE_BLANK:
                break;
            default:
                break;
            }
        }
        return result.toString();
    }
    /**
     * 导出  ---到固定文件目录
     * 根据传入List数据集合导出Excel表格 生成本地excel
     * @param file (输出流路径)d:\\123.xml
     * @param list 任何对象类型的list(数据库直接查询出的)User(id,name,age,sex)
     * @param columnNames(表头名称)(姓名、性别、年龄)
     * @param columns (表头对应的列名)(name,sex,age)注意顺序
     * @param sheetName(sheet名称)
     */
     @SuppressWarnings("rawtypes")
     public static void exportExcelByList(String file, List list,String[] columnNames, String[] columns, String sheetName) {
         OutputStream fos  =null;
         try {
            //获取输出流
             fos= new FileOutputStream(file);
            //创建工作薄HSSFWorkbook
             HSSFWorkbook wb = new HSSFWorkbook();
            //创建表单sheet
             HSSFSheet sheet = wb.createSheet(sheetName);
            //创建样式对象
             HSSFCellStyle style = wb.createCellStyle(); // 样式对象
             style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 垂直
             style.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 水平
 
 
            //创建行--表头
             HSSFRow row = sheet.createRow(0);
             for (int i = 0; i < columnNames.length; i++) {
                //创建列、单元格
                 HSSFCell cell = row.createCell(i);
                 cell.setCellValue(columnNames[i]);
                 cell.setCellStyle(style);
             }
            //创建数据列
             for (int i = 0; i < list.size(); i++) {
                 Object o = list.get(i);
                //创建行--数据
                 HSSFRow listRow = sheet.createRow(i + 1);
                //循环列字段数组
                 for (int j = 0; j < columns.length; j++) {
                    //创建列
                     HSSFCell listCell = listRow.createCell(j);
                     //根据反射调用方法
                     Method m = o.getClass().getMethod("get" + upperStr(columns[j]));
                     String value = (String) m.invoke(o);
                     if (value != null) {
                         listCell.setCellValue(value);
                         listCell.setCellStyle(style);
                     } else {
                         listCell.setCellValue("");
                         listCell.setCellStyle(style);
                     }
                     sheet.autoSizeColumn(j+1, true);//自适应,从1开始
                 }
             }
            //把工作薄写入到输出流
             wb.write(fos);
             System.out.println("生成excel成功:"+file);
         } catch (Exception e) {
             e.printStackTrace();
         }finally {
             try {
                fos.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
     }
 
 
     /**
      * 根据传入List数据集合导出Excel表格 返回页面选择保存路径的excel
      * @param response (响应页面)
      * @param list 数据列表
      * @param columnNames 表头
      * @param columns 对应列名
      * @param sheetName 
      * @param filename
      */
     @SuppressWarnings("rawtypes")
     public static void exportExcel(HttpServletResponse response,List list, String[] columnNames, String[] columns,String sheetName, String filename) {
         OutputStream fos = null;
         try {
            //响应输出流,让用户自己选择保存路径
             response.setCharacterEncoding("UTF-8");
             response.reset();//清除缓存
             response.setContentType("octets/stream");
             response.addHeader("Content-Disposition", "attachment;filename="+ new String((filename).getBytes("UTF-8"), "iso8859-1")+ ".xls");
             fos = response.getOutputStream();
 
 
             HSSFWorkbook wb = new HSSFWorkbook();
             HSSFSheet sheet = wb.createSheet(sheetName);
             HSSFCellStyle style = wb.createCellStyle(); // 样式对象
             style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 垂直
             style.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 水平
 
 
             HSSFRow row = sheet.createRow(0);
             for (int i = 0; i < columnNames.length; i++) {
                 HSSFCell cell = row.createCell(i);
                 cell.setCellValue(columnNames[i]);
                 cell.setCellStyle(style);
             }
             for (int i = 0; i < list.size(); i++) {
                 HSSFRow listRow = sheet.createRow(i + 1);
                 Object o = list.get(i);
                 for (int j = 0; j < columns.length; j++) {
                     HSSFCell listCell = listRow.createCell(j);
                     Method m = o.getClass().getMethod("get" + upperStr(columns[j]));
                     String value = (String) m.invoke(o);
                     if (value != null) {
                         listCell.setCellValue(value + "");
                         listCell.setCellStyle(style);
                     } else {
                         listCell.setCellValue("");
                         listCell.setCellStyle(style);
                     }
                     sheet.autoSizeColumn(j+1, true);//自适应,从1开始
                 }
             }
             wb.write(fos);
         } catch (Exception e) {
             e.printStackTrace();
         } finally {
             try {
                fos.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
     }
     /**
      * 把输入字符串的首字母改成大写
      * 
      * @param str
      * @return
      */
     private static String upperStr(String str) {
         char[] ch = str.toCharArray();
         if (ch[0] >= 'a' && ch[0] <= 'z') {
             ch[0] = (char) (ch[0] - 32);
         }
         return new String(ch);
     }
     /**
      * 海量数据导出 100万以上
      * wangyue
      * @param response 直接响应到浏览器
      * @param list 数据列表
      * @param columnNames 表头数组
      * @param columns 和表头数组对应的字段数组
      * @param sheetName sheet表单名称
      * @param filename  工作薄名称
      * 2018年4月26日下午1:53:29
      */
     public static void exportBigData(HttpServletResponse response,List list, String[] columnNames, String[] columns,String sheetName, String filename){
 
 
        OutputStream os = null;
        try {
            response.setContentType("application/force-download"); // 设置下载类型
            response.setHeader("Content-Disposition","attachment;filename=" + filename); // 设置文件的名称
            os = response.getOutputStream(); // 输出流
            SXSSFWorkbook wb = new SXSSFWorkbook(1000);//内存中保留 1000 条数据,以免内存溢出,其余写入 硬盘
            //获得该工作区的第一个sheet   
            Sheet sheet1 = wb.createSheet(sheetName); 
            int excelRow = 0;
            //标题行
            Row titleRow = (Row) sheet1.createRow(excelRow++);
            for (int i = 0; i < columns.length; i++) {
                Cell cell = titleRow.createCell(i);  
                cell.setCellValue(columns[i]);
            }
            
            if (list!= null && list.size() > 0) {
                for (int i = 0; i < list.size(); i++) {
                    //明细行
                    Row contentRow = (Row) sheet1.createRow(excelRow++);
                    List<String> reParam = (List<String>) list.get(i);
                    for (int j = 0; j < reParam.size(); j++) {
                        Cell cell = contentRow.createCell(j);  
                        cell.setCellValue(reParam.get(j));
                    }
                }
            }
            wb.write(os);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                if (os != null) {
                    os.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            } // 关闭输出流
        }
     }
 
 
}
第三步:controller层接收请求并进行处理

//    导入
    @RequestMapping("importexcel")
    @ResponseBody
    public Map<String,Object> importexcel(MultipartFile file){
        Map<String,Object> map = new HashMap<String, Object>();
        try {
            //用工具类
            String[][] data = ExcelUtils.readexcellByInput(file.getInputStream(), file.getOriginalFilename(), 1);
            for(int i=0;i<data.length;i++){
                User user = new User();
                user.setUser_name(data[i][0]+"02");
                user.setPassword(data[i][1]);
                user.setName(data[i][2]);
                user.setPhone(data[i][3]);
                userService.save(user, null);//这是一个添加方法,dao层写入sql语句即可
            }
            map.put("success", true);
            
        }catch (Exception e) {
            e.printStackTrace();
            map.put("success", false);
            map.put("errmsg", e.getMessage());
        }
        
        return map;
    }
这样一来导入也大功告成了。

希望我的博客能够帮助到大家,还希望大家多多点评。
--------------------- 
作者:Romantic_321 
来源:CSDN 
原文:https://blog.csdn.net/romantic_321/article/details/80917941 
版权声明:本文为博主原创文章,转载请附上博文链接!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值