poi对excel的基本读写操作

简介: 最近简单的弄了下poi对excel的应用,为方便自己以后的使用就把一些基本操作记录下来,其他更复杂的操作可以等以后有需求的时候再来深入了解一番!   写操作: /** * * 层次结构就是workbook-->Sheet-->Row-->Cell * 只要按照这种层次...

最近简单的弄了下poi对excel的应用,为方便自己以后的使用就把一些基本操作记录下来,其他更复杂的操作可以等以后有需求的时候再来深入了解一番!

 

写操作:

/**
 * 
 * 层次结构就是workbook-->Sheet-->Row-->Cell
 * 只要按照这种层次结构操作就不会有什么大的问题
 * @author Administrator
 *
 */
public class Test1 {

	public static void main(String args[]) throws IOException {
		
		//HSSFWorkbook对应的是2003
		//XSSFWorkbook对应的是2007
		//对于03和07它们的操作都是差不多的,只是在需要用07的时候把相应的HSSF前缀改成XSSF前缀就可以了
		//第一步建一个工作簿,即workbook
		Workbook workbook = new HSSFWorkbook();
		//第二步建一个工作表单,急sheet
		Sheet sheet = workbook.createSheet("mysheet1");
		for (int i=0;i<5;i++) {
			//有了表单以后就是行Row了,
			Row row = sheet.createRow(i);
			for (int j=0;j<5;j++) {
				//有了row以后就是row上的一个个小的单元格了
				Cell cell = row.createCell(j);
				//给单元格添加内容
				cell.setCellValue("row"+(i+1)+",column"+(j+1));
			}
		}
		//建一个用于存放新建的excel的文件输出流
		OutputStream os = new FileOutputStream("file/test1.xls");
		//把形成的workbook写到一个输出流里面
		workbook.write(os);
		os.close();
	}
	
}

 

读操作:

public class Test4 {

	public static void main(String args[]) throws IOException {
		InputStream is = new FileInputStream("file/test1.xls");
		Workbook wb = new HSSFWorkbook(is);
		Sheet sheet = wb.getSheetAt(0);
		// 因为Row,Cell,Sheet都继承了java.lang.Iterator接口,所以可以用下面的方法来进行遍历
		for (Row row : sheet) {
			for (Cell cell : row) {
				int cellType = cell.getCellType();
				switch (cellType) {
				//在取数据的时候类型一定要取对,否则将抛出异常
				case Cell.CELL_TYPE_STRING:
					String str = cell.getRichStringCellValue().getString();
					System.out.println(str);// 对取得的数据的简单处理;
					break;
				case Cell.CELL_TYPE_BLANK:
					if (DateUtil.isCellDateFormatted(cell)) {
						System.out.println(cell.getDateCellValue());
					} else {
						System.out.println(cell.getNumericCellValue());
					}
					break;
				case Cell.CELL_TYPE_FORMULA:
					System.out.println(cell.getCellFormula());
					break;
				case Cell.CELL_TYPE_BOOLEAN:
					System.out.println(cell.getBooleanCellValue());
					break;
				default:
					System.out.println("---------------------");
					break;
				}
			}
		}
		//当然还可以这样来遍历
		//row是从1开始的,cell是从头0开始的,但是在创建的时候它们都是0-based;
		for (int i=0;i<sheet.getLastRowNum()+1;i++) {
			Row row = sheet.getRow(i);
			if (row==null)
				continue;
			for (int j=0;j<row.getLastCellNum();j++) {
				Cell cell = row.getCell(j);
				if (cell==null)
					continue;
				//在取数据的时候数据类型一定要取对,否则将抛出异常,like NumberFormatException
				System.out.println(cell.getStringCellValue());
			}
		}
		is.close();
	}

}

 

合并单元格:

public static void main(String args[]) throws IOException {
		Workbook wb = new HSSFWorkbook();
		Sheet sheet = wb.createSheet("sheet1");
		Row row = sheet.createRow(1);
		Cell cell = row.createCell(1);
		cell.setCellValue("a test of merge!");
		//执行合并操作的语句
		sheet.addMergedRegion(new CellRangeAddress(
				1,// 开始行
				1,// 结束行
				1,// 开始列
				3// 结束列
		));
		OutputStream os = new FileOutputStream("file/test3.xls");
		wb.write(os);
		os.close();
	}

 

 

换行:

