博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java excel导出 poi 后缀名_Java使用poi生成Excel
阅读量:5149 次
发布时间:2019-06-13

本文共 3235 字,大约阅读时间需要 10 分钟。

package test.cc;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.OutputStream;

import java.util.ArrayList;

import java.util.List;

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

import org.apache.poi.hssf.util.HSSFColor;

public class poi {

public static String[] headers={"第一个","第二个","第三个"};

public static String[] data1={"数据1","数据11","数据111"};

public static String[] data2={"数据2","数据22","数据222"};

public static List dataset=new ArrayList(){

{

add(data1);

add(data2);

}

};

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

OutputStream os=new FileOutputStream("test.xlsx");

// 声明一个工作薄

HSSFWorkbook workbook = new HSSFWorkbook();

try {

// 生成一个表格

HSSFSheet sheet = workbook.createSheet("testtest");

// 生成一个样式

HSSFCellStyle headerStyle = workbook.createCellStyle();

// 设置这些样式

headerStyle.setFillForegroundColor(HSSFColor.SKY_BLUE.index);

headerStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);

headerStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);

headerStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);

headerStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);

headerStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);

headerStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);

// 生成一个字体

HSSFFont headerFont = workbook.createFont();

headerFont.setColor(HSSFColor.VIOLET.index);

headerFont.setFontHeightInPoints((short) 12);

headerFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);

// 把字体应用到当前的样式

headerStyle.setFont(headerFont);

// 生成并设置另一个样式

HSSFCellStyle dataStyle = workbook.createCellStyle();

dataStyle.setFillForegroundColor(HSSFColor.LIGHT_YELLOW.index);

dataStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);

dataStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);

dataStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);

dataStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);

dataStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);

dataStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);

dataStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);

// 生成另一个字体

HSSFFont dataFont = workbook.createFont();

dataFont.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);

// 把字体应用到当前的样式

dataStyle.setFont(dataFont);

// 产生表格标题行

HSSFRow row = sheet.createRow(0);

HSSFCell noCell = row.createCell(0);

noCell.setCellStyle(headerStyle);

noCell.setCellValue("编号");

for (int headerIndex = 0; headerIndex < headers.length; headerIndex++) {

HSSFCell headerCell = row.createCell(headerIndex + 1);

headerCell.setCellStyle(headerStyle);

HSSFRichTextString text = new HSSFRichTextString(headers[headerIndex]);

headerCell.setCellValue(text);

}

// 遍历集合数据,产生数据行

for (int dataIndex = 0; dataIndex < dataset.size(); dataIndex++) {

row = sheet.createRow(dataIndex + 1);

HSSFCell dataNoCell = row.createCell(0);

dataNoCell.setCellStyle(dataStyle);

dataNoCell.setCellValue(dataIndex + 1);

String[] rowData = dataset.get(dataIndex);

for (int fieldIndex = 0; fieldIndex < rowData.length; fieldIndex++) {

HSSFCell dataCell = row.createCell(fieldIndex + 1);

dataCell.setCellStyle(dataStyle);

dataCell.setCellValue(rowData[fieldIndex]);

}

}

for (int columnIndex = 0; columnIndex < headers.length + 1; columnIndex++) {

sheet.autoSizeColumn(columnIndex, true);

}

} catch (Exception e) {

e.printStackTrace();

} finally {

// 清理资源

workbook.write(os);

workbook.close();

}

}

}

转载地址:http://bodnv.baihongyu.com/

你可能感兴趣的文章
我要翻译《Think Python》 - 开篇申明
查看>>
MS SQL Server2012中的CONCAT函数
查看>>
不一样的编辑器
查看>>
博客园安家--写给自己
查看>>
B/S和C/S架构的区别
查看>>
[Java] Java record
查看>>
jQuery - 控制元素显示、隐藏、切换、滑动的方法
查看>>
postgresql学习文档
查看>>
python 列表中的数字转为字符串
查看>>
Struts2返回JSON数据的具体应用范例
查看>>
js深度克隆对象、数组
查看>>
c++ 贪吃蛇
查看>>
socket阻塞与非阻塞,同步与异步
查看>>
图论求割点模板
查看>>
poj3903 Stock Exchange 二分+dp
查看>>
Okhttp代码
查看>>
点击树结构实现变色
查看>>
【IT笔试面试题整理】字符串的排列
查看>>
算法描述---伪代码
查看>>
RT-thread 设备驱动组件之IIC总线设备
查看>>