利用poi读写excel和word

如果在项目中想把excel数据导入到数据库中或者将数据库中的数据导出为excel,POI是个不错的选择。Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程式对Microsoft Office格式档案读和写的功能。


HSSF - 提供读写Microsoft Excel格式档案的功能。

XSSF - 提供读写Microsoft Excel OOXML格式档案的功能。
HWPF - 提供读写Microsoft Word格式档案的功能。
HSLF - 提供读写Microsoft PowerPoint格式档案的功能。
HDGF - 提供读写Microsoft Visio格式档案的功能。

 

下面是两个demo,分别读写excel和word:

 

读取xls数据:


package poi.xls;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFCell;
import java.io.FileInputStream;

/**
 * 利用POI实现从excel中读取内容
 */
public class XLSReader {
	
	public static String fileToRead = "c:/test.xls";

	public static void main(String args[]) throws Exception{
			// 创建对Excel工作簿文件的引用
			HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(fileToRead));

			//HSSFSheet sheet = workbook.getSheet("第一页");
			HSSFSheet sheet = workbook.getSheetAt(0);
			
			//读取指定索引行的值
			HSSFRow row = sheet.getRow(1);
			//读取指定索引格的值
			HSSFCell id = row.getCell((short) 0);
			HSSFCell name = row.getCell((short) 1);
			HSSFCell password = row.getCell((short) 2);
			
			//读出数据
			System.out.println("id: " + id.getNumericCellValue());
			System.out.println("name:  " + name.getRichStringCellValue());
			System.out.println("password:  " + password.getRichStringCellValue());
	}
}


 

 

创建xls文件:


package poi.xls;

import java.io.FileOutputStream;

import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFCell;

/**
 * 利用POI实现向excel中写入内容
 */
public class XLSWriter {
	
	public static String fileToWrite = "c:/test.xls";
	
	public static void main(String[] args) throws Exception {

		// 创建新的Excel 工作簿
		HSSFWorkbook workbook = new HSSFWorkbook();

		// 在Excel工作簿中建一工作表,其名为缺省值
		HSSFSheet sheet = workbook.createSheet("第一页");
		//HSSFSheet sheet = workbook.createSheet();

		// 在指定的索引处创建一行
		HSSFRow row = sheet.createRow((short) 0);

		//在指定索引处创建单元格
		HSSFCell id = row.createCell((short) 0);
		// 定义单元格为字符串类型
		id.setCellType(HSSFCell.CELL_TYPE_NUMERIC);
		// 在单元格中输入一些内容,HSSFRichTextString可以解决乱码问题
		HSSFRichTextString idContent = new HSSFRichTextString("用户id号");
		id.setCellValue(idContent);

		HSSFCell name = row.createCell((short) 1);
		name.setCellType(HSSFCell.CELL_TYPE_STRING);
		HSSFRichTextString nameContent = new HSSFRichTextString("用户名");
		name.setCellValue(nameContent);

		HSSFCell password = row.createCell((short) 2);
		password.setCellType(HSSFCell.CELL_TYPE_STRING);
		HSSFRichTextString passwordContent = new HSSFRichTextString("用户密码");
		password.setCellValue(passwordContent);

		// 新建一输出文件流
		FileOutputStream out = new FileOutputStream(fileToWrite);
		// 把相应的Excel 工作簿存盘
		workbook.write(out);
		out.flush();
		// 操作结束,关闭文件
		out.close();

		System.out.println("文件生成..." + fileToWrite);
	}
}


 

 

读取word内容:


package poi.doc;

/**
 * 利用POI实现从word中读取内容
 */
import java.io.FileInputStream;

import org.apache.poi.hwpf.extractor.WordExtractor;

public class DOCReader {
	
	public static String fileToRead = "c:/test.doc";
	
	public static void main(String[] args) throws Exception{
			// 创建输入流读取DOC文件
			FileInputStream in = new FileInputStream(fileToRead);
			
			// 创建WordExtractor
			WordExtractor extractor = new WordExtractor(in);
			
			// 对DOC文件进行提取
			String text = extractor.getText();

			System.out.println(text);
	}

}


 

 

创建word 文件:


package poi.doc;

import java.io.ByteArrayInputStream;
import java.io.FileOutputStream;

import org.apache.poi.poifs.filesystem.POIFSFileSystem;

/**
 * 利用POI实现向word写入内容
 */
public class DOCWriter {

	public static String fileToWrite = "c:/test.doc";

	public static void main(String[] args) throws Exception{
		String content = "测试数据,将被写入文档";
		
		byte b[] = content.getBytes();

		ByteArrayInputStream bais = new ByteArrayInputStream(b);

		POIFSFileSystem fs = new POIFSFileSystem();
		
		FileOutputStream ostream = new FileOutputStream(fileToWrite);

		fs.writeFilesystem(ostream);

		bais.close();
		
		ostream.close();

	}
}


 

 上面是几个小示例,要使用更复杂的应用,可以参照POI的API。

编程技巧