package com.zcj.poi;
import java.io.FileOutputStream;
import java.util.Calendar;
import java.util.Date;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.BorderStyle;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.CellType;
import org.apache.poi.ss.usermodel.CreationHelper;
import org.apache.poi.ss.usermodel.HorizontalAlignment;
import org.apache.poi.ss.usermodel.IndexedColors;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.VerticalAlignment;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.util.WorkbookUtil;
import org.junit.Test;
public class PoiDemo001 {
@Test
public void test() throws Exception{
Workbook wb = new HSSFWorkbook();//创建excel文件
Sheet sheet1 = wb.createSheet("sheet1");//创建工作簿
String safeName = WorkbookUtil.createSafeSheetName("[zhou'sheet2*?]");//创建安全的工作簿名
Sheet sheet2 = wb.createSheet(safeName);
FileOutputStream execl = new FileOutputStream("workbook.xls");//创建一个文件流
wb.write(execl);//把内容写入流
execl.close();
}
@Test
public void testCells() throws Exception{
Workbook wb = new HSSFWorkbook();//创建excel文件
CreationHelper creationHelper = wb.getCreationHelper();
Sheet sheet1 = wb.createSheet("sheet1");//创建工作簿
Row row = sheet1.createRow(0);//定位行
Cell cell = row.createCell(0);//定位单元格
cell.setCellValue("cell");
row.createCell(1).setCellValue(9.9);
row.createCell(2).setCellValue(creationHelper.createRichTextString("This is a String"));
row.createCell(3).setCellValue(true);
String safeName = WorkbookUtil.createSafeSheetName("[zhou'sheet2*?]");//创建安全的工作簿名
Sheet sheet2 = wb.createSheet(safeName);
FileOutputStream execl = new FileOutputStream("workbook.xls");//创建一个文件流
wb.write(execl);//把内容写入流
execl.close();
}
@Test
public void testCreatingDateCells() throws Exception{
Workbook wb = new HSSFWorkbook();//创建excel文件
CreationHelper creationHelper = wb.getCreationHelper();
CellStyle style = wb.createCellStyle();//创建样式
style.setDataFormat(creationHelper.createDataFormat().getFormat("m/d/yy h:mm"));//设置时间样式
Sheet sheet1 = wb.createSheet("sheet1");//创建工作簿
Row row = sheet1.createRow(0);//定位行
Cell cell = null;
cell = row.createCell(0);
cell.setCellValue(new Date());//不使用样式
cell = row.createCell(1);
cell.setCellValue(new Date());
cell.setCellStyle(style);//使用样式
cell = row.createCell(2);
cell.setCellValue(Calendar.getInstance());//使用日历
cell.setCellStyle(style);
FileOutputStream execl = new FileOutputStream("workbook.xls");//创建一个文件流
wb.write(execl);//把内容写入流
execl.close();
}
@Test
public void testWorkingWithDifferentTypesOfCells() throws Exception{
Workbook wb = new HSSFWorkbook();//创建excel文件
CreationHelper creationHelper = wb.getCreationHelper();
CellStyle style = wb.createCellStyle();//创建样式
style.setDataFormat(creationHelper.createDataFormat().getFormat("m/d/yy h:mm"));//设置时间样式
Sheet sheet1 = wb.createSheet("sheet1");//创建工作簿
Row row = sheet1.createRow(0);//定位行
row.createCell(0).setCellValue(true);
row.createCell(1).setCellValue(Calendar.getInstance());
row.createCell(2).setCellValue(new Date());
row.createCell(3).setCellValue(9.9);
row.createCell(4).setCellValue(creationHelper.createRichTextString("This is a String"));
row.createCell(5).setCellValue("String");
row.createCell(6).setCellType(CellType.ERROR);
FileOutputStream execl = new FileOutputStream("workbook.xls");//创建一个文件流
wb.write(execl);//把内容写入流
execl.close();
}
@Test
public void testDemonstratesVariousAlignmentOptions() throws Exception{
Workbook wb = new HSSFWorkbook();//创建excel文件
Sheet sheet1 = wb.createSheet("sheet1");//创建工作簿
Row row = sheet1.createRow(0);//定位行
row.setHeightInPoints(30);
createCell(wb, row, 0, HorizontalAlignment.LEFT, VerticalAlignment.TOP);
createCell(wb, row, 1, HorizontalAlignment.LEFT, VerticalAlignment.CENTER);
createCell(wb, row, 2, HorizontalAlignment.LEFT, VerticalAlignment.BOTTOM);
createCell(wb, row, 3, HorizontalAlignment.CENTER, VerticalAlignment.TOP);
createCell(wb, row, 4, HorizontalAlignment.CENTER, VerticalAlignment.CENTER);
createCell(wb, row, 5, HorizontalAlignment.CENTER, VerticalAlignment.BOTTOM);
createCell(wb, row, 6, HorizontalAlignment.RIGHT, VerticalAlignment.TOP);
createCell(wb, row, 7, HorizontalAlignment.RIGHT, VerticalAlignment.CENTER);
createCell(wb, row, 8, HorizontalAlignment.RIGHT, VerticalAlignment.BOTTOM);
FileOutputStream execl = new FileOutputStream("workbook.xls");//创建一个文件流
wb.write(execl);//把内容写入流
execl.close();
}
/**
* 设置单元格水平垂直对象方向
* @param wb excel
* @param row 行
* @param column 列
* @param halign 水平方向
* @param valign 垂直方向
*/
private static void createCell(Workbook wb,Row row,Integer column,HorizontalAlignment halign,VerticalAlignment valign){
Cell cell = row.createCell(column);
cell.setCellValue("Align It");
CellStyle cellStyle = wb.createCellStyle();
cellStyle.setAlignment(halign);
cellStyle.setVerticalAlignment(valign);
cell.setCellStyle(cellStyle);
}
@Test
public void testWorkingWithBorders() throws Exception{
Workbook wb = new HSSFWorkbook();//创建excel文件
CreationHelper creationHelper = wb.getCreationHelper();
CellStyle cellStyle = wb.createCellStyle();//创建样式
//设置边框线条样式
cellStyle.setBorderBottom(BorderStyle.THIN);
cellStyle.setBorderTop(BorderStyle.THIN);
cellStyle.setBorderLeft(BorderStyle.DOUBLE);
cellStyle.setBorderRight(BorderStyle.DOUBLE);
//设置边框线条颜色
cellStyle.setBottomBorderColor(IndexedColors.RED.getIndex());
cellStyle.setTopBorderColor(IndexedColors.RED.getIndex());
cellStyle.setLeftBorderColor(IndexedColors.BLUE.getIndex());
cellStyle.setRightBorderColor(IndexedColors.BLUE.getIndex());
Sheet sheet1 = wb.createSheet("sheet1");//创建工作簿
Row row = sheet1.createRow(1);//定位行
Cell cell = row.createCell(1);
cell.setCellValue("边框");
cell.setCellStyle(cellStyle);
FileOutputStream execl = new FileOutputStream("workbook.xls");//创建一个文件流
wb.write(execl);//把内容写入流
execl.close();
}
@Test
public void tests() throws Exception{
Workbook wb = new HSSFWorkbook();//创建excel文件
CreationHelper creationHelper = wb.getCreationHelper();
CellStyle cellStyle = wb.createCellStyle();//创建样式
//设置边框线条样式
cellStyle.setBorderBottom(BorderStyle.THIN);
cellStyle.setBorderTop(BorderStyle.THIN);
cellStyle.setBorderLeft(BorderStyle.DOUBLE);
cellStyle.setBorderRight(BorderStyle.DOUBLE);
//设置边框线条颜色
cellStyle.setBottomBorderColor(IndexedColors.RED.getIndex());
cellStyle.setTopBorderColor(IndexedColors.RED.getIndex());
cellStyle.setLeftBorderColor(IndexedColors.BLUE.getIndex());
cellStyle.setRightBorderColor(IndexedColors.BLUE.getIndex());
Sheet sheet1 = wb.createSheet("sheet1");//创建工作簿
Row row = sheet1.createRow(1);//定位行
Cell cell = row.createCell(1);
cell.setCellValue("边框");
cell.setCellStyle(cellStyle);
FileOutputStream execl = new FileOutputStream("workbook.xls");//创建一个文件流
wb.write(execl);//把内容写入流
execl.close();
}
@Test
public void testss() throws Exception{
Workbook wb = new HSSFWorkbook();
Sheet sheet = wb.createSheet("new sheet");
// Create a row and put some cells in it. Rows are 0 based.
Row row = sheet.createRow((short) 1);
// Aqua background
CellStyle style = wb.createCellStyle();
style.setFillBackgroundColor(IndexedColors.AQUA.getIndex());
style.setFillPattern(CellStyle.BIG_SPOTS);
Cell cell = row.createCell((short) 1);
cell.setCellValue("X");
cell.setCellStyle(style);
// Orange "foreground", foreground being the fill foreground not the font color.
style = wb.createCellStyle();
style.setFillForegroundColor(IndexedColors.ORANGE.getIndex());
style.setFillPattern(CellStyle.SOLID_FOREGROUND);
cell = row.createCell((short) 2);
cell.setCellValue("Y");
cell.setCellStyle(style);
// Write the output to a file
FileOutputStream fileOut = new FileOutputStream("workbook.xls");
wb.write(fileOut);
fileOut.close();
}
}
分享到:
相关推荐
java.lang.management 提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。 java.lang.ref 提供了引用对象类,支持在某种程度上与垃圾回收器之间的交互。 java.lang.reflect 提供类...
这是一本以面试题为入口讲解 Java 核心内容的技术书籍,书中内容极力的向你证实代码是对数学逻辑的具体实现。当你仔细阅读书籍时,会发现Java中有大量的数学知识,包括:扰动函数、负载因子、拉链寻址、开放寻址、...
Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这款实例会对你有所帮助。 Calendar万年历 1个目标文件 EJB 模拟银行ATM流程及操作源代码 6个目标文件,EJB来模拟银行ATM...
Java局域网通信——飞鸽传书源代码,大家都知道VB版、VC版还有Delphi版的飞鸽传书软件,但是Java版的确实不多,因此这个Java文件传输实例不可错过,Java网络编程技能的提升很有帮助。 Java聊天程序,包括服务端和...
Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这款实例会对你有所帮助。 Calendar万年历 1个目标文件 EJB 模拟银行ATM流程及操作源代码 6个目标文件,EJB来模拟银行...
Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这款实例会对你有所帮助。 Calendar万年历 1个目标文件 EJB 模拟银行ATM流程及操作源代码 6个目标文件,EJB来模拟银行...
Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这款实例会对你有所帮助。 Calendar万年历 1个目标文件 EJB 模拟银行ATM流程及操作源代码 6个目标文件,EJB来模拟银行...
JAVA开发人员最新版本7.0 api文档!本文档是 Java Platform Standard Edition 7 的 API !Java 1.7 API的中文帮助文档。 深圳电信培训中心 徐海蛟博士教学用api 7.0中文文档。支持全文检索,在线即时查询。 里面列...
JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...
JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...
JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...
JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...
JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...
JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...
JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...
HelloWorldApp.java 第一个用Java开发的应用程序。 firstApplet.java 第一个用Java开发的Applet小程序。 firstApplet.htm 用来装载Applet的网页文件 第2章 示例描述:本章介绍开发Java的基础语法知识。 ...
JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...
JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...
第一章 Java语言的产生及其特点 第二章 Java程序开发与运行环境 第三章 Java程序设计基础 第四章 Java应用程序的基本框架 第五章 Java的类 第六章 Java图形用户接口 第七章 多线程 第八章 Java的"异常" 第九...