POI入门操作Excel单元格

简介: POI入门操作Excel单元格

1 依赖

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>4.0.1</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>4.0.1</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml-schemas</artifactId>
    <version>4.0.1</version>
</dependency>

2 写入

//1.打开excel
XSSFWorkbook workbook = new XSSFWorkbook();
//2.创建sheet页
XSSFSheet sheet1 = workbook.createSheet("sheet1");//sheet:工作表
//3.创建行,索引从0开始
XSSFRow row = sheet1.createRow(0);//row 行
//4.创建单元格,索引从0开始
XSSFCell cell = row.createCell(0);//cell:单元格
//5.向单元格中插入数据
cell.setCellValue("你好");
//6.将数据写入文件,相当于另存为
workbook.write(new FileOutputStream("d://b.xlsx"));

3 读取

//1.使用excel打开指定的xlsx文件
XSSFWorkbook fw = new XSSFWorkbook("d://b.xlsx");
//2.获取第一个sheet页
XSSFSheet sheet1 = fw.getSheetAt(0);
//3.获取第0行
XSSFRow row = sheet1.getRow(0);
//4.获取第0个单元格
XSSFCell cell = row.getCell(0);
//5.获取单元格中的数据
System.out.println(cell.getStringCellValue());

4 练习

查看一下excel数据结构,使用POI实现

/*1.创建EXCEL文件*/
XSSFWorkbook workbook = new XSSFWorkbook();
/*2.创建sheet页面*/
XSSFSheet sheet1 = workbook.createSheet("sheet1");
sheet1.addMergedRegion(new CellRangeAddress(0,0,0,2));
/*3.创建学生信息头*/
XSSFRow row = sheet1.createRow(0);
XSSFCell cell = row.createCell(0);
XSSFCellStyle textAlignCenter = workbook.createCellStyle();
textAlignCenter.setAlignment(HorizontalAlignment.CENTER);//横着对其
textAlignCenter.setVerticalAlignment(VerticalAlignment.CENTER);//上下对齐
cell.setCellStyle(textAlignCenter);
cell.setCellValue("学生信息");
/*4.创建表头*/
XSSFRow titleRow = sheet1.createRow(1);
XSSFCell idCell = titleRow.createCell(0);
idCell.setCellValue("编号");
XSSFCell nameCell = titleRow.createCell(1);
nameCell.setCellValue("姓名");
XSSFCell ageCell = titleRow.createCell(2);
ageCell.setCellValue("年龄");
/*5.创建数据*/
XSSFRow dataRow1 = sheet1.createRow(2);
XSSFCell idCell1 = dataRow1.createCell(0);
idCell1.setCellValue("1");
XSSFCell nameCell1 = dataRow1.createCell(1);
nameCell1.setCellValue("牛宁宁");
XSSFCell ageCell1 = dataRow1.createCell(2);
ageCell1.setCellValue("22");
XSSFRow dataRow2 = sheet1.createRow(3);
XSSFCell idCell2 = dataRow2.createCell(0);
idCell2.setCellValue("1");
XSSFCell nameCell2 = dataRow2.createCell(1);
nameCell2.setCellValue("牛宁宁");
XSSFCell ageCell2 = dataRow2.createCell(2);
ageCell2.setCellValue("22");
workbook.write(new FileOutputStream("d://b.xlsx"));

使用循环生成

/*1.创建EXCEL文件*/
XSSFWorkbook workbook = new XSSFWorkbook();
/*2.创建sheet页面*/
XSSFSheet sheet1 = workbook.createSheet("sheet1");
sheet1.addMergedRegion(new CellRangeAddress(0,0,0,2));
/*3.创建学生信息头*/
XSSFRow row = sheet1.createRow(0);
XSSFCell cell = row.createCell(0);
XSSFCellStyle textAlignCenter = workbook.createCellStyle();
textAlignCenter.setAlignment(HorizontalAlignment.CENTER);
textAlignCenter.setVerticalAlignment(VerticalAlignment.CENTER);
cell.setCellStyle(textAlignCenter);
cell.setCellValue("学生信息");
/*4.创建表头*/
XSSFRow titleRow = sheet1.createRow(1);
XSSFCell idCell = titleRow.createCell(0);
idCell.setCellValue("编号");
XSSFCell nameCell = titleRow.createCell(1);
nameCell.setCellValue("姓名");
XSSFCell ageCell = titleRow.createCell(2);
ageCell.setCellValue("年龄");
/*5.创建数据*/
ArrayList<Student> students = new ArrayList<>();
students.add(new Student(1,"牛宁宁",22));
students.add(new Student(2,"冯荣",222));
students.add(new Student(3,"张家齐",212));
students.add(new Student(4,"范亚涛",122));
for (int i = 0; i < students.size(); i++) {
    XSSFRow dataRow1 = sheet1.createRow(2+i);
    XSSFCell idCell1 = dataRow1.createCell(0);
    idCell1.setCellValue(students.get(i).getId());
    XSSFCell nameCell1 = dataRow1.createCell(1);
    nameCell1.setCellValue(students.get(i).getName());
    XSSFCell ageCell1 = dataRow1.createCell(2);
    ageCell1.setCellValue(students.get(i).getAge());
}
workbook.write(new FileOutputStream("d://b.xlsx"));

