java利用poi 读写(导入导出)word、excel(数组越界求解决办法)


java 读写 word excel 简单的实例

需要的jar包有

poi-3.8-20120326.jar

poi-examples-3.8-20120326.jar

poi-excelant-3.8-20120326.jar

poi-ooxml-3.8-20120326.jar

poi-ooxml-schemas-3.8-20120326.jar

poi-scratchpad-3.8-20120326.jar


具体实例代码如下 :

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

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hwpf.extractor.WordExtractor;
import org.apache.poi.poifs.filesystem.DirectoryEntry;
import org.apache.poi.poifs.filesystem.DocumentEntry;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;

/**
 * 
 * @author Administrator
 *
 */
public class ExcelWord {

	static public void main(String[] args) throws Exception {
		// ------------在xls中写入数据-----即导出excel
		FileOutputStream fos = new FileOutputStream("e:\\text.xls");
		HSSFWorkbook wb = new HSSFWorkbook();
		//给sheet命名
		HSSFSheet s = wb.createSheet("第一个sheet");
//		wb.setSheetName(0, "first sheet");
		//第一行
		HSSFRow row = s.createRow((short)0);
		//第一行第一列
		HSSFCell cell = row.createCell((short) 0);
		HSSFRichTextString hts = new HSSFRichTextString("nihao你好啊啊");
		cell.setCellValue(hts);
		//第一行第二列
		cell = row.createCell((short) 1);
		HSSFRichTextString hts1 = new HSSFRichTextString("中国龙");
		cell.setCellValue(hts1);
		/////第二行
		HSSFRow row2 = s.createRow((short)1);
		//第二行第一列
		HSSFCell cell1 = row2.createCell((short) 0);
		HSSFRichTextString hts2 = new HSSFRichTextString("第二行数据1111");
		cell1.setCellValue(hts2);
		//第二行第二列
		cell1 = row2.createCell((short) 1);
		HSSFRichTextString hts3 = new HSSFRichTextString("第二列数据ddd");
		cell1.setCellValue(hts3);
		
		//写入excel 关闭流
		wb.write(fos);
		fos.flush();
		fos.close();
		
		
		
		// ------------从xls读出数据----即数据导入
		StringBuffer sb=new StringBuffer();
		wb = new HSSFWorkbook(new FileInputStream("e:\\text.xls"));
		//获得第一张sheet
		s = wb.getSheetAt(0);
		System.out.println("行数:"+s.getLastRowNum());
		//末行+1
		for(int i=s.getFirstRowNum();i


遇到的问题:

poi 导出数据到word后,再读取该word文档中的数据会抛出数组越界异常,直接读取正常编辑的word文件没有抛错。希望大神指点一二。




你可能感兴趣的:(javaSe)