数据导出Excel 超过435行文件损坏

J2EE 码拜 10年前 (2015-04-16) 1322次浏览 0个评论
 

http://blog.csdn.net/lenotang/article/details/2823230

我根据这个文章做出了2个程序 就是数据导出 Excel功能  今天又一葫芦画出第三个功能来 但是这次的数据量大(1300多行数据), 使用上面的文章 把数据导出Excel的时候,导出的Excel文件 只到数据的435行 且 最后一列没有 Excel文件报损坏。

我想是不是 

public void exportExcel(String title, String[] headers,

	Collection<T> dataset, OutputStream out, String pattern) {

		// 声明一个工作薄

		HSSFWorkbook workbook = new HSSFWorkbook();

		// 生成一个表格

		HSSFSheet sheet = workbook.createSheet(title);

		// 设置表格默认列宽度为15个字节

		sheet.setDefaultColumnWidth((short) 15);

		// 生成一个样式

		HSSFCellStyle style = workbook.createCellStyle();

		// 设置这些样式

		style.setFillForegroundColor(HSSFColor.SKY_BLUE.index);

		style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);

		style.setBorderBottom(HSSFCellStyle.BORDER_THIN);

		style.setBorderLeft(HSSFCellStyle.BORDER_THIN);

		style.setBorderRight(HSSFCellStyle.BORDER_THIN);

		style.setBorderTop(HSSFCellStyle.BORDER_THIN);

		style.setAlignment(HSSFCellStyle.ALIGN_CENTER);

		// 生成一个字体

		HSSFFont font = workbook.createFont();

		font.setColor(HSSFColor.VIOLET.index);
		//font.setColor(HSSFColor.BLACK.index);

		font.setFontHeightInPoints((short) 12);

		font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);

		// 把字体应用到当前的样式

		style.setFont(font);

		// 生成并设置另一个样式

		HSSFCellStyle style2 = workbook.createCellStyle();

		style2.setFillForegroundColor(HSSFColor.LIGHT_YELLOW.index);

		style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);

		style2.setBorderBottom(HSSFCellStyle.BORDER_THIN);

		style2.setBorderLeft(HSSFCellStyle.BORDER_THIN);

		style2.setBorderRight(HSSFCellStyle.BORDER_THIN);

		style2.setBorderTop(HSSFCellStyle.BORDER_THIN);

		style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);

		style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);

		// 生成另一个字体

		HSSFFont font2 = workbook.createFont();

		font2.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);

		// 把字体应用到当前的样式

		style2.setFont(font2);

		// 声明一个画图的顶级管理器

		HSSFPatriarch patriarch = sheet.createDrawingPatriarch();

		// 定义注释的大小和位置,详见文档

		HSSFComment comment = patriarch.createComment(new HSSFClientAnchor(0,
				0, 0, 0, (short) 4, 2, (short) 6, 5));

		// 设置注释内容

		comment.setString(new HSSFRichTextString("可以在POI中添加注释!"));

		// 设置注释作者,当鼠标移动到单元格上是可以在状态栏中看到该内容.

		comment.setAuthor("leno");

		// 产生表格标题行

		HSSFRow row = sheet.createRow(0);

		for (short i = 0; i < headers.length; i++) {

			HSSFCell cell = row.createCell(i);

			cell.setCellStyle(style);

			HSSFRichTextString text = new HSSFRichTextString(headers[i]);

			cell.setCellValue(text);

		}

		// 遍历集合数据,产生数据行

		Iterator<T> it = dataset.iterator();

		int index = 0;

		while (it.hasNext()) {

			index++;

			row = sheet.createRow(index);

			T t = (T) it.next();

			// 利用反射,根据javabean属性的先后顺序,动态调用getXxx()方法得到属性值

			Field[] fields = t.getClass().getDeclaredFields();

			for (short i = 0; i < fields.length; i++) {

				HSSFCell cell = row.createCell(i);

				cell.setCellStyle(style2);

				Field field = fields[i];

				String fieldName = field.getName();

				String getMethodName = "get"

				+ fieldName.substring(0, 1).toUpperCase()

				+ fieldName.substring(1);

				try {

					Class tCls = t.getClass();

					Method getMethod = tCls.getMethod(getMethodName,

					new Class[] {});

					Object value = getMethod.invoke(t, new Object[] {});

					// 判断值的类型后进行强制类型转换

					String textValue = null;

					// if (value instanceof Integer) {

					// int intValue = (Integer) value;

					// cell.setCellValue(intValue);

					// } else if (value instanceof Float) {

					// float fValue = (Float) value;

					// textValue = new HSSFRichTextString(

					// String.valueOf(fValue));

					// cell.setCellValue(textValue);

					// } else if (value instanceof Double) {

					// double dValue = (Double) value;

					// textValue = new HSSFRichTextString(

					// String.valueOf(dValue));

					// cell.setCellValue(textValue);

					// } else if (value instanceof Long) {

					// long longValue = (Long) value;

					// cell.setCellValue(longValue);

					// }

					if (value instanceof Boolean) {

						boolean bValue = (Boolean) value;

						textValue = "男";

						if (!bValue) {

							textValue = "女";

						}

					} else if (value instanceof Date) {

						Date date = (Date) value;

						SimpleDateFormat sdf = new SimpleDateFormat(pattern);

						textValue = sdf.format(date);

					} else if (value instanceof byte[]) {

						// 有图片时,设置行高为60px;

						row.setHeightInPoints(60);

						// 设置图片所在列宽度为80px,注意这里单位的一个换算

						sheet.setColumnWidth(i, (short) (35.7 * 80));

						// sheet.autoSizeColumn(i);

						byte[] bsValue = (byte[]) value;

						HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0,

						1023, 255, (short) 6, index, (short) 6, index);

						anchor.setAnchorType(2);

						patriarch.createPicture(anchor, workbook.addPicture(

						bsValue, HSSFWorkbook.PICTURE_TYPE_JPEG));

					} else {

						// 其它数据类型都当作字符串简单处理

						textValue = value.toString();

					}

					// 如果不是图片数据,就利用正则表达式判断textValue是否全部由数字组成

					if (textValue != null) {

						Pattern p = Pattern.compile("^//d+(//.//d+)?$");

						Matcher matcher = p.matcher(textValue);

						if (matcher.matches()) {

							// 是数字当作double处理

							cell.setCellValue(Double.parseDouble(textValue));

						} else {

							HSSFRichTextString richString = new HSSFRichTextString(
									textValue);

							HSSFFont font3 = workbook.createFont();

							//font3.setColor(HSSFColor.BLUE.index);
							font3.setColor(HSSFColor.BLACK.index);
							richString.applyFont(font3);

							cell.setCellValue(richString);

						}

					}

				} catch (SecurityException e) {

 里面的样式出问题了 求给我改成初始的样式
或者  是  给一个 导出 excel的通用程序也行  我有数据集 然后简单套用就成的

数据导出Excel 超过435行文件损坏
20分
 导出 excel的通用程序  我有哈,导出成List<map> 格式的…
数据导出Excel 超过435行文件损坏
引用 1 楼 attilax 的回复:

 导出 excel的通用程序  我有哈,导出成List<map> 格式的…

有行数 限制没有啊 


CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明数据导出Excel 超过435行文件损坏
喜欢 (0)
[1034331897@qq.com]
分享 (0)

文章评论已关闭!