使用POI生成Excel文件,可以自动调整excel列宽遇到的问题及解决

自己就遇到的几个问题说一下:

public class ff {
	
	public static void main(String[] args) throws IOException {
		HSSFWorkbook wwk = new HSSFWorkbook();
		HSSFSheet sheet = wwk.createSheet("sheet1");
		
		String strData = "";
		UserPO userPO = new UserPO();
		Field[] fields = userPO.getClass().getDeclaredFields();
		for (int i = 0; i < fields.length; i++) {
			strData = strData.concat(fields[i].getName()).concat("\t");
		}
		strData = strData.concat("\r\n");

		List<UserPO> list = DaoServiceProvider.getResInstanceDao().GetXLS("UserPO");
		if (list != null && list.size() > 0) {
			for (int i = 0; i < list.size(); i++)
				strData = strData.concat(list.get(i).getName())
						.concat("\t").concat(list.get(i).getPassword()).concat(
								"\r\n");
		}
              
		HSSFRow row=sheet.createRow(( short )0);    		
		HSSFCell cell=row.createCell((short) 0);
		HSSFRichTextString hssfString = new HSSFRichTextString("11111111111111");
		//HSSFRichTextString hssfString = new HSSFRichTextString(strData);
		//cell.setCellValue(strData);
		cell.setCellValue(hssfString);
	
		sheet.autoSizeColumn((short) 0);
		FileOutputStream stream = new FileOutputStream("E:/123.xls");
		wwk.write(stream);
		stream.close();

	}

}


上述是自动调列宽的最基本的语句。

问题一:autoSizeColumn()这个方法在2.5 poi中是没有的。后来在3.0 poi存在就使用了;

问题二:setCellValue(strData);这个方法的使用,如果你里面的参数只是string,那么autoSizeColumn()这个方法就可能会失效。后来使用了HSSFRichTextString这种参数就实现了HSSFRichTextString hssfString = new HSSFRichTextString("11111111111111");其实他只是将string转化一下;

问题三:对于string参数的使用,就我上面写的那个strData字符串,好像就无法让其autoSizeColumn()方法失效。可能是用到了转义字符"\t" ,"\r\n"。

希望能给遇到这些问题的同学一点帮助。。。

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值