Apache_POI_HSSF和XSSF读写EXCEL总结

时间:2024.1.16

Apache POI HSSF和XSSF读写EXCEL总结

HSSF是指20xx年以前的,XSSF是指20xx年版本以上的

这个还是比较好用的,这些总结来自Apache的官方向导的点点滴滴

还有好多没有没有写的,详细的请参考/spreadsheet/quick-guide.html 还有LOG也比较好看

Java代码

public class SummaryHSSF {

public static void main(String[] args) throws IOException {

//创建Workbook对象(这一个对象代表着对应的一个Excel文件)

//HSSFWorkbook表示以xls为后缀名的文件

Workbook wb = new HSSFWorkbook();

//获得CreationHelper对象,这个应该是一个帮助类

CreationHelper helper = wb.getCreationHelper();

//创建Sheet并给名字(表示Excel的一个Sheet)

Sheet sheet1 = wb.createSheet("HSSF_Sheet_1");

Sheet sheet2 = wb.createSheet("HSSF_Sheet_2");

//Row表示一行Cell表示一列

Row row = null;

Cell cell = null;

for(int i=0;i<60;i=i+2){

//获得这个sheet的第i行

row = sheet1.createRow(i);

//设置行长度自动

//row.setHeight((short)500);

row.setHeightInPoints(20);

//row.setZeroHeight(true);

for(int j=0;j<25;j++){

//设置每个sheet每一行的宽度,自动,根据需求自行确定

sheet1.autoSizeColumn(j+1, true);

//创建一个基本的样式

CellStyle cellStyle = SummaryHSSF.createStyleCell(wb);

//获得这一行的每j列

cell = row.createCell(j);

if(j==0){

//设置文字在单元格里面的位置

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle,

ApachePOIHSSF和XSSF读写EXCEL总结

CellStyle.ALIGN_CENTER,

CellStyle.VERTICAL_CENTER);

//先创建字体样式,并把这个样式加到单元格的字体里面

cellStyle.setFont(createFonts(wb));

//把这个样式加到单元格里面

cell.setCellStyle(cellStyle);

//给单元格设值

cell.setCellValue(true);

}else if(j==1){

//设置文字在单元格里面的位置

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

//设置这个样式的格式(Format)

cellStyle = SummaryHSSF.setCellFormat(helper,cellStyle, "#,##0.0000");

//先创建字体样式,并把这个样式加到单元格的字体里面

cellStyle.setFont(createFonts(wb));

//把这个样式加到单元格里面

cell.setCellStyle(cellStyle);

//给单元格设值

cell.setCellValue(new Double(2008.2008));

}else if(j==2){

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

cellStyle.setFont(createFonts(wb));

cell.setCellStyle(cellStyle);

cell.setCellValue(helper.createRichTextString("RichString"+i+j));

}else if(j==3){

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

cellStyle = SummaryHSSF.setCellFormat(helper,cellStyle, "MM-yyyy-dd");

cell.setCellStyle(cellStyle);

cell.setCellValue(new Date());

}else if(j==24){

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

cellStyle.setFont(createFonts(wb));

//设置公式

cell.setCellFormula("SUM(E"+(i+1)+":X"+(i+1)+")");

}else{

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

cellStyle = SummaryHSSF.setFillBackgroundColors(cellStyle,IndexedColors.ORANGE.getIndex(),IndexedColors.ORANGE.getIndex(),CellStyle.SOLID_FOREGROUND);

cell.setCellStyle(cellStyle);

cell.setCellValue(1);

}

}

}

//输出

OutputStream os = new FileOutputStream(new File("c://SummaryHSSF.xls")); wb.write(os);

os.close();

}

/**

* 边框

* @param wb

* @return

*/