5 文件下载

整体流程

servlet需要做的事情

1.告诉浏览器返回的是EXCEL文件,并且要下载该文件,不能直接在浏览器打开

2.读取服务器上面的资源,写给客户端。

service层接口:QuestionService

 /**生成报表数据*/
ByteArrayOutputStream report()throws Exception;

service层接口的实现类

  @Override
    public ByteArrayOutputStream report() throws Exception {
        /*1.从数据库查询所有的问题列表*/
        List<Question> questionList = this.findAll();
        /*2.将查询到的数据写入内存,下面代码拷贝,别自己写*/
        Workbook wb = new XSSFWorkbook();
        Sheet s = wb.createSheet("题目数据文件");
        //设置通用配置
        //s.setColumnWidth(4,100);
        CellStyle cs_field = wb.createCellStyle();
        cs_field.setAlignment(HorizontalAlignment.CENTER);
        cs_field.setBorderTop(BorderStyle.THIN);
        cs_field.setBorderBottom(BorderStyle.THIN);
        cs_field.setBorderLeft(BorderStyle.THIN);
        cs_field.setBorderRight(BorderStyle.THIN);
        //制作标题
        s.addMergedRegion(new CellRangeAddress(1,1,1,12));
        Row row_1 = s.createRow(1);
        Cell cell_1_1 = row_1.createCell(1);
        cell_1_1.setCellValue("在线试题导出信息");
        //创建一个样式
        CellStyle cs_title = wb.createCellStyle();
        cs_title.setAlignment(HorizontalAlignment.CENTER);
        cs_title.setVerticalAlignment(VerticalAlignment.CENTER);
        cell_1_1.setCellStyle(cs_title);
        //制作表头
        String[] fields = {"题目ID","所属公司ID","所属目录ID","题目简介","题干描述",
                "题干配图","题目分析","题目类型","题目难度","是否经典题","题目状态","审核状态"};
        Row row_2 = s.createRow(2);
        for (int i = 0; i < fields.length; i++) {
            Cell cell_2_temp = row_2.createCell(1 + i); //++
            cell_2_temp.setCellValue(fields[i]);    //++
            cell_2_temp.setCellStyle(cs_field);
        }
        //制作数据区
        int row_index = 0;
        for (Question q : questionList) {
            int cell_index = 0;
            Row row_temp = s.createRow(3 + row_index++);
            Cell cell_data_1 = row_temp.createCell(1 + cell_index++);
            cell_data_1.setCellValue(q.getId());    //++
            cell_data_1.setCellStyle(cs_field);
            Cell cell_data_2 = row_temp.createCell(1 + cell_index++);
            cell_data_2.setCellValue(q.getCompanyId());    //++
            cell_data_2.setCellStyle(cs_field);
            Cell cell_data_3 = row_temp.createCell(1 + cell_index++);
            cell_data_3.setCellValue(q.getCatalogId());    //++
            cell_data_3.setCellStyle(cs_field);
            Cell cell_data_4 = row_temp.createCell(1 + cell_index++);
            cell_data_4.setCellValue(q.getRemark());    //++
            cell_data_4.setCellStyle(cs_field);
            Cell cell_data_5 = row_temp.createCell(1 + cell_index++);
            cell_data_5.setCellValue(q.getSubject());    //++
            cell_data_5.setCellStyle(cs_field);
            Cell cell_data_6 = row_temp.createCell(1 + cell_index++);
            cell_data_6.setCellValue(q.getPicture());    //++
            cell_data_6.setCellStyle(cs_field);
            Cell cell_data_7 = row_temp.createCell(1 + cell_index++);
            cell_data_7.setCellValue(q.getAnalysis());    //++
            cell_data_7.setCellStyle(cs_field);
            Cell cell_data_8 = row_temp.createCell(1 + cell_index++);
            cell_data_8.setCellValue(q.getType());    //++
            cell_data_8.setCellStyle(cs_field);
            Cell cell_data_9 = row_temp.createCell(1 + cell_index++);
            cell_data_9.setCellValue(q.getDifficulty());    //++
            cell_data_9.setCellStyle(cs_field);
            Cell cell_data_10 = row_temp.createCell(1 + cell_index++);
            cell_data_10.setCellValue(q.getIsClassic());    //++
            cell_data_10.setCellStyle(cs_field);
            Cell cell_data_11 = row_temp.createCell(1 + cell_index++);
            cell_data_11.setCellValue(q.getState());    //++
            cell_data_11.setCellStyle(cs_field);
            Cell cell_data_12 = row_temp.createCell(1 + cell_index++);
            cell_data_12.setCellValue(q.getReviewStatus());    //++
            cell_data_12.setCellStyle(cs_field);
        }
        //将内存中的workbook数据写入到流中
        ByteArrayOutputStream os = new ByteArrayOutputStream();//ArrayList<Byte>
        wb.write(os);
        wb.close();
        return os;
    }