public static void main(String args[]) throws IOException {
		Workbook wb = new HSSFWorkbook();
		Sheet sheet = wb.createSheet();
		Row row = sheet.createRow(6);
		sheet.autoSizeColumn(2);
		for (int i=0;i<5;i++) {
			Cell cell = row.createCell(i+2);
			CellStyle style = wb.createCellStyle();
			//to set cell newLine should set its wrap true
			style.setWrapText(true);
			//利用\n来实现换行操作,只有在Cell设置为setWrapText(true)的时候才能实现人为的换行
			cell.setCellValue("just use \n to wrap in a cell!");
			cell.setCellStyle(style);
		}
		OutputStream os = new FileOutputStream("file/test6_newLine.xls");
		wb.write(os);
		os.close();
		System.out.println("----------------------------");
	}

 

 

画图:

//drawing shapes
		/*
		 * To create a shape you have to go through the following steps: 

			1.Create the patriarch.
			2.Create an anchor to position the shape on the sheet.
			3.Ask the patriarch to create the shape.
			4.Set the shape type (line, oval, rectangle etc...)
			5.Set any other style details converning the shape. (eg: line thickness, etc...)

		 */
		HSSFPatriarch partriarch = (HSSFPatriarch) sheet5.createDrawingPatriarch();
		HSSFSimpleShape shape = partriarch.createSimpleShape(new HSSFClientAnchor(0,0,0,0,(short)3,3,(short)5,5));
		shape.setShapeType(HSSFSimpleShape.OBJECT_TYPE_OVAL);
		//shape可以设置很多的属性
		shape.setFillColor(255,200,200);
		shape.setLineStyle(HSSFSimpleShape.LINESTYLE_DASHGEL);
		//Text boxes are created using a different call: 

 

 

目录
相关文章
|
3月前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
74 2
|
3月前
|
前端开发 JavaScript Java
导出excel的两个方式:前端vue+XLSX 导出excel,vue+后端POI 导出excel,并进行分析、比较
这篇文章介绍了使用前端Vue框架结合XLSX库和后端结合Apache POI库导出Excel文件的两种方法,并对比分析了它们的优缺点。
1171 0
|
3月前
|
索引 Python
Excel学习笔记(一):python读写excel,并完成计算平均成绩、成绩等级划分、每个同学分数大于70的次数、找最优成绩
这篇文章是关于如何使用Python读取Excel文件中的学生成绩数据,并进行计算平均成绩、成绩等级划分、统计分数大于70的次数以及找出最优成绩等操作的教程。
114 0
|
3月前
|
Java Apache
Apache POI java对excel表格进行操作(读、写) 有代码!!!
文章提供了使用Apache POI库在Java中创建和读取Excel文件的详细代码示例,包括写入数据到Excel和从Excel读取数据的方法。
93 0
对excel读写的三个模块,xlsxwriter最牛,xlwt , xlrd,openpyxl
对excel读写的三个模块,xlsxwriter最牛,xlwt , xlrd,openpyxl
|
5月前
|
SQL JSON 关系型数据库
n种方式教你用python读写excel等数据文件
n种方式教你用python读写excel等数据文件
80 1
|
5月前
|
easyexcel Java 关系型数据库
阿里巴巴-EasyExcel 基于Java的简单、省内存的读写Excel
该文章主要介绍了在Java应用中如何使用EasyExcel技术完成对Excel文件的导入和导出操作,包括环境搭建、基本概念、快速入门、进阶操作和综合应用等内容,并提供了相关代码示例和注意事项。
 阿里巴巴-EasyExcel 基于Java的简单、省内存的读写Excel
|
6月前
|
存储 对象存储 Python
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
|
7月前
|
Java API Spring
集成EasyPoi(一个基于POI的Excel导入导出工具)到Spring Boot项目中
集成EasyPoi(一个基于POI的Excel导入导出工具)到Spring Boot项目中
605 1
|
7月前
|
XML Java 测试技术
《手把手教你》系列技巧篇(六十七)-java+ selenium自动化测试 - 读写excel文件 - 中篇(详细教程)
【6月更文挑战第8天】本文介绍了Java中操作Excel的工具,包括POI和JXL。POI支持处理Office 2003及以下的OLE2格式(.xls)和2007以上的OOXML格式(.xlsx)。而JXL只能处理2003版本的Excel文件。文章详细讲解了如何下载和使用JXL库,并给出了一个简单的Java代码示例,展示如何读取2003版Excel文件中的数据。在实际项目中,由于JXL对新版本Excel的支持限制,通常推荐使用POI。
80 5