public static CellStyle createStyleCell(Workbook wb){

CellStyle cellStyle = wb.createCellStyle();

//设置一个单元格边框颜色

cellStyle.setBorderBottom(CellStyle.BORDER_THIN);

cellStyle.setBorderTop(CellStyle.BORDER_THIN);

cellStyle.setBorderLeft(CellStyle.BORDER_THIN);

cellStyle.setBorderRight(CellStyle.BORDER_THIN);

//设置一个单元格边框颜色

cellStyle.setRightBorderColor(IndexedColors.BLACK.getIndex());

cellStyle.setLeftBorderColor(IndexedColors.BLACK.getIndex());

cellStyle.setBottomBorderColor(IndexedColors.BLACK.getIndex());

cellStyle.setTopBorderColor(IndexedColors.BLACK.getIndex());

return cellStyle;

}

/**

* 设置文字在单元格里面的位置

* CellStyle.ALIGN_CENTER

* CellStyle.VERTICAL_CENTER

* @param cellStyle

* @param halign

* @param valign

* @return

*/

public static CellStyle setCellStyleAlignment(CellStyle cellStyle,short halign,short valign){ //设置上下

cellStyle.setAlignment(CellStyle.ALIGN_CENTER);

//设置左右

cellStyle.setVerticalAlignment(CellStyle.VERTICAL_CENTER);

return cellStyle;

}

/**

* 格式化单元格

* 如#,##0.00,m/d/yy去HSSFDataFormat或XSSFDataFormat里面找

* @param cellStyle

* @param fmt

* @return

*/

public static CellStyle setCellFormat(CreationHelper helper,CellStyle cellStyle,String fmt){ //还可以用其它方法创建format

cellStyle.setDataFormat(helper.createDataFormat().getFormat(fmt));

return cellStyle;

}

/**

* 前景和背景填充的着色

* @param cellStyle

* @param bg IndexedColors.ORANGE.getIndex();

* @param fg IndexedColors.ORANGE.getIndex();

* @param fp CellStyle.SOLID_FOREGROUND

* @return

*/

public static CellStyle setFillBackgroundColors(CellStyle cellStyle,short bg,short fg,short fp){ //cellStyle.setFillBackgroundColor(bg);

cellStyle.setFillForegroundColor(fg);

cellStyle.setFillPattern(fp);

return cellStyle;

}

/**

* 设置字体

* @param wb

* @return

*/

public static Font createFonts(Workbook wb){

//创建Font对象

Font font = wb.createFont();

//设置字体

font.setFontName("黑体");

//着色

font.setColor(HSSFColor.BLUE.index);

//斜体

font.setItalic(true);

//字体大小

font.setFontHeight((short)300);

return font;

}

}

public class SummaryHSSF {

public static void main(String[] args) throws IOException {

//创建Workbook对象(这一个对象代表着对应的一个Excel文件) //HSSFWorkbook表示以xls为后缀名的文件

Workbook wb = new HSSFWorkbook();

//获得CreationHelper对象,这个应该是一个帮助类

CreationHelper helper = wb.getCreationHelper();

//创建Sheet并给名字(表示Excel的一个Sheet)

Sheet sheet1 = wb.createSheet("HSSF_Sheet_1");

Sheet sheet2 = wb.createSheet("HSSF_Sheet_2");

//Row表示一行Cell表示一列

Row row = null;

Cell cell = null;

for(int i=0;i<60;i=i+2){

//获得这个sheet的第i行

row = sheet1.createRow(i);

//设置行长度自动

//row.setHeight((short)500);

row.setHeightInPoints(20);

//row.setZeroHeight(true);

for(int j=0;j<25;j++){

//设置每个sheet每一行的宽度,自动,根据需求自行确定 sheet1.autoSizeColumn(j+1, true);

//创建一个基本的样式

CellStyle cellStyle = SummaryHSSF.createStyleCell(wb);

//获得这一行的每j列

cell = row.createCell(j);

if(j==0){

//设置文字在单元格里面的位置

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.VERTICAL_CENTER);

//先创建字体样式,并把这个样式加到单元格的字体里面 cellStyle.setFont(createFonts(wb));

//把这个样式加到单元格里面

cell.setCellStyle(cellStyle);

//给单元格设值

cell.setCellValue(true);

}else if(j==1){

//设置文字在单元格里面的位置

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.ALIGN_CENTER,

CellStyle.VERTICAL_CENTER);

//设置这个样式的格式(Format)

cellStyle = SummaryHSSF.setCellFormat(helper,cellStyle, "#,##0.0000");

//先创建字体样式,并把这个样式加到单元格的字体里面

cellStyle.setFont(createFonts(wb));

//把这个样式加到单元格里面

cell.setCellStyle(cellStyle);

//给单元格设值

cell.setCellValue(new Double(2008.2008));

}else if(j==2){

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

cellStyle.setFont(createFonts(wb));

cell.setCellStyle(cellStyle);

cell.setCellValue(helper.createRichTextString("RichString"+i+j));

}else if(j==3){

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

cellStyle = SummaryHSSF.setCellFormat(helper,cellStyle, "MM-yyyy-dd");

cell.setCellStyle(cellStyle);

cell.setCellValue(new Date());

}else if(j==24){

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

cellStyle.setFont(createFonts(wb));

//设置公式

cell.setCellFormula("SUM(E"+(i+1)+":X"+(i+1)+")");

}else{

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

cellStyle = SummaryHSSF.setFillBackgroundColors(cellStyle,IndexedColors.ORANGE.getIndex(),IndexedColors.ORANGE.getIndex(),CellStyle.SOLID_FOREGROUND);

cell.setCellStyle(cellStyle);

cell.setCellValue(1);

}

}

}

