`
阅读更多
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源码包---java 源码 大量 实例

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

    Java 面经手册·小傅哥.pdf

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

    Java OCR 图像智能字符识别技术,可识别中文

    Java OCR(Optical Character Recognition,光学字符识别)技术是一种计算机视觉领域的应用,它能将图像中的文字转换成可编辑的文本格式。这项技术在各种场景下都有广泛应用,比如文档扫描、车牌识别、发票处理等。...

    Java API文档 中文网页版

    Java API文档是Java开发者的重要参考资料,它包含了Java开发工具包(JDK)中的所有类、接口、方法和常量的详细说明。这份中文网页版的Java API文档为中国的开发者提供了便利,无需通过英文版本来学习和查找API信息,...

    java_011 java 人脸识别完整源代码

    java_011 java 人脸识别完整源代码java_011 java 人脸识别完整源代码java_011 java 人脸识别完整源代码java_011 java 人脸识别完整源代码java_011 java 人脸识别完整源代码java_011 java 人脸识别完整源代码java_011...

    java源码包2

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

    java源码包实例源码JAVA开发源码50个合集.zip

    java源码包实例源码JAVA开发源码50个合集: Ajax框架 ZK.rar Java图书馆管理系统源程序.rar Java图片倒影效果实例源码.rar Java图片翻折,将图像压扁.rar Java坦克大战网络对战版源代码.rar Java声音播放程序源代码....

    java api最新7.0

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

    java笔记 java笔记

    ### Java基础知识概述 #### 1. 前言 Java是一种广泛使用的面向对象的编程语言,因其跨平台性、安全性和强大的功能而受到欢迎。Java的设计理念是“一次编写,到处运行”,这意味着编写的Java程序可以在任何安装了...

    java景点导航系统java景点导航系统

    java景点导航系统java景点导航系统java景点导航系统java景点导航系统java景点导航系统java景点导航系统java景点导航系统java景点导航系统java景点导航系统java景点导航系统java景点导航系统java景点导航系统java景点...

    java单机小游戏.zip

    java单机小游戏java单机小游戏java单机小游戏java单机小游戏 java单机小游戏java单机小游戏java单机小游戏java单机小游戏 java单机小游戏java单机小游戏java单机小游戏java单机小游戏 java单机小游戏java单机小游戏...

    java开源包4

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

    Java学习资料全套.zip

    最新全套Java学习资料打包 最新全套Java学习资料打包 最新全套Java学习资料打包 最新全套Java学习资料打包 最新全套Java学习资料打包 最新全套Java学习资料打包 最新全套Java学习资料打包 最新全套Java...

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

    日历表格面板 [ConfigLine.java] 控制条类 [RoundBox.java] 限定选择控件 [MonthMaker.java] 月份表算法类 [Pallet.java] 调色板,统一配色类 Java扫雷源码 Java生成自定义控件源代码 2个目标文件 Java实现HTTP连接...

    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错误处理:java.lang.OutOfMemoryError: Java heap space

    ### Java 错误处理:java.lang.OutOfMemoryError: Java heap space 在Java应用程序开发过程中,经常遇到的一个问题就是内存溢出错误,特别是在处理大量数据或长时间运行的应用时。其中,“java.lang....

    从Java菜鸟到专家的资料

    这份名为“从Java菜鸟到专家的资料”的压缩包文件包含了丰富的学习资源,旨在帮助初学者逐步成长为Java领域的专家。以下是对各个文件的详细解读: 1. **J2EE研究文集.chm**:这个文件专注于Java企业级应用开发,...

Global site tag (gtag.js) - Google Analytics