java生成简单Excel工作薄
前言:
代码都是建立在实际需求上的,上周做完一个调外部电影券接口的项目,这周产品又要excel表格,大致内容为:券所属影院、图片URL、等信息制作为excel表格,把每次同步过来的数据给他分析。
jxl:全称JavaExcelAPI,是一个用来读写修改EXCEL的JAVA开源类库,使用起来相对简单。
jar包下载地址: http://www.andykhan.com/jexcelapi/download.html
下面是刚写完的一个简单不能再简单的Demo了,没有任何附加样式,下班了,样式这周末再慢慢调吧
Demo代码:
package com.java.jexcel; import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.Calendar;
import java.util.Date;
import jxl.Workbook;
import jxl.write.DateFormats;
import jxl.write.DateTime;
import jxl.write.Label;
import jxl.write.Number;
import jxl.write.WritableCellFormat;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook; /**
* @author liuyt
* @date 2014-11-20 下午5:04:48
* bolgs http://www.cnblogs.com/liuyitian/
*/
public class SimpleExcelDemo {
/**
* java生成Excel工作薄文件至本地目录
* @param fileName 文件名
* @return
* @throws Exception
*/
public static String exportExcel(String fileName) throws Exception { // 首先创建一个用于保存excel表格的文件
File file = new File("D:\\data\\" + fileName +".xls"); // 创建一个文件输出流,用于写出表格到本地文件夹
OutputStream out = new FileOutputStream(file); // 创建一个可读写入的工作薄(相当于创建了一个excel表格。抽象类,不能用new来创建)
WritableWorkbook workbook = Workbook.createWorkbook(out); // 创建一个新页(一个excel文件可以包含多页哦。参数一:本页名称;参数二:页数,第一页为0)
WritableSheet sheet = workbook.createSheet("简单excel制作", 0); /**
* 创建一个标签,相当于单元格,用于填充到本页中
* (参数一:列坐标,0开始; 参数二:行坐标,0开始; 参数三:单元格内容;参数四:可选,一个格式工具-之后介绍)
* 所以行坐标为0的时候,可以理解为表头哦。
*/
Label cell = new Label(0, 0, "姓名"); // 1行1列 // 添加单元格至本页中(目前表格最左上角应该有一个“步骤一”的单元格)
sheet.addCell(cell); // 一鼓作气先把表头制作出来
cell = new Label(1, 0, "年龄"); // 1行2列
sheet.addCell(cell);
cell = new Label(2, 0, "生日"); // 1行3列
sheet.addCell(cell);
cell = new Label(3, 0, "博客地址"); // 1行4列
sheet.addCell(cell); /**
* 接下来填充内容,记住表头的设置哦,别对混淆了。
* cell并非只有Lable一种类型,还有其他三种分别为:Number,Boolean,DateTime。 分别对应了字符串,数字,布尔和时间格式
* 设计这么多类型多余吗?NO,你在写入的时候无所谓,但当你读取一个excel到程序中,没有这些类型帮助你判断,..各种转换异常..
*/
cell = new Label(0, 1, "刘一天"); // 2行1列
sheet.addCell(cell); Number age = new Number(1, 1, 23); // 2行2列 (年龄:Number类型)
sheet.addCell(age); /**
* 对于日期格式,你可以直接写入一个java.util.Date类型的时间,但格式可能不是你想要的
* jxl自己有单元格格式化类:WritableCellFormat,它可以设置单元格背景颜色、文字换行、边框和样式等
* 也可以传入一个DisplayFormat(显示形式)来构造一个格式工具类
*/
WritableCellFormat wf = new WritableCellFormat(DateFormats.FORMAT1);
Calendar c = Calendar.getInstance();
c.set(1991, 5, 16);
Date d = c.getTime();
DateTime birthday = new DateTime(2, 1, d, wf); // 2行3列 (生日:DateTime类型)
sheet.addCell(birthday); cell = new Label(3, 1, "http://www.cnblogs.com/liuyitian/"); // 2行4列
sheet.addCell(cell); workbook.write(); // 写入Excel工作表
workbook.close(); // 关闭Excel工作表,同时也会关闭IO流,勿忘。
return "写入完成,就是这么简单,自己亲自试一下吧?";
} /** 简单test **/
public static void main(String[] args) {
try {
System.out.println(SimpleExcelDemo.exportExcel("简单excel制作"));
} catch (Exception e) {
System.out.println("写入失败"+e.getMessage());
}
}
}
效果图:
下班了,赶紧撤。
ps:欢迎转载,转载请注明出处:http://www.cnblogs.com/liuyitian/p/4111451.html
写作不易,难免有疏漏和错误,还请慷慨指正,不错请推荐
每天多学一点点 代码少敲一点点
java生成简单Excel工作薄的更多相关文章
- excel如何将一个工作薄中的工作表生成独立的工作薄
excel如何将一个工作薄中的工作表生成独立的工作薄 '用vba代码 Sub 另存所有工作表为工作簿() Dim sht As Worksheet Application.ScreenUpdatin ...
- java 生成简单word(利用Itext工具),生成简单Excel,以及下载笔记
1.java 生成简单word(包含图片表格) pom中加入itext 相关依赖 <dependency> <groupId>com.lowagie</groupId&g ...
- 如何把一个excel工作薄中N个工作表复制到另一个工作薄中
一般遇到标题这样的情况,许多人可能会一个一个的复制粘贴,其实完全不必那么麻烦. 你可以按以下步骤来操作: 第一步:打开所有要操作的excel工作薄\n 第二步:按住Shift键,选择所有要复制的工作表 ...
- VBA基础之Excel 工作薄(Book)的操作(三)
三. Excel 工作薄(Book)的操作1. Excel 创建工作薄(Book) Sub addWorkbook() Workbooks.Add End Sub 2. Excel 打开工作薄(Boo ...
- 获取Excel工作薄中Sheet页(工作表)名集合
#region 获取Excel工作薄中Sheet页(工作表)名集合 02./// <summary> 03./// 获取Excel工作薄中Sheet页(工作表)名集合 04./// < ...
- python解决excel工作薄合并处理(openpyxl处理excel2010以上版本)
前段时间使用xlrd.xlwt对文件进行处理(https://www.cnblogs.com/pinpin/p/10287491.html),但是只能处理excel2010以下版本,所以又写了个处理e ...
- java生成简单验证码图片
概要 最近项目需要用java实现输出随机验证码图片到前台,正好有机会接触下java的绘图类,完成需求后也有时间做个总结,写篇随笔记录下也希望能帮助到有同样需求的人! 需求流程图 1.生成随机数 在ja ...
- 合并Excel工作薄中成绩表的VBA代码,非常适合教育一线的朋友_python
这时候还需要把各个工作表合并到一起来形成一个汇总表.这时候比较麻烦也比较容易出错,因为各个表的学号不一定都是一致的.对齐的.因为可能会有人缺考,有人会考号涂错等等.特奉献以下代码,用于合并学生成绩表或 ...
- python解决excel工作薄合并处理
年度了,要对每个月的数据进行总的汇总,去计算每消耗品的使用情况,表格都在一个工作表的不同sheet中,并且格式相同,所以就用python写了这个小脚本,现在把脚本粘贴出来,以后有需要就可以在此基础上改 ...
随机推荐
- poj 3159(差分约束经典题)
题目链接:http://poj.org/problem?id=3159思路:题目意思很简单,都与给定的条件dist[b]-dist[a]<=c,求dist[n]-dist[1]的最大值,显然这是 ...
- UML类图、接口、包、关系
一.类图:允许我们去标记静态内容及类之间的关系. 类的基本表示法: 名称 属性(类型,可见性) 方法(参数,返回值) tip: 显示可见性:Options->Show Visibility 显 ...
- JAVA Map集合类简介
了解最常用的集合类型之一 Map 的基础知识以及如何针对您应用程序特有的数据优化 Map. 本文相关下载: · Jack 的 HashMap 测试· Oracle JDeveloper 10g jav ...
- ArcGIS Runtime SDK for Android 10.2.5新开发平台安装配置指南
ArcGIS Runtime SDK for Android 10.2.5版本在年前发布,其中一个重大的变化是:新版本使用了新的开发环境,在10.2.5版本中Esri使用了官方提供的新的Android ...
- #-webkit-autofill##google#启用表单自动填充时,如何覆盖黄色背景
google和opera浏览器的表单自动填充后,输入框均会变成黄色背景,黑色字体.如下图. 这样的话会与网页的整体设计风格不一致,怎样自定义样式,来覆盖黄色背景. 首先来看看是什么导致的,右键查看元素 ...
- 如何添加或删除ubuntu用户和组【转】
转自:http://blog.csdn.net/sin90lzc/article/details/7525670 在创建用户时,需要为新建用户指定一用户组,如果不指定其用户所属的工作组,自动会生成一个 ...
- Android 判断用户2G/3G/4G移动数据网络
Android 判断用户2G/3G/4G移动数据网络 在做 Android App 的时候,为了给用户省流量,为了不激起用户的愤怒,为了更好的用户体验,是需要根据用户当前网络情况来做一些调整的,也可以 ...
- 二维码(2)二维码登录原理及Android客户端示例
1,原理 服务器: 数据库: 建立一个2维码登录的数据表,产生一个登录页时,插入一条记录X,X含将要登录的用户名字段(初始为空),2维码中的数据字段(唯一) 登录页面: 在产生的2维码中包含关键数据Y ...
- Objective-C 类的继承、方法的重写和重载
一.类的继承 Objective-c中类的继承与C++类似,不同的是Objective-c不支持多重继承,一个类只能有一个父类,单继承使Objective-c的继承关系很简单,易于管理程序.Objec ...
- Codeforces Round #320 (Div. 2) D. "Or" Game 数学
D. "Or" Game time limit per test 2 seconds memory limit per test 256 megabytes input stand ...