Poi 生成xls
来首小诗:
今日不胜昨日寒,我却把那拖鞋穿,脚儿冰冰秋风瑟,抬头一看碧蓝天。 ---泥沙砖瓦浆木匠
项目需求:
p2p项目中,需要一些数据报表一xls的格式,提供下载。并给主管签名。
方案:
------------------------
poi 3.9
------------------------
第一步学习:
了解poi:
Apache POI是一个开源的Java读写Excel、WORD等微软OLE2组件文档的项目。目前POI已经有了Ruby版本。
结构:
- HSSF - 提供读写Microsoft Excel XLS格式档案的功能。
- XSSF - 提供读写Microsoft Excel OOXML XLSX格式档案的功能。
- HWPF - 提供读写Microsoft Word DOC格式档案的功能。
- HSLF - 提供读写Microsoft PowerPoint格式档案的功能。
- HDGF - 提供读Microsoft Visio格式档案的功能。
- HPBF - 提供读Microsoft Publisher格式档案的功能。
- HSMF - 提供读Microsoft Outlook格式档案的功能。
我需要的就是hssf。
poi3.9这里我分享下
链接: http://pan.baidu.com/s/1EHymz 密码: f94c
第二步学习:
清单1.定义新的xls里面工作簿和一个sheet页
Workbook wb = new HSSFWorkbook(); //定义一个新的工作簿
Sheet sheet1= wb.createSheet("满标复审模板"); //定义第一个sheet页
清单2.创建一个文件流,并输出一个xls
wb.write(fos); // Workbook 将流写进工作簿
FileOutputStream fos = new FileOutputStream("D://测试.xls"); //输出一个新的xls
wb.write(fos);
fos.close();
做了前两个,main里面运行就生成了一个xls
清单3.创建行,单元格-->并赋值
Row row = sheet1.createRow(); //为第一个sheet页创建标题
Cell cell = row.createCell(column); //为相应行创建一个单元格
cell.setCellValue("借款标满标确认单");
并注意,这些写在清单1,2之间。
第三步学习:
鄙人自己想了想,然后学习下,觉得
1.字体font,单元style归一类
2.赋值,合并单元格归一类
在一个sheet页里面,
step1.创建内容
/**创建 制单人--制单编号**/
Row row1 = sheet1.createRow();
setRowOfFourSecondTitle(wb, sheet, row1,,"制单人:",
"Li","制单编号:","20131115");
step2.进入setRowOfFourSecondTitle
/**
* 创建 制单人--制单编号
* @param workbook
* @param sheet
* @param row
* @param column
* @param valString1 //列1的值
* @param valString2 //列2的值
* @param changeString1 //列3的值--填入值
* @param changeString2 //列4的值--填入值
*/
private static void setRowOfFourSecondTitle(Workbook workbook,Sheet sheet,Row row,
int column,String valString1,String changeString1 ,String valString2,String changeString2) {
row.setHeightInPoints(); //行高度
sheet.setDefaultColumnWidth(); //设置列的宽度 Cell cel0 = row.createCell(); //为相应行创建列1 单元格
cel0.setCellValue(valString1);
cel0.setCellStyle(getCellStyleOfOne(workbook)); Cell cell2 = row.createCell(); //为相应行创建列3单元格
cell2.setCellValue(valString2);
cell2.setCellStyle(getCellStyleOfOne(workbook)); Cell cell1 = row.createCell(); //为相应行创建列2单元格
cell1.setCellValue(changeString1);
cell1.setCellStyle(getCellStyleOfTwo(workbook)); Cell cell3 = row.createCell();
cell3.setCellValue(changeString2);
cell3.setCellStyle(getCellStyleOfTwo(workbook));
}
step3.由于单元格的里面样式不同
--------------------------------------------
getCellStyleOfTwo 其一 getCellStyleOfOne 其二
------------------------------------------
举其中的一个例子:
其一
/**
* 制单人--制单编号 对应样式
* @param workbook
* @return 制单人--制单编号 对应样式
*/
private static CellStyle getCellStyleOfOne(Workbook workbook) {
CellStyle style1 = workbook.createCellStyle(); // 样式对象
style1.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 垂直
style1.setAlignment(HSSFCellStyle.ALIGN_RIGHT); // 水平
Font font1=workbook.createFont();
font1.setColor(HSSFColor.BLACK.index); //字体颜色
font1.setFontHeightInPoints((short)); //字体大小
font1.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); //字体增粗
style1.setFont(font1);
return style1;
}
第四步学习:
www.baidu.com 文档学习。
总结:
poi操作xls挺简单的,应用那块也有推荐。可以找找视频学习。主要是一些接口的熟悉。
Poi 生成xls的更多相关文章
- 【POI】使用POI 创建生成XLS,打开xls文件提示【此文件中某些文本格式可能已经更改,因为它已经超出最多允许的字体数。】
使用POI 创建生成XLS,打开xls文件提示[此文件中某些文本格式可能已经更改,因为它已经超出最多允许的字体数.] 原因: 是因为在POI处理xls的过程中,太多次调用了: HSSFFont fon ...
- 使用POI生成Excel报表
先把报表模板截图贴上来 下面是POI编写的报表生成类ExcelReport.java package com.jadyer.report; import java.io.FileNotFoundExc ...
- 使用Java类库POI生成简易的Excel报表
使用Java类库POI生成简易的Excel报表 1.需求 1.数据库生成报表需要转义其中字段的信息.比如 1,有效 2.无效等 2.日期格式的自数据需要转义其格式. 3.标题的格式和数据的格式需要分别 ...
- java使用poi生成excel
使用poi生成excel通常包含一下几个步骤 创建一个工作簿 创建一个sheet 创建一个Row对象 创建一个cell对象(1个row+1个cell构成一个单元格) 设置单元格内容 设置单元格样式. ...
- POI生成WORD文档
h2:first-child, body>h1:first-child, body>h1:first-child+h2, body>h3:first-child, body>h ...
- poi jsp xls
poi jsp xls <%@ page language="java" pageEncoding="UTF-8"import="java.ut ...
- Java下使用Apache POI生成具有三级联动下拉列表的Excel文档
使用Apache POI生成具有三级联动下拉列表的Excel文档: 具体效果图与代码如下文. 先上效果图: 开始贴代码,代码中部分测试数据不影响功能. 第一部分(核心业务处理): 此部分包含几个方面: ...
- POI生成EXCEL文件
POI生成EXCEL文件 一.背景 根据指定格式的JSON文件生成对应的excel文件,需求如下 支持多sheet 支持单元格合并 支持插入图片 支持单元格样式可定制 需要 标题(title),表头( ...
- POI生成Web版Word文件
POI生成Web版Word文件 1 通过URL的输入流实现 2 直接把Html文本写入到Word文件 所谓的使用POI生成Web版Word文件是指利用POI将Html代码插入到 ...
随机推荐
- C++题解:Matrix Power Series ——矩阵套矩阵的矩阵加速
Matrix Power Series r时间限制: 1 Sec 内存限制: 512 MB 题目描述 给定矩阵A,求矩阵S=A^1+A^2+--+A^k,输出矩阵,S矩阵中每个元都要模m. 数据范围: ...
- js group by
var arr = ['Car', 'Car', 'Truck', 'Boat', 'Truck'];var hist = {};hist = arr.reduce((prev, item) => ...
- docker之tomcat简单部署
将apache-tomcat-8.0.36.tar.gz及jdk-7u79-linux-x64.gz拷贝到创建的tomcat8目录下 在tomcat8目录下创建Dockerfile文件 在Docker ...
- ADO SQL手写分页
//实现层 ---------------------------------------------------------分割线---------------------------------- ...
- 神经网络参数与TensorFlow变量
在TensorFlow中变量的作用是保存和更新神经网络中的参数,需要给变量指定初始值,如下声明一个2x3矩阵变量 weights =tf.Variable(tf.random_normal([2,3] ...
- 关于Idea里设置Terminal为Git/bin/bash.exe中文乱码的问题的终极解决方案
1.这里如果设置为Git/git-bash.exe确实不会乱码,但是每次点Idea里的Terminal都会弹出一个单独的terminal窗口而非在idea子窗口里出现: 2.因此需要设置为Git/bi ...
- 把dotx模板的样式应用到当前文档中(不应用dotx的其他东西)
Word.Document doc = this.Application.ActiveDocument; //模板样式添加到当前文档 doc.CopyStylesFromTemplate(@" ...
- socket的阻塞与非阻塞,同步与非同步
网络编程中通常提到四种方式,同步/异步,阻塞/非阻塞.以下对它们的概念进行总结 1.同步/异步:主要针对C端 同步:所谓同步,就是在C端发出一个功能调用时,在没有得到结果之前,调用不返回,也就是必须一 ...
- EF学习笔记(七):读取关联数据
总目录:ASP.NET MVC5 及 EF6 学习笔记 - (目录整理) 本篇参考原文链接:Reading Related Data 本章主要讲述加载显示关联数据: 数据加载分为以下三种 Lazy l ...
- Maven和Gradle的区别
转自:http://www.infoq.com/cn/news/2011/04/xxb-maven-6-gradle Maven面临的挑战 软件行业新旧交替的速度之快往往令人咂舌,不用多少时间,你就会 ...