//输出

OutputStream os = new FileOutputStream(new File("c://SummaryHSSF.xls"));

wb.write(os);

os.close();

}

/**

* 边框

* @param wb

* @return

*/

public static CellStyle createStyleCell(Workbook wb){

CellStyle cellStyle = wb.createCellStyle();

//设置一个单元格边框颜色

cellStyle.setBorderBottom(CellStyle.BORDER_THIN);

cellStyle.setBorderTop(CellStyle.BORDER_THIN);

cellStyle.setBorderLeft(CellStyle.BORDER_THIN);

cellStyle.setBorderRight(CellStyle.BORDER_THIN);

//设置一个单元格边框颜色

cellStyle.setRightBorderColor(IndexedColors.BLACK.getIndex());

cellStyle.setLeftBorderColor(IndexedColors.BLACK.getIndex());

cellStyle.setBottomBorderColor(IndexedColors.BLACK.getIndex());

cellStyle.setTopBorderColor(IndexedColors.BLACK.getIndex());

return cellStyle;

}

/**

* 设置文字在单元格里面的位置

* CellStyle.ALIGN_CENTER

* CellStyle.VERTICAL_CENTER

* @param cellStyle

* @param halign

* @param valign

* @return

*/

public static CellStyle setCellStyleAlignment(CellStyle cellStyle,short halign,short valign){ //设置上下

cellStyle.setAlignment(CellStyle.ALIGN_CENTER);

//设置左右

cellStyle.setVerticalAlignment(CellStyle.VERTICAL_CENTER);

return cellStyle;

}

/**

* 格式化单元格

* 如#,##0.00,m/d/yy去HSSFDataFormat或XSSFDataFormat里面找

* @param cellStyle

* @param fmt

* @return

*/

public static CellStyle setCellFormat(CreationHelper helper,CellStyle cellStyle,String fmt){ //还可以用其它方法创建format

cellStyle.setDataFormat(helper.createDataFormat().getFormat(fmt));

return cellStyle;

}

/**

* 前景和背景填充的着色

* @param cellStyle

* @param bg IndexedColors.ORANGE.getIndex();

* @param fg IndexedColors.ORANGE.getIndex();

* @param fp CellStyle.SOLID_FOREGROUND

* @return

*/

public static CellStyle setFillBackgroundColors(CellStyle cellStyle,short bg,short fg,short fp){ //cellStyle.setFillBackgroundColor(bg);

cellStyle.setFillForegroundColor(fg);

cellStyle.setFillPattern(fp);

return cellStyle;

}

/**

* 设置字体

* @param wb

* @return

*/

