`
bean-woo
  • 浏览: 134194 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

POI工具类

    博客分类:
  • POI
阅读更多

 

package com.adtech.tools;

 

import java.io.IOException;

 

import javax.servlet.ServletException;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import javax.servlet.http.HttpSession;

 

import org.apache.poi.hssf.usermodel.HSSFCell;

import org.apache.poi.hssf.usermodel.HSSFCellStyle;

import org.apache.poi.hssf.usermodel.HSSFFont;

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.hssf.util.Region;

 

/**

 * 报表打印工具类

 * 

 * @date 2010-01-22

 */

public class ReportTool {

/**

* Excel编码处理

* @param toEncoded

* @param encoding

* @return

*/

public static String getUnicode(String toEncoded, String encoding) {

String retString = "";

if (toEncoded.equals("") || toEncoded.trim().equals("")) {

return toEncoded;

}

try {

byte[] b = toEncoded.getBytes(encoding);

sun.io.ByteToCharConverter convertor = sun.io.ByteToCharConverter

.getConverter(encoding);

char[] c = convertor.convertAll(b);

for (int i = 0; i < c.length; i++) {

retString += String.valueOf(c[i]);

}

} catch (java.io.UnsupportedEncodingException usee) {

System.out.println("不支持" + encoding + "编码方式");

usee.printStackTrace();

} catch (sun.io.MalformedInputException mfie) {

System.out.println("输入参数无效!!!");

mfie.printStackTrace();

}

return retString;

}

 

/**

* 处理文件名乱码

* @param str

* @return

*/

public static String getStr(String str) {

try {

String temp_p = str;

byte[] temp_t = temp_p.getBytes("ISO8859_1");

String temp = new String(temp_t);

return temp;

} catch (Exception e) {

e.printStackTrace();

}

return "null";

}

 

/**

* 定义字体大小样式

* @param workbook

* @param color

*            字体颜色

* @param boldweight

*            字体样式

* @param fontHeight

*            字体大小

* @return

*/

public static HSSFFont createHSSFFont(HSSFWorkbook workbook, short color,

short boldweight, int fontHeight) {

HSSFFont font = workbook.createFont();

font.setColor(HSSFFont.COLOR_NORMAL);

font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);

font.setFontHeight((short) fontHeight);

return font;

}

 

/**

* 定义边框样式 单元格四周都有边框

* @param workbook

* @param verticalAlignment

*            垂直显示

* @param alignment

*            水平显示样式

* @param top

*            上边框粗细

* @param bottom

*            下边框粗细

* @param left

*            左边框粗细

* @param right

*            右边框粗细

* @return

*/

public static HSSFCellStyle createHSSFCellStyle(HSSFWorkbook workbook,

short verticalAlignment, short alignment, int top, int bottom,

int left, int right) {

HSSFCellStyle cellStyle = workbook.createCellStyle();

cellStyle.setVerticalAlignment(verticalAlignment);

cellStyle.setAlignment(alignment);

cellStyle.setBorderBottom((short) bottom);

cellStyle.setBorderLeft((short) left);

cellStyle.setBorderRight((short) right);

cellStyle.setBorderTop((short) top);

return cellStyle;

 

}

 

/**

* 定义边框样式 单元格四周都有边框

* @param workbook

* @param verticalAlignment

*            垂直显示

* @param alignment

*            水平显示样式

* @param top

*            上边框粗细

* @param bottom

*            下边框粗细

* @param left

*            左边框粗细

* @param right

*            右边框粗细

* @param font

*            单元格字体样式

* @return

*/

public static HSSFCellStyle createHSSFCellStyle(HSSFWorkbook workbook,

HSSFFont font, short verticalAlignment, short alignment, int top,

int bottom, int left, int right) {

HSSFCellStyle cellStyle = workbook.createCellStyle();

cellStyle.setVerticalAlignment(verticalAlignment);

cellStyle.setAlignment(alignment);

cellStyle.setBorderBottom((short) bottom);

cellStyle.setBorderLeft((short) left);

cellStyle.setBorderRight((short) right);

cellStyle.setBorderTop((short) top);

cellStyle.setFont(font);

return cellStyle;

 

}

 

/**

* 创建行

* @param sheet

*            工作表

* @param rowNum

*            行号

* @param height

*            行高

* @return

*/

public static HSSFRow createHSSFRow(HSSFSheet sheet, int rowNum, int height) {

HSSFRow row = sheet.createRow((short) rowNum);

row.setHeight((short) height);

return row;

}

 

/**

* 创建列

* @param hssfRow

*            行对象

* @param cellStyle

*            单元格样式

* @param cellNum

*            列号

* @param content

*            单元格内容

*/

public static void createHSSFCell(HSSFRow hssfRow, HSSFCellStyle cellStyle,

int cellNum, String content) {

HSSFCell cell = hssfRow.createCell((short) cellNum);

cell.setCellType(HSSFCell.CELL_TYPE_STRING);

cell.setEncoding(HSSFCell.ENCODING_UTF_16);

cell.setCellStyle(cellStyle);

content = getUnicode(content, "gb2312");

cell.setCellValue(content);

 

}

 

/**

* 创建列

* @param hssfRow

*            行对象

* @param cellStyle

*            单元格样式

* @param cellNum

*            列号

* @param content

*            单元格内容

* @param beginRow

*            合并单元格开始行

* @param beginCell

*            合并单元格开始列

* @param endRow

*            合并单元格结束行

* @param endCell

*            合并单元格结束列

*/

public static void createHSSFCell(HSSFSheet sheet, HSSFRow hssfRow,

HSSFCellStyle cellStyle, int cellNum, String content, int beginRow,

int beginCell, int endRow, int endCell) {

HSSFCell cell = hssfRow.createCell((short) cellNum);

cell.setCellType(HSSFCell.CELL_TYPE_STRING);

cell.setEncoding(HSSFCell.ENCODING_UTF_16);

cell.setCellStyle(cellStyle);

content = getUnicode(content, "gb2312");

cell.setCellValue(content);

sheet.addMergedRegion(new Region((short) beginRow, (short) beginCell,

(short) endRow, (short) endCell));

for (int i = beginCell + 1; i < endCell + 1; i++) {

cell = hssfRow.createCell((short) i);

cell.setCellType(HSSFCell.CELL_TYPE_STRING);

cell.setEncoding(HSSFCell.ENCODING_UTF_16);

cell.setCellStyle(cellStyle);

}

if (beginRow < endRow) {

for (int j = beginRow + 1; j < endRow + 1; j++) {

HSSFRow row = ReportTool.createHSSFRow(sheet, j, 300);

 

for (int i = beginCell; i < endCell + 1; i++) {

cell = row.createCell((short) i);

cell.setCellType(HSSFCell.CELL_TYPE_STRING);

cell.setEncoding(HSSFCell.ENCODING_UTF_16);

cell.setCellStyle(cellStyle);

}

}

}

 

}

 

/**

* 设置页面返回类型

* @param request

* @param response

* @param jyPath

* @throws ServletException

* @throws IOException

*/

public static void setExclType(HttpServletRequest request,

HttpServletResponse response, String jyPath) {

 

response.setContentType("application/octet-stream");

String outputFile = request.getParameter("TEMPLET_NNAME") != null ? getUnicode(

request.getParameter("TEMPLET_NNAME"), "gb2312")

+ ".xls"

: "";

HttpSession session = request.getSession();

if (outputFile.equals("")) {

// 所有状态查询标题不能为空

session.setAttribute("ADQMS9000_MESSAGE_TYPE", "1");

session.setAttribute("ADQMS9000_MESSAGE_CONTENT", "你没有权限导出!");

session.setAttribute("ADQMS9000_MESSAGE_GOTO",

"javascript:history.back(1)");

 

try {

request.getRequestDispatcher(jyPath).forward(request, response);

} catch (Exception e) {

}

}

String fileName = outputFile;

response.setHeader("Content-Disposition", "attachment;filename="

+ fileName);

}

}


分享到:
评论

相关推荐

    Excel POI 工具类

    本篇将深入探讨"Excel POI 工具类",这个工具类旨在简化日常的Excel操作,提升开发效率。 Apache POI 提供了HSSF(Horizontally Stored Sheets Format)和XSSF(XML Spreadsheet Format)两个主要的API,分别用于...

    excel poi工具类 导入 导出 合并单元格 计算公式

    这个“excel poi工具类”是利用Apache POI库来实现对Excel文件进行导入、导出、合并单元格以及处理计算公式的功能。下面我们将深入探讨这些知识点。 **1. Apache POI库介绍** Apache POI是一个开源项目,它为Java...

    poi工具类.rar

    在给定的“poi工具类.rar”压缩包中,我们可以预见到包含了一个专门针对POI 3.9版本的工具类,用于帮助开发人员更方便地处理Excel文件,并且能够将数据导出为PDF格式。这个工具类可能包含了设置页边距、背景颜色以及...

    excel导入导出(poi工具类).zip

    在本压缩包"excel导入导出(poi工具类).zip"中,我们可以预见到包含了一个或多个Java工具类,这些类可能封装了使用Apache POI进行Excel文件导入和导出的功能。接下来,我们将详细探讨Apache POI库以及如何利用它来...

    poi工具类poi导出表格的工具类

    本教程将深入探讨如何使用Apache POI工具类来高效地导出Excel表格。 **1. Apache POI的基本概念** Apache POI 提供了HSSF(Horizontally-Scattered Stream Format)和XSSF(XML Spreadsheet Format)两个主要的API...

    poi工具类poi工具类poi工具类

    poigongju

    poi工具类项目导出excel

    在本项目“poi工具类项目导出excel”中,我们主要关注的是使用 Apache POI 库来创建和导出 Excel 文件。下面将详细介绍 Apache POI 的核心概念以及如何利用它来实现 Excel 的导出功能。 Apache POI 提供了 HSSF 和 ...

    EasyPoi Excel和 Word简易工具类

    easypoi功能如同名字easy,主打的功能就是容易,让一个没见...POI 工具类,Excel的快速导入导出,Excel模板导出,Word模板导出,可以仅仅5行代码就可以完成Excel的导入导出,修改导出格式简单粗暴,快速有效,easypoi值得你尝试

    Java poi导入导出EXCEL工具类(兼容各版本)

    概述:Java poi导入导出EXCEL工具类(兼容各版本) 一、功能说明 允许同时导入或导出多个sheet,同一sheet可同时存在多个数据块,按数据块划分处理数据。 二、配置文件示例及详细说明 1、导入xml配置示例如下(见...

    Excel导入导出 jxl及Poi 工具类

    为了更好地理解这两个库的用法,你可以查看提供的"Excel导入导出(jxl及Poi)工具类"压缩包中的示例代码。通过阅读和运行这些代码,你可以更深入地了解如何在实际项目中应用jxl和Apache POI。 总的来说,jxl和Apache ...

    Excel操作组件poi工具类

    在开发过程中工具类可以简化我们的操作,提高代码重用.下面是我操作poi(一个Excel操作组件)的工具类.请大家指点

    Apache POI 工具类

    总的来说,Apache POI是Java开发中处理Office文档不可或缺的工具,通过其丰富的API,开发者可以轻松实现各种复杂的文档操作,提升工作效率。在实际项目中,理解并熟练掌握Apache POI的使用,将有助于更好地处理数据...

    java中poi读写excel封装工具类(兼容office2003和2007等版本)

    以下是对"java中poi读写excel封装工具类"这一主题的详细解释。 1. **Apache POI介绍** Apache POI是一个开源项目,允许Java开发者创建、修改和显示Microsoft Office文件,包括Excel、Word和PowerPoint。它的核心...

    邮件发送 poi 二维码 条形码等java常用的工具类

    POIUtil:poi工具类,excel导出 QrCodeUtil:二维码操作工具, 包括生成和读取 ShellUtil:shell命令操作工具,包括linux登陆,命令执行...... 较为简单,具体需要自行扩充 SignUtil:签名工具,包括MD5 位运算 ...

    POI导出工具类

    使用POI工具类,导入到项目中,引用项目的方法,修改一下内部的Bean类型,就可以将数据导出为excel格式的文件。(支持excel2013)

    java使用POI导出 Excel工具类

    java使用POI导出 Excel+图片工具类 ,里面含有poi jar包,只调用接口即可直接保存Excel。使用的时候需先把数据封装,具体包装需根据实际导出数据进行处理。文件demo中只提供包装格式。

    PoiUtils工具类

    一个比较实用的java导出excel工具类,使用的是Poi技术

    利用POI合并多个Excel表

    在这个场景下,我们可能需要用到XSSFWorkbook类来处理.xlsx格式的Excel文件。 **步骤1:设置项目依赖** 确保你的项目已经添加了Apache POI库。如果你使用的是Maven,可以在pom.xml文件中添加以下依赖: ```xml ...

    java_poi导入excel通用工具类

    这个"java_poi导入excel通用工具类"是利用Java的POI库和一些额外的技术来实现对Excel数据的导入功能,使得开发人员能够方便地将Excel数据转化为Java对象或者对已有对象进行填充。下面我们将深入探讨相关的知识点。 ...

    poi获取导入行所在的图片

    在Java的POI库中,处理Excel文件时,我们经常需要读取并操作其中的数据,包括文本、数字以及图像等元素。然而,POI API在设计时...通过这个知识点,你可以进一步完善自己的POI工具类,使其具有更强大的Excel处理能力。

Global site tag (gtag.js) - Google Analytics