`
阅读更多
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_API1.6文档(中文)

    java.lang.management 提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。 java.lang.ref 提供了引用对象类,支持在某种程度上与垃圾回收器之间的交互。 java.lang.reflect 提供类...

    Java 面经手册·小傅哥.pdf

    这是一本以面试题为入口讲解 Java 核心内容的技术书籍,书中内容极力的向你证实代码是对数学逻辑的具体实现。当你仔细阅读书籍时,会发现Java中有大量的数学知识,包括:扰动函数、负载因子、拉链寻址、开放寻址、...

    java源码包---java 源码 大量 实例

    Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这款实例会对你有所帮助。 Calendar万年历 1个目标文件 EJB 模拟银行ATM流程及操作源代码 6个目标文件,EJB来模拟银行ATM...

    JAVA上百实例源码以及开源项目

     Java局域网通信——飞鸽传书源代码,大家都知道VB版、VC版还有Delphi版的飞鸽传书软件,但是Java版的确实不多,因此这个Java文件传输实例不可错过,Java网络编程技能的提升很有帮助。 Java聊天程序,包括服务端和...

    java源码包2

    Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这款实例会对你有所帮助。 Calendar万年历 1个目标文件 EJB 模拟银行ATM流程及操作源代码 6个目标文件,EJB来模拟银行...

    java源码包4

    Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这款实例会对你有所帮助。 Calendar万年历 1个目标文件 EJB 模拟银行ATM流程及操作源代码 6个目标文件,EJB来模拟银行...

    java源码包3

    Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这款实例会对你有所帮助。 Calendar万年历 1个目标文件 EJB 模拟银行ATM流程及操作源代码 6个目标文件,EJB来模拟银行...

    java api最新7.0

    JAVA开发人员最新版本7.0 api文档!本文档是 Java Platform Standard Edition 7 的 API !Java 1.7 API的中文帮助文档。 深圳电信培训中心 徐海蛟博士教学用api 7.0中文文档。支持全文检索,在线即时查询。 里面列...

    java开源包11

    JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...

    java开源包4

    JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...

    java开源包6

    JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...

    java开源包9

    JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...

    java开源包5

    JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...

    java开源包8

    JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...

    java开源包10

    JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...

    Java开发技术大全(500个源代码).

    HelloWorldApp.java 第一个用Java开发的应用程序。 firstApplet.java 第一个用Java开发的Applet小程序。 firstApplet.htm 用来装载Applet的网页文件 第2章 示例描述:本章介绍开发Java的基础语法知识。 ...

    java开源包1

    JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...

    java开源包3

    JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java对象集进行查询,排序,分组。 搜索自动提示 Autotips AutoTips是为解决应用系统对于...

    Java 中文入门学习手册合集[chm版]

    第一章 Java语言的产生及其特点 第二章 Java程序开发与运行环境 第三章 Java程序设计基础 第四章 Java应用程序的基本框架 第五章 Java的类 第六章 Java图形用户接口 第七章 多线程 第八章 Java的"异常" 第九...

Global site tag (gtag.js) - Google Analytics