public static Font createFonts(Workbook wb){

//创建Font对象

Font font = wb.createFont();

//设置字体

font.setFontName("黑体");

//着色

font.setColor(HSSFColor.BLUE.index);

//斜体

font.setItalic(true);

//字体大小

font.setFontHeight((short)300);

return font;

}

}

读取Excel文件

Java代码

public class ReadExcel {

public static void main(String[] args) throws Exception {

InputStream is = new FileInputStream(new File("c://SummaryHSSF.xls"));

//根据输入流创建Workbook对象

Workbook wb = WorkbookFactory.create(is);

//get到Sheet对象

Sheet sheet = wb.getSheetAt(0);

//这个必须用接口

for(Row row : sheet){

for(Cell cell : row){

//cell.getCellType是获得cell里面保存的值的type

//如Cell.CELL_TYPE_STRING

switch(cell.getCellType()){

case Cell.CELL_TYPE_BOOLEAN:

//得到Boolean对象的方法

System.out.print(cell.getBooleanCellValue()+" ");

break;

case Cell.CELL_TYPE_NUMERIC:

//先看是否是日期格式

if(DateUtil.isCellDateFormatted(cell)){

//读取日期格式

System.out.print(cell.getDateCellValue()+" ");

}else{

//读取数字

System.out.print(cell.getNumericCellValue()+" ");

}

break;

case Cell.CELL_TYPE_FORMULA:

//读取公式

System.out.print(cell.getCellFormula()+" ");

break;

case Cell.CELL_TYPE_STRING:

//读取String

System.out.print(cell.getRichStringCellValue().toString()+" "); break;

}

}

System.out.println("");

}

}

}

public class ReadExcel {

public static void main(String[] args) throws Exception {

InputStream is = new FileInputStream(new File("c://SummaryHSSF.xls")); //根据输入流创建Workbook对象

Workbook wb = WorkbookFactory.create(is);

//get到Sheet对象

Sheet sheet = wb.getSheetAt(0);

//这个必须用接口

for(Row row : sheet){

for(Cell cell : row){

//cell.getCellType是获得cell里面保存的值的type //如Cell.CELL_TYPE_STRING

switch(cell.getCellType()){

case Cell.CELL_TYPE_BOOLEAN:

//得到Boolean对象的方法

System.out.print(cell.getBooleanCellValue()+" "); break;

case Cell.CELL_TYPE_NUMERIC:

//先看是否是日期格式

if(DateUtil.isCellDateFormatted(cell)){

//读取日期格式

System.out.print(cell.getDateCellValue()+" ");

}else{

//读取数字

System.out.print(cell.getNumericCellValue()+" "); }

break;

case Cell.CELL_TYPE_FORMULA:

//读取公式

System.out.print(cell.getCellFormula()+" ");

break;

case Cell.CELL_TYPE_STRING:

//读取String

System.out.print(cell.getRichStringCellValue().toString()+" "); break;

}

}

System.out.println("");

}

}

}

还有一种传统的读法

Java代码

Sheet sheet = wb.getSheetAt(0);

for (Iterator rit = sheet.rowIterator(); rit.hasNext(); ) { Row row = (Row)rit.next();

for (Iterator cit = row.cellIterator(); cit.hasNext(); ) { Cell cell = (Cell)cit.next();

// Do something here

}

}

HSSFSheet sheet = wb.getSheetAt(0);

for (Iterator<HSSFRow> rit = (Iterator<HSSFRow>)sheet.rowIterator(); rit.hasNext(); ) { HSSFRow row = rit.next();

for (Iterator<HSSFCell> cit = (Iterator<HSSFCell>)row.cellIterator(); cit.hasNext(); ) { HSSFCell cell = cit.next();

// Do something here

}

}

Sheet sheet = wb.getSheetAt(0);

for (Iterator rit = sheet.rowIterator(); rit. has Next(); ) {

Row row = (Row)rit.next();

for (Iterator cit = row.cellIterator(); cit.hasNext(); ) {

Cell cell = (Cell)cit.next();

// Do something here

}

}

HSSFSheet sheet = wb.getSheetAt(0);

