热门课程

免费试听

上课方式

开班时间

当前位置: 首页 -   文章 -   新闻动态 -   正文

Java用poi导入导出Excel

知了堂姐
2024-07-09 11:12:24
0

前言

1、将用户信息导出为excel表格(导出数据….)

2、将Excel表中的信息录入到网站数据库(习题上传….)

开发中经常会设计到excel的处理,如导出Excel,导入Excel到数据库中!

操作Excel目前比较流行的就是 Apache POI 和 阿里巴巴的 easyExcel !

接下来说说Apache下的POI吧


    
    
        org.apache.poi
        poi
        3.9
    
    
    
        org.apache.poi
        poi-ooxml
        3.9
    
    
    
        joda-time
        joda-time
        2.10.1
    
    
    
        junit
        junit
        4.12
    

注意:

1、jar包需要保持版本(version)一样

2、2003 版本和 2007 版本存在兼容性的问题!03版本最多只有 65536 行!07版本没有限制

2、Excel导入

public void importExcel(@RequestParam("file") MultipartFile multipartFile) {
        //MultipartFile转换成File
        File file=MultipartFile2FileUtil.MultipartFile2File(multipartFile);
        //需要解析的Excel文件
        try {
            //获取工作簿
            /**
             * 构造函数获取一个FileInputStream对象
             * FileUtils.openInputStream 调用了 FileInputStream 的构造函数去打开一个文件(open0是一个本地方法,打开指定文件进行读取)
             * 对FileInputStream中的open调用open0方法---> https://blog.csdn.net/zhlily1/article/details/109468154
             */
            FileInputStream fs = FileUtils.openInputStream(file);
            XSSFWorkbook workbook = new XSSFWorkbook(fs);
            //获取最Excel中的sheet数量
            int numberOfSheets = workbook.getNumberOfSheets();
            for (int j=0;j list = new ArrayList<>();
                //注:row为行   cell为列
                for (int i = first; i <= last; i++) {
                    XSSFRow row = hs.getRow(i);
                    String cell1=new String();
                    //可以在这里遍历row,获取当前行每列的数据
                    if (!StringUtil.isNullOrEmpty(cell1)) {
                        try {
                            cell1=row.getCell(1).getStringCellValue();
                        }catch (Exception e){
                            cell1=String.valueOf(row.getCell(1).getNumericCellValue());
                        }
                    }
                }
                String name = hs.getSheetName();
                equipmentAuditContentService.importEquipmentAuditContent(name, list);
            }
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        //清空文件缓存,并且调用delete0关闭文件
        MultipartFile2FileUtil.deleteFile(file);
    }

3、MultipartFile2FileUtil工具类

public class MultipartFile2FileUtil {
    /**
     * MultipartFile转换为File
     * @param multipartFile
     * @return
     * MultipartFile继承了InputStreamSource
     */
    public static File MultipartFile2File(MultipartFile multipartFile){
        //文件上传前的名称
        String fileName = multipartFile.getOriginalFilename();
        //new 一个 file
        File file = new File(fileName);
        OutputStream out = null;
        try{
            //获取文件流,以文件流的方式输出到新文件 
//    InputStream in = multipartFile.getInputStream();
            //获取到一个file的输出流
            out = new FileOutputStream(file);
            //获取multipartFile的字节文件,并将字节文件遍历write到out输出流
            byte[] ss = multipartFile.getBytes();
            for(int i = 0; i < ss.length; i++){
                out.write(ss[i]);
            }
        }catch(IOException e){
            e.printStackTrace();
        }finally {
            //进行判断关闭输出流
            if (out != null){
                try {
                    out.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        return file;
    }
    public static void deleteFile(File file){
        File f = new File(file.toURI());
        f.delete();
    }
}

4、导出Excel

public ApiResult exportAuditContent(HttpServletResponse response, @RequestBody ExportAuditContentIds exportAuditContentIds){
        OutputStream outputStream = tryCatch2gGetOutput(response);
        List entitys=dao.getEntitys();
        HSSFWorkbook workbook = new HSSFWorkbook();
        //headers
        String[] headers=new String[]{"表头1","表头2","表头3"};
        int sheetNum=0;
        //遍历查到的list
        for (Entity entity : entitys) {
            List> result=new ArrayList<>();
            //sheetName
            String sheetTitle=entity.getSheetName();
            for (entity exportAuditContent : auditContent.getContentName()) {
                List str=new ArrayList<>();
                str.add(exportAuditContent.getXXX());
                str.add(exportAuditContent.getXXX());
                str.add(exportAuditContent.getXXX());
                result.add(str);
            }
                ExcelForMoreSheet.exportExcel(workbook,sheetNum,sheetTitle,headers,result,outputStream);
            sheetNum++;
        }
        try {
            workbook.write(outputStream);
            outputStream.close();
        } catch (Exception e) {
            throw new AnyException("导出出错");
        }
        return success("导出成功","成功");
    }

5、tryCatch2gGetOutput

private OutputStream tryCatch2gGetOutput(HttpServletResponse response){
        try {
            OutputStream output = response.getOutputStream();
            response.reset();
            String filename = "title"+new SimpleDateFormat("yyyy-MM-dd").format(new Date()) +".xls";
            response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
            response.setHeader("Content-Disposition", "attachment;filename="
                    .concat(String.valueOf(URLEncoder.encode(filename, "UTF-8"))));
            response.setHeader("Access-Control-Allow-Origin", "*");
            response.setHeader("Cache-Control", "no-cache");
            return output;
        } catch (Exception e) {
            throw new AnyException("导出出错");
        }
    }

6、Excel导出工具类

package com.troo;

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;
import org.joda.time.DateTime;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
public class ExcelForMoreSheet {
    /**
     * @Title: exportExcel
     * @Description: 导出Excel的方法
     * @author: evan @ 2014-01-09
     * @param workbook
     * @param sheetNum (sheet的位置,0表示第一个表格中的第一个sheet)
     * @param sheetTitle  (sheet的名称)
     * @param headers    (表格的标题)
     * @param result   (表格的数据)
     * @param out  (输出流)
     * @throws Exception
     */
    public static void exportExcel(HSSFWorkbook workbook, int sheetNum,
                            String sheetTitle, String[] headers, List> result,
                            OutputStream out)  {
        // 生成一个表格
        HSSFSheet sheet = workbook.createSheet();
        workbook.setSheetName(sheetNum, sheetTitle);
        // 设置表格默认列宽度为20个字节
        sheet.setDefaultColumnWidth((short) 20);
        // 生成一个样式
        HSSFCellStyle style = workbook.createCellStyle();
        // 设置这些样式
        style.setFillForegroundColor(HSSFColor.PALE_BLUE.index);
        style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
        style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
        style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
        style.setBorderRight(HSSFCellStyle.BORDER_THIN);
        style.setBorderTop(HSSFCellStyle.BORDER_THIN);
        style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
        // 生成一个字体
        HSSFFont font = workbook.createFont();
        font.setColor(HSSFColor.BLACK.index);
        font.setFontHeightInPoints((short) 12);
        font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
        // 把字体应用到当前的样式
        style.setFont(font);
        // 指定当单元格内容显示不下时自动换行
        style.setWrapText(true);
        // 产生表格标题行
        HSSFRow row = sheet.createRow(0);
        for (int i = 0; i < headers.length; i++) {
            HSSFCell cell = row.createCell((short) i);
            cell.setCellStyle(style);
            HSSFRichTextString text = new HSSFRichTextString(headers[i]);
            cell.setCellValue(text.toString());
        }
        // 遍历集合数据,产生数据行
        if (result != null) {
            int index = 1;
            for (List m : result) {
                row = sheet.createRow(index);
                int cellIndex = 0;
                for (String str : m) {
                    HSSFCell cell = row.createCell((short) cellIndex);
                    if (str==null){
                        str="";
                    }
                    cell.setCellValue(str.toString());
                    cellIndex++;
                }
                index++;
            }
        }
    }
}

7、Entity类

public class Entity{
    private String sheetName;
    private List subEntitys;
}
public class ExportAuditContent {
    private String param1;
    private String param2;
    private String param3;
}

8、03版测试

String PATH = "D:\\idea.webProject\\26";
@Test
public void testWrite03() throws Exception {
    // 1、创建一个工作簿
    Workbook workbook = new HSSFWorkbook();
    // 2、创建一个工作表
    Sheet sheet = workbook.createSheet("统计表");
    // 3、创建一个行  (1,1)
    Row row1 = sheet.createRow(0);
    // 4、创建一个单元格
    Cell cell11 = row1.createCell(0);
    cell11.setCellValue("今日新增");
    // (1,2)
    Cell cell12 = row1.createCell(1);
    cell12.setCellValue(666);
    // 第二行 (2,1)
    Row row2 = sheet.createRow(1);
    Cell cell21 = row2.createCell(0);
    cell21.setCellValue("统计时间");
    // (2,2)
    Cell cell22 = row2.createCell(1);
    String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");
    cell22.setCellValue(time);
    // 生成一张表(IO 流)  03 版本就是使用 xls结尾!
    FileOutputStream fileOutputStream = new FileOutputStream(PATH + "zh03.xls");
    // 输出
    workbook.write(fileOutputStream);
    // 关闭流
    fileOutputStream.close();
    System.out.println("zh03 生成完毕!");
}

9、07版测试

@org.junit.Test
    public void testWrite07() throws IOException {
        //1、创建一个工作簿
         Workbook workbook = new XSSFWorkbook();
         //2、创建一个工作表
        Sheet sheet = workbook.createSheet("统计表");
        //3、创建一个行(1,1)
        Row row1=sheet.createRow(0);
        //4、创建一个单元格
        Cell cell11 = row1.createCell(0);
        cell11.setCellValue("今日新增");

        Cell cell12 = row1.createCell(1);
        cell12.setCellValue("今日无增");

        //创建一个行(2,1)
        Row row2 = sheet.createRow(1);
        //创建一个单元格
        Cell cell21 = row2.createCell(0);
        cell21.setCellValue("统计时间");

        Cell cell22 = row2.createCell(1);
        String time = new DateTime().toString("yyyy-mm-dd HH:mm:ss");
        cell22.setCellValue(time);

        //生成一张表 io流  注意这里是07版本
        FileOutputStream fileOutputStream = new FileOutputStream(path+"java07.xlsx");
        workbook.write(fileOutputStream);
        //关闭流
        fileOutputStream.close();
        System.out.println("07版本文件生成完毕");
    }

测试成功!

10、总结:

在ApachePoi 官方提供了对操作大数据量的导入导出的工具和解决办法,操作Excel2007使用XSSF对象,可以分为三种模式:

  • 用户模式:用户模式有许多封装好的方法操作简单,但创建太多的对象,非常耗内存(之前使用的方法)
  • 事件模式:基于SAX方式解析XML,SAX全称Simple API for XML,它是一个接口,也是一个软件包。它是一种XML解析的替代方法,不同于DOM解析XML文档时把所有内容一次性加载到内存中的方式,它逐行扫描文档,一边扫描,一边解析。
  • SXSSF对象:是用来生成海量excel数据文件,主要原理是借助临时存储空间生成excel



以上便是关于Java用poi导入导出Excel相关内容啦,若想了解更多技术干货可联系知了小姐姐哦~

预约申请试听课
大家都在看

互联网主要的传输协议是哪些?常用的是什么?

2024-07-09 浏览次数:0

零基础想做网络安全工程师,自学一般要学多久?

2024-07-09 浏览次数:0

成都前端全栈培训费用是多少?一般人都不知道的内部...

2024-07-09 浏览次数:0

选择成都汇智知了堂,选靠谱的网络安全培训机构

2024-07-09 浏览次数:0

0基础怎么学网络安全?两种方式让你随心学

2024-07-09 浏览次数:0

UI设计可以自学吗?UI设计需要去培训吗?

2024-07-09 浏览次数:0
最新资讯
中间件技术之消息队列   01、学习中间件的方式和技巧  1:理解中间件在项目架构中的作用,以及各中间件的底层实现。 2:...
专科生通过Java培训班可以成...   作为一门在全球火了二十几年的编程语言,全球的软件开发工程师有将近2000万人,而Java开发工程...
专业的Java技术培训机构哪家...   对于很多零基础想要学习Java的小伙伴来讲,因为自己本身没有任何基础所以在前期Java培训机构的...
转行学java怎么样?到底有没...   Java语言是目前世界上最流行的开发语言,也是大多数企业使用的开发语言,所以现在很多人都想改用J...
转行Java需要培训吗?想转行...   转行Java需要培训吗?很多人工作一两年后发现Java这个岗位工资高,所以都想转,但是发现技术要...
自学基本做不成java是真的吗...   自学基本做不成java是真的吗?有些人觉得Java培训费用太贵,所以选择自学,但是最后却发现依然...
自学Java,如何提升项目经验   学Java,提升能力最直接的办法就是实战,特别是在初学期间,积累代码量格外重要。很多自学Java...
自学Java如何快速入门?能找...   Java作为编程入门语言,通用性强,广泛应用于网站、游戏控制台、APP开发、大数据、云计算等,据...
org.apache.poi poi 3.9 org.apache.poi poi-ooxml 3.9 joda-time joda-time 2.10.1 junit junit 4.12

注意:

1、jar包需要保持版本(version)一样

2、2003 版本和 2007 版本存在兼容性的问题!03版本最多只有 65536 行!07版本没有限制

2、Excel导入

public void importExcel(@RequestParam("file") MultipartFile multipartFile) {
        //MultipartFile转换成File
        File file=MultipartFile2FileUtil.MultipartFile2File(multipartFile);
        //需要解析的Excel文件
        try {
            //获取工作簿
            /**
             * 构造函数获取一个FileInputStream对象
             * FileUtils.openInputStream 调用了 FileInputStream 的构造函数去打开一个文件(open0是一个本地方法,打开指定文件进行读取)
             * 对FileInputStream中的open调用open0方法---> https://blog.csdn.net/zhlily1/article/details/109468154
             */
            FileInputStream fs = FileUtils.openInputStream(file);
            XSSFWorkbook workbook = new XSSFWorkbook(fs);
            //获取最Excel中的sheet数量
            int numberOfSheets = workbook.getNumberOfSheets();
            for (int j=0;j list = new ArrayList<>();
                //注:row为行   cell为列
                for (int i = first; i <= last; i++) {
                    XSSFRow row = hs.getRow(i);
                    String cell1=new String();
                    //可以在这里遍历row,获取当前行每列的数据
                    if (!StringUtil.isNullOrEmpty(cell1)) {
                        try {
                            cell1=row.getCell(1).getStringCellValue();
                        }catch (Exception e){
                            cell1=String.valueOf(row.getCell(1).getNumericCellValue());
                        }
                    }
                }
                String name = hs.getSheetName();
                equipmentAuditContentService.importEquipmentAuditContent(name, list);
            }
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        //清空文件缓存,并且调用delete0关闭文件
        MultipartFile2FileUtil.deleteFile(file);
    }

3、MultipartFile2FileUtil工具类

public class MultipartFile2FileUtil {
    /**
     * MultipartFile转换为File
     * @param multipartFile
     * @return
     * MultipartFile继承了InputStreamSource
     */
    public static File MultipartFile2File(MultipartFile multipartFile){
        //文件上传前的名称
        String fileName = multipartFile.getOriginalFilename();
        //new 一个 file
        File file = new File(fileName);
        OutputStream out = null;
        try{
            //获取文件流,以文件流的方式输出到新文件 
//    InputStream in = multipartFile.getInputStream();
            //获取到一个file的输出流
            out = new FileOutputStream(file);
            //获取multipartFile的字节文件,并将字节文件遍历write到out输出流
            byte[] ss = multipartFile.getBytes();
            for(int i = 0; i < ss.length; i++){
                out.write(ss[i]);
            }
        }catch(IOException e){
            e.printStackTrace();
        }finally {
            //进行判断关闭输出流
            if (out != null){
                try {
                    out.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        return file;
    }
    public static void deleteFile(File file){
        File f = new File(file.toURI());
        f.delete();
    }
}

4、导出Excel

public ApiResult exportAuditContent(HttpServletResponse response, @RequestBody ExportAuditContentIds exportAuditContentIds){
        OutputStream outputStream = tryCatch2gGetOutput(response);
        List entitys=dao.getEntitys();
        HSSFWorkbook workbook = new HSSFWorkbook();
        //headers
        String[] headers=new String[]{"表头1","表头2","表头3"};
        int sheetNum=0;
        //遍历查到的list
        for (Entity entity : entitys) {
            List> result=new ArrayList<>();
            //sheetName
            String sheetTitle=entity.getSheetName();
            for (entity exportAuditContent : auditContent.getContentName()) {
                List str=new ArrayList<>();
                str.add(exportAuditContent.getXXX());
                str.add(exportAuditContent.getXXX());
                str.add(exportAuditContent.getXXX());
                result.add(str);
            }
                ExcelForMoreSheet.exportExcel(workbook,sheetNum,sheetTitle,headers,result,outputStream);
            sheetNum++;
        }
        try {
            workbook.write(outputStream);
            outputStream.close();
        } catch (Exception e) {
            throw new AnyException("导出出错");
        }
        return success("导出成功","成功");
    }

5、tryCatch2gGetOutput

private OutputStream tryCatch2gGetOutput(HttpServletResponse response){
        try {
            OutputStream output = response.getOutputStream();
            response.reset();
            String filename = "title"+new SimpleDateFormat("yyyy-MM-dd").format(new Date()) +".xls";
            response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
            response.setHeader("Content-Disposition", "attachment;filename="
                    .concat(String.valueOf(URLEncoder.encode(filename, "UTF-8"))));
            response.setHeader("Access-Control-Allow-Origin", "*");
            response.setHeader("Cache-Control", "no-cache");
            return output;
        } catch (Exception e) {
            throw new AnyException("导出出错");
        }
    }

6、Excel导出工具类

package com.troo;

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;
import org.joda.time.DateTime;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
public class ExcelForMoreSheet {
    /**
     * @Title: exportExcel
     * @Description: 导出Excel的方法
     * @author: evan @ 2014-01-09
     * @param workbook
     * @param sheetNum (sheet的位置,0表示第一个表格中的第一个sheet)
     * @param sheetTitle  (sheet的名称)
     * @param headers    (表格的标题)
     * @param result   (表格的数据)
     * @param out  (输出流)
     * @throws Exception
     */
    public static void exportExcel(HSSFWorkbook workbook, int sheetNum,
                            String sheetTitle, String[] headers, List> result,
                            OutputStream out)  {
        // 生成一个表格
        HSSFSheet sheet = workbook.createSheet();
        workbook.setSheetName(sheetNum, sheetTitle);
        // 设置表格默认列宽度为20个字节
        sheet.setDefaultColumnWidth((short) 20);
        // 生成一个样式
        HSSFCellStyle style = workbook.createCellStyle();
        // 设置这些样式
        style.setFillForegroundColor(HSSFColor.PALE_BLUE.index);
        style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
        style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
        style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
        style.setBorderRight(HSSFCellStyle.BORDER_THIN);
        style.setBorderTop(HSSFCellStyle.BORDER_THIN);
        style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
        // 生成一个字体
        HSSFFont font = workbook.createFont();
        font.setColor(HSSFColor.BLACK.index);
        font.setFontHeightInPoints((short) 12);
        font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
        // 把字体应用到当前的样式
        style.setFont(font);
        // 指定当单元格内容显示不下时自动换行
        style.setWrapText(true);
        // 产生表格标题行
        HSSFRow row = sheet.createRow(0);
        for (int i = 0; i < headers.length; i++) {
            HSSFCell cell = row.createCell((short) i);
            cell.setCellStyle(style);
            HSSFRichTextString text = new HSSFRichTextString(headers[i]);
            cell.setCellValue(text.toString());
        }
        // 遍历集合数据,产生数据行
        if (result != null) {
            int index = 1;
            for (List m : result) {
                row = sheet.createRow(index);
                int cellIndex = 0;
                for (String str : m) {
                    HSSFCell cell = row.createCell((short) cellIndex);
                    if (str==null){
                        str="";
                    }
                    cell.setCellValue(str.toString());
                    cellIndex++;
                }
                index++;
            }
        }
    }
}

7、Entity类

public class Entity{
    private String sheetName;
    private List subEntitys;
}
public class ExportAuditContent {
    private String param1;
    private String param2;
    private String param3;
}

8、03版测试

String PATH = "D:\\idea.webProject\\26";
@Test
public void testWrite03() throws Exception {
    // 1、创建一个工作簿
    Workbook workbook = new HSSFWorkbook();
    // 2、创建一个工作表
    Sheet sheet = workbook.createSheet("统计表");
    // 3、创建一个行  (1,1)
    Row row1 = sheet.createRow(0);
    // 4、创建一个单元格
    Cell cell11 = row1.createCell(0);
    cell11.setCellValue("今日新增");
    // (1,2)
    Cell cell12 = row1.createCell(1);
    cell12.setCellValue(666);
    // 第二行 (2,1)
    Row row2 = sheet.createRow(1);
    Cell cell21 = row2.createCell(0);
    cell21.setCellValue("统计时间");
    // (2,2)
    Cell cell22 = row2.createCell(1);
    String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");
    cell22.setCellValue(time);
    // 生成一张表(IO 流)  03 版本就是使用 xls结尾!
    FileOutputStream fileOutputStream = new FileOutputStream(PATH + "zh03.xls");
    // 输出
    workbook.write(fileOutputStream);
    // 关闭流
    fileOutputStream.close();
    System.out.println("zh03 生成完毕!");
}

9、07版测试

@org.junit.Test
    public void testWrite07() throws IOException {
        //1、创建一个工作簿
         Workbook workbook = new XSSFWorkbook();
         //2、创建一个工作表
        Sheet sheet = workbook.createSheet("统计表");
        //3、创建一个行(1,1)
        Row row1=sheet.createRow(0);
        //4、创建一个单元格
        Cell cell11 = row1.createCell(0);
        cell11.setCellValue("今日新增");

        Cell cell12 = row1.createCell(1);
        cell12.setCellValue("今日无增");

        //创建一个行(2,1)
        Row row2 = sheet.createRow(1);
        //创建一个单元格
        Cell cell21 = row2.createCell(0);
        cell21.setCellValue("统计时间");

        Cell cell22 = row2.createCell(1);
        String time = new DateTime().toString("yyyy-mm-dd HH:mm:ss");
        cell22.setCellValue(time);

        //生成一张表 io流  注意这里是07版本
        FileOutputStream fileOutputStream = new FileOutputStream(path+"java07.xlsx");
        workbook.write(fileOutputStream);
        //关闭流
        fileOutputStream.close();
        System.out.println("07版本文件生成完毕");
    }

测试成功!

10、总结:

在ApachePoi 官方提供了对操作大数据量的导入导出的工具和解决办法,操作Excel2007使用XSSF对象,可以分为三种模式:



以上便是关于Java用poi导入导出Excel相关内容啦,若想了解更多技术干货可联系知了小姐姐哦~

Java poi

上一篇:深入掌握Json

下一篇:SpringBoot整合QQ邮件发送

相关内容

中间件技术之消息队列
  01、学习中间件的方式和技巧  1:理解中间件在项目架构中的作...
2025-01-07 11:21:11
专科生通过Java培训班可...
  作为一门在全球火了二十几年的编程语言,全球的软件开发工程师有将...
2025-01-03 13:51:11
专业的Java技术培训机构...
  对于很多零基础想要学习Java的小伙伴来讲,因为自己本身没有任...
2025-01-03 13:50:08
转行学java怎么样?到底...
  Java语言是目前世界上最流行的开发语言,也是大多数企业使用的...
2025-01-03 11:26:06
转行Java需要培训吗?想...
  转行Java需要培训吗?很多人工作一两年后发现Java这个岗位...
2025-01-03 11:03:01
自学基本做不成java是真...
  自学基本做不成java是真的吗?有些人觉得Java培训费用太贵...
2025-01-03 10:39:07

热门资讯

就业课程介绍(Java+前端+... Java+大数据,前端全栈,信息安全
关于我们 请输入文章描述
0基础转行信安,他如何做到月薪... 转行并非简单的换份工作,而是我们在职场进行自我认同、重塑身份的一个过程。今天知了小姐姐为大家介绍一位...
img标签的onerror事件... 1.img 标签除了 onerror 属性外,还有其他获取管理员路径的办法吗? src 指定一个远程...
cisp考试费用多少?cisp...   随着网络技术的快速发展,网络安全问题变得越来越重要。那么,CISP考试费用多少?CISP报名条件...
【前端每日一题】什么是BFC?... 秋招马上就要开始了,小伙伴们最近在准备面试的东西没呢,知了姐今天将蛋糕哥整理的前端面试题共享出来,同...
pythone 文件和数据格式... 关于 Python 对文件的处理,以下选项中描述错误的是
网络安全运维岗面试题及答案详解... 在当今数字化时代,网络安全运维工程师的角色变得愈发重要。为了保障网络安全,各个企业都需要拥有一支经验...
知了堂官网V3第一版内测邀请 经过几个月的加班加点,我们终于迎来了知了堂官网3.1.0版本 现正招募内测中
川农第一次线下拓展精彩瞬间 5月15日,知了堂的哥哥姐姐们携手企业拓展教练浩浩荡荡奔赴川农。
-->