package junit.test;

import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List; import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.write.Label;
import jxl.write.Number;
import jxl.write.WritableImage;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException; import org.apache.commons.lang3.math.NumberUtils;
import org.junit.Test; /**
* Excel导入导出
*
* @author 林计钦
* @version 1.0 Feb 7, 2014 4:14:51 PM
*/
public class ExcelTest { /**
* 导入(导入到内存)
*/
@Test
public void importExcel() {
Workbook book = null;
try {
book = Workbook.getWorkbook(new File("D:/test/测试.xls"));
// 获得第一个工作表对象
Sheet sheet = book.getSheet(0);
int rows=sheet.getRows();
int columns=sheet.getColumns();
// 遍历每行每列的单元格
for(int i=0;i<rows;i++){
for(int j=0;j<columns;j++){
Cell cell = sheet.getCell(j, i);
String result = cell.getContents();
if(j==0){
System.out.print("姓名:"+result+" ");
}
if(j==1){
System.out.print("年龄:"+result+" ");
}
if((j+1)%2==0){
System.out.println();
}
}
}
System.out.println("========");
// 得到第一列第一行的单元格
Cell cell1 = sheet.getCell(0, 0);
String result = cell1.getContents();
System.out.println(result);
System.out.println("========");
} catch (Exception e) {
System.out.println(e);
}finally{
if(book!=null){
book.close();
}
}
} /**
* 导出(导出到磁盘)
*/
@Test
public void exportExcel() {
WritableWorkbook book = null;
try {
// 打开文件
book = Workbook.createWorkbook(new File("D:/test/测试.xls"));
// 生成名为"学生"的工作表,参数0表示这是第一页
WritableSheet sheet = book.createSheet("学生", 0);
// 指定单元格位置是第一列第一行(0, 0)以及单元格内容为张三
Label label = new Label(0, 0, "张三");
// 将定义好的单元格添加到工作表中
sheet.addCell(label);
// 保存数字的单元格必须使用Number的完整包路径
jxl.write.Number number = new jxl.write.Number(1, 0, 30);
sheet.addCell(number);
// 写入数据并关闭文件
book.write();
} catch (Exception e) {
System.out.println(e);
}finally{
if(book!=null){
try {
book.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
} /**
* 对象数据写入到Excel
*/
@Test
public void writeExcel() {
WritableWorkbook book = null;
try {
// 打开文件
book = Workbook.createWorkbook(new File("D:/test/stu.xls"));
// 生成名为"学生"的工作表,参数0表示这是第一页
WritableSheet sheet = book.createSheet("学生", 0); List<Student> stuList=queryStudentList();
if(stuList!=null && !stuList.isEmpty()){
for(int i=0; i<stuList.size(); i++){
sheet.addCell(new Label(0, i, stuList.get(i).getName()));
sheet.addCell(new Number(1, i, stuList.get(i).getAge()));
}
} // 写入数据并关闭文件
book.write();
} catch (Exception e) {
System.out.println(e);
}finally{
if(book!=null){
try {
book.close();
} catch (Exception e) {
e.printStackTrace();
}
}
} } /**
* 读取Excel数据到内存
*/
@Test
public void readExcel() {
Workbook book = null;
try {
// 打开文件
book = Workbook.getWorkbook(new File("D:/test/stu.xls"));
// 获得第一个工作表对象
Sheet sheet = book.getSheet(0);
int rows=sheet.getRows();
int columns=sheet.getColumns();
List<Student> stuList=new ArrayList<Student>();
// 遍历每行每列的单元格
for(int i=0;i<rows;i++){
Student stu = new Student();
for(int j=0;j<columns;j++){
Cell cell = sheet.getCell(j, i);
String result = cell.getContents();
if(j==0){
stu.setName(result);
}
if(j==1){
stu.setAge(NumberUtils.toInt(result));
}
if((j+1)%2==0){
stuList.add(stu);
stu=null;
}
}
} //遍历数据
for(Student stu : stuList){
System.out.println(String.format("姓名:%s, 年龄:%s",
stu.getName(), stu.getAge()));
} } catch (Exception e) {
System.out.println(e);
}finally{
if(book!=null){
try {
book.close();
} catch (Exception e) {
e.printStackTrace();
}
}
} } /**
* 图片写入Excel,只支持png图片
*/
@Test
public void writeImg() {
WritableWorkbook wwb = null;
try {
wwb = Workbook.createWorkbook(new File("D:/test/image.xls"));
WritableSheet ws = wwb.createSheet("图片", 0);
File file = new File("D:\\test\\png.png");
//前两位是起始格,后两位是图片占多少个格,并非是位置
WritableImage image = new WritableImage(1, 4, 6, 18, file);
ws.addImage(image);
wwb.write();
} catch (Exception e) {
e.printStackTrace();
}finally{
if(wwb!=null){
try {
wwb.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
} private List<Student> queryStudentList(){
List<Student> stuList=new ArrayList<Student>();
stuList.add(new Student("zhangsan", 20));
stuList.add(new Student("lisi", 25));
stuList.add(new Student("wangwu", 30));
return stuList;
} public class Student {
private String name;
private int age; public Student() {
} public Student(String name, int age) {
super();
this.name = name;
this.age = age;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
}
}
}

2、jxl常用操作
a、数据格式化
在Excel中不涉及复杂的数据类型,能够比较好的处理字符串、数字和日期已经能够满足一般的应用。

字串格式化
字符串的格式化涉及到的是字体、粗细、字号等元素,这些功能主要由WritableFont和WritableCellFormat类来负责。假设我们在生成一个含有字串的单元格时,使用如下语句,为方便叙述,我们为每一行命令加了编号:

① WritableFont font1= new WritableFont(WritableFont.TIMES, 16, WritableFont.BOLD); 或//设置字体格式为excel支持的格式 WritableFont font3=new WritableFont(WritableFont.createFont("楷体 _GB2312"), 12, WritableFont.NO_BOLD);
② WritableCellFormat format1=new WritableCellFormat(font1);
③ Label label=new Label(0, 0, "data 4 test", format1);

其中,
①指定了字串格式:字体为TIMES,字号16,加粗显示。
WritableFont有非常丰富的构造子函数,供不同情况下使用,jExcelAPI的java-doc中有详细列表,这里不再列出。
②处代码使用了WritableCellFormat类,这个类非常重要,通过它可以指定单元格的各种属性,后面的单元格格式化中会有更多描述。 
③处使用了Label类的构造子,指定了字串被赋予那种格式。在WritableCellFormat类中,还有一个很重要的方法是指定数据的对齐方式,比如针对我们上面的实例,可以指定:

//把水平对齐方式指定为居中
format1.setAlignment(jxl.format.Alignment.CENTRE);
//把垂直对齐方式指定为居中
format1.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);
//设置自动换行
format1.setWrap(true);

b、单元格操作
Excel中很重要的一部分是对单元格的操作,比如行高、列宽、单元格合并等,所幸jExcelAPI提供了这些支持。这些操作相对比较简单,下面只介绍一下相关的API。
1、合并单元格
//作用是从(m,n)到(p,q)的单元格全部合并
WritableSheet.mergeCells(int m, int n, int p, int q); 
比如:

WritableSheet sheet=book.createSheet("第一页", 0);
//合并第一列第一行到第六列第一行的所有单元格
//合并既可以是横向的,也可以是纵向的。合并后的单元格不能再次进行合并,否则会触发异常。
sheet.mergeCells(0, 0, 5, 0);

c、行高和列宽
//作用是指定第i+1行的高度
WritableSheet.setRowView(int i, int height);
比如:将第一行的高度设为200

sheet.setRowView(0, 200);

//作用是指定第i+1列的宽度,
WritableSheet.setColumnView(int i,int width);
比如:将第一列的宽度设为30

sheet.setColumnView(0, 30);

d、操作图片(只支持png图片)

    /**
* 图片写入Excel,只支持png图片
*/
@Test
public void writeImg() {
WritableWorkbook wwb = null;
try {
wwb = Workbook.createWorkbook(new File("D:/test/image.xls"));
WritableSheet ws = wwb.createSheet("图片", 0);
File file = new File("D:\\test\\png.png");
//前两位是起始格,后两位是图片占多少个格,并非是位置
WritableImage image = new WritableImage(1, 4, 6, 18, file);
ws.addImage(image);
wwb.write();
} catch (Exception e) {
e.printStackTrace();
}finally{
if(wwb!=null){
try {
wwb.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}

很简单和插入单元格的方式一样,不过就是参数多了些,WritableImage这个类继承了 Draw,上面只是他构造方法的一种,最后一个参数不用说了,前面四个参数的类型都是double,依次是 x, y, width, height,注意,这里的宽和高可不是图片的宽和高,而是图片所要占的单元格的个数,因为继承的Draw所以他的类型必须是double,具体里面怎么实现的我还没细看:)因为着急赶活,先完成功能,其他的以后有时间慢慢研究。以后会继续写出在使用中的心得给大家。

3、注意事项
a、jxl导出excel乱码
在导出excel时,发现中文的标题乱码,试了N种编码方式,开始总是试图转为utf-8、gb2312、gbk,没想到转为iso-8859-1中文乱码的问题解决了

fileName = new String(fileName.getBytes(),"iso-8859-1");
response.setCharacterEncoding("gb2312");
response.reset();
response.setContentType("application/OCTET-STREAM;charset=gb2312");
response.setHeader("pragma", "no-cache");
response.addHeader("Content-Disposition", "attachment;filename=\""
+ fileName + ".xls\"");// 点击导出excle按钮时候页面显示的默认名称
workbook = Workbook.createWorkbook(response.getOutputStream());

最新文章

  1. to_date &amp; to_char
  2. python——argsort函数
  3. EF分页中的陷阱
  4. input , textarea 边框问题
  5. Web services 安全 - HTTP Basic Authentication
  6. mysql没有delete操作,那是delete from操作,
  7. Elasticsearch内存分配设置详解
  8. Python中if __name__ == &quot;__main__&quot;: 的作用
  9. windows下能读写linux分区的软件 转
  10. bzoj1202
  11. PND_白盾
  12. jquery selector
  13. javascript 的工具方法 --- 类型判断
  14. inno setup 安装个界面提示信息修改
  15. hightcharts在移动端运用 FastClick后苹果上legend点击失效的解决办法
  16. MongoDB三节点高可用模式安装
  17. uvalive 7500 Boxes and Balls
  18. HISI VENC 实际输出帧率控制
  19. JavaWeb学习 (十四)————JSP基础语法
  20. 配置svn用户及权限

热门文章

  1. shell 的基本理解
  2. PAT甲级——A1066 Root of AVL Tree
  3. sqlmap:入门(手工注入)
  4. Linux-c给线程取名字
  5. ajaxStart 和 ajaxSend 不执行
  6. redis消息队列先进先出需要注意什么?
  7. 利用animate.css和es6制作文字向上滚动的效果
  8. Jenkins自动部署springboot项目
  9. vim 插入行号
  10. vue.js_06_vue.js的自定义指令和自定义键盘修饰符