private void downloadReport(HttpServletRequest request, HttpServletResponse response) throws Exception {
        /*1.告诉浏览器返回的是EXCEL文件,并且要下载该文件,不能直接在浏览器打开*/
        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");
        response.addHeader("Content-Disposition","attachment;fileName="+UUIDUtil.getSimpleUUID()+".xlsx");
        /*2.创建xlns文件,并且将EXCEL中的数据写到内存*/
        ByteArrayOutputStream os = questionService.report();
        /*3.将内存中的数据变成字节数据写入到浏览器*/
        os.writeTo(response.getOutputStream());
        os.close();
}
目录
相关文章
|
15天前
|
Python
使用OpenPyXL库实现Excel单元格其他对齐方式设置
本文介绍了如何使用Python的`openpyxl`库设置Excel单元格中的文本对齐方式,包括文本旋转、换行、自动调整大小和缩进等,通过具体示例代码展示了每种对齐方式的应用方法,适合需要频繁操作Excel文件的用户学习参考。
147 85
使用OpenPyXL库实现Excel单元格其他对齐方式设置
|
19天前
|
数据可视化 Python
使用OpenPyXL在Excel中创建折线图:数据可视化入门
本文介绍了如何使用Python的`openpyxl`库在Excel中创建折线图,包括安装库、加载Excel文件、定义数据范围、设置图表属性(如标题、轴标签)及保存文件等步骤,适合数据可视化初学者。
50 15
|
1月前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
99 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
5月前
|
Java BI 数据处理
如何在Java中实现Excel操作
如何在Java中实现Excel操作
|
6月前
|
Java 数据库 数据安全/隐私保护
Java操作Excel文件导入导出【内含有 jxl.jar 】
Java操作Excel文件导入导出【内含有 jxl.jar 】
90 0
|
2月前
|
前端开发 JavaScript Java
导出excel的两个方式:前端vue+XLSX 导出excel,vue+后端POI 导出excel,并进行分析、比较
这篇文章介绍了使用前端Vue框架结合XLSX库和后端结合Apache POI库导出Excel文件的两种方法,并对比分析了它们的优缺点。
810 0
|
2月前
|
Java Apache
Apache POI java对excel表格进行操作(读、写) 有代码!!!
文章提供了使用Apache POI库在Java中创建和读取Excel文件的详细代码示例,包括写入数据到Excel和从Excel读取数据的方法。
62 0
|
4月前
|
开发工具 开发者
Excel 2016 VBA 提取单元格的中文字符
Excel 2016 VBA 提取单元格的中文字符
39 1
Excel如何使用VBA操作引用其它工作簿中的单元格
Excel引用其它工作簿中的单元格的值及使用VBA操作
|
6月前
|
Java API Spring
集成EasyPoi(一个基于POI的Excel导入导出工具)到Spring Boot项目中
集成EasyPoi(一个基于POI的Excel导入导出工具)到Spring Boot项目中
576 1