for (Iterator<HSSFRow> rit = (Iterator<HSSFRow>)sheet.rowIterator(); rit.hasNext(); ) { HSSFRow row = rit.next();

for (Iterator<HSSFCell> cit = (Iterator<HSSFCell>)row.cellIterator(); cit.hasNext(); ) { HSSFCell cell = cit.next();

// Do something here

}

}

更多相关推荐:
APEC会议期间安全生产工作总结

北京地铁8号线三期工程编制人:审核人:审批人:八号线三期**标段于20xx年x月x日开工核查通过,26日正式开工,进行风道围护结构桩基施工,根据轨道公司《20xx年APEC会议期间特保期保障工作方案》以及《…

APEC会议期间村党支部工作总结

APEC会议期间村党支部工作总结APEC会议期间,我村党组织高度重视,认真学习了此期间各项保障精神学习文件,将此期间保障任务作为了头等大事来对待。一、成立工作小组APEC会议期间我村分别成立了以村党支部为首、全…

APEC会议社会面火灾防控工作总结

桥梓镇20xx年APEC会议社会面火灾防控5-8月份工作总结为贯彻落实怀柔区防火安全委员会《亚太经合组织第二十二次会议社会面火灾防控工作方案》精神,杜绝火灾事故发生,保障桥梓镇人民生命财产安全,确保APEC会议…

05总监办APEC会议期间安全生产工作总结

地铁8号线三期土建施工监理05合同段APEC会议期间安全生产工作总结北京方达工程管理有限公司北京地铁8号线三期工程土建施工监理05合同段总监办二零一四年十一月十六日APEC会议期间安全生产工作总结根据北京市轨道...

APEC总结

Xxxxx公司APEC会议期间道路运输秩序保障的总结20xx年11月5日至11日亚太经合组织APEC第22次领导人非正式会议及相关活动将在北京举行为确保会议期间北京交通运输环境秩序安全稳定和谐有效新乡市新运交通...

20xx APEC 青年周感想

作为apec青年周的一名志愿者,我为见证那历史性的一刻而感到自豪。我的岗位在音控室,负责保障会场麦克风和投影仪等的正常使用,事实上这是再简单不过的事,因为有专业的音控师傅来操作,并不需要志愿者有多么强的技术要求…

APEC交通服务总结表彰大会上的讲话

在执行APEC峰会交通服务任务表彰大会上的总结讲话北汽集团董事长总经理张峻峰各位领导同志们大家下午好下面我针对北汽集团执行2104北京APEC峰会交通服务保障任务做一简要的小结20xx年APEC峰会是十八大以来...

APEC蓝

对APEC蓝的看法刚刚过去不久的APEC会议除了达成令人瞩目的诸多经济成果,最让咱们老百姓高兴的就是会议期间万里无云的蓝天和清新的空气。天公作美,“APEC蓝”没随同会议的结束如期而退,众多民众最期望的就是“A…

20xx APEC 青年周感

我与APEC青年周作为一名大一新生能通过层层选拔成为交大站的志愿者真的是我APEC假期最难忘的经历我所在的组是铁道博物馆组我的工作主要是引导代表们入场并全程陪同交流代表们来的前一天我们去熟悉了铁道博物馆记下了相...

学习pdca的心得体会

学习PDCA后的心得体会昨天很荣幸地在李总的带领下学习了PDCA管理方法现将本人对PDCA的认识和学习后的一些心得体会汇报如下PDCA又叫戴明环它将一个解决问题需要的四个阶段即计划实施检查处理完美有序地揉和在一...

pdca计划

计划Plan实施Do检查Check处理ActionISO9000认证的核心是持续改进以下是我在网上找的和我学的一样供参考PDCA循环也称戴明环是由美国著名质量管理专家戴明WEDeming首先提出的这个循环主要包...

pdca模式

PDCA管理模式计划Plan实施Do检查Check处理ActionISO9000认证的核心是持续改进以下是我在网上找的和我学的一样供参考PDCA循环也称戴明环是由美国著名质量管理专家戴明WEDeming首先提出...

apec总结(3篇)