先贴代码吧,执行一下。看看效果,然后看看凝视,再看看代码后面的基础介绍

创建一个新excel并写入数据:

public static void myExcel2() throws IOException, WriteException {
WritableWorkbook wwb = Workbook.createWorkbook(new File("F:"
+ File.separator + "myExcel1.xls"));
// 创建excel表格中的一个sheet项
WritableSheet sheet = wwb.createSheet("第一页", 0);
// excel中的cell元素能够有非常多种数据类型,比方Number,Label等等
// 在API中,为我们提供了非常多的cell类型
// 单元格格式编辑
// 合并单元格式
sheet.mergeCells(0, 0, 5, 0);
/* ===========单元格中文字的格式案例============ */
// cell元素中字体(字体格式,颜色,大小的控制)
WritableCellFormat forFont = new WritableCellFormat();// 单元格样式对象
WritableFont font = new WritableFont(WritableFont.ARIAL);// 选择字体
font.setColour(Colour.RED);// 颜色
font.setPointSize(20); // 大小
font.setUnderlineStyle(UnderlineStyle.DOUBLE);// 下划线
forFont.setFont(font); // 将字体样式对象加入进入单元格样式对象
forFont.setAlignment(Alignment.CENTRE);// 文字居中
// 创建一个单元格,并指定位置。内容和格式
Label topLabel = new Label(0, 0, "合并单元格。设置字体格式", forFont);
// 将创建的单元格对象加入进入sheet页中
sheet.addCell(topLabel);
sheet.setRowView(0, 1000); /* ===========单元格中数字的格式化案例============ */
// 创建数字格式化对象
NumberFormat numFormat = new NumberFormat("#.000");
// 创建单元格格式化对象并加入数字格式化对象
WritableCellFormat forNumber = new WritableCellFormat(numFormat);
Number myNumber = new Number(0, 1, 3.14159, forNumber);
sheet.addCell(myNumber); /* ===========单元格中日期的格式化案例============ */
DateFormat dateFormat = new DateFormat("yyyy-MM-dd");
WritableCellFormat forDate = new WritableCellFormat(dateFormat);
forDate.setBackground(Colour.BLUE); // 设置单元格颜色
DateTime myDate = new DateTime(1, 1, new Date(), forDate);
sheet.addCell(myDate);
// 写入文件
wwb.write();
// 关闭
wwb.close();
}

利用java创建一个全新的Excel文档,通过学习API,我总结的一个流程例如以下:

1.须要创建一个能够进行写入操作的Workbook对象,即:WritableWorkbook,同一时候传入參数能够是一个文件输出流,也能够是一个通过File创建的一个对象(參数是文件名称),如:

WritableWorkbook wwb = new
WritableWorkbook(new File("myExcel.xls"));

2.创建可编辑的WritableSheet对象。在Excel文档中能够有多个sheet页,第一个sheet指定为0,如:

WritableSheet sheet = wwb.createSheet("sheet1",0);

3.首先,创建一个相应类型的格式化对象,比方

NunberFormat dateformat = new NunberFormat("yyyy-MM-dd")对象

4.然后创建一个Excel单元格格式化对象。而且将上述相应类型格式化对象以參数的方式传递,比方

WritableCellFormat datecellformat = new WritableCellFormat(dateformat);

5.创建单元格对象,设置位置,值,以及指定单元格格式化对象

DateTime mydate = new DateTime(0,0,new Date(),datecellformat);

单元格格式化对象的參数说明:这里以四个參数的构造函数为例进行说明:

第一个參数是列号,第二个參数是行号,第三个參数是值。第四个參数是可选择的,表示格式,
原因是第四个參数能够通过setCellFormat()方法指定格式

6.将创建的单元格对象,加入到sheet中

7.进行写入操作:wwb.write();

8.关闭操作:wwb.close()

特别说明,假设有输出流。不用的时候请关闭输出流

意外发现,java中也有Number。所以,我们在这里请务必导入jsl.write.Number,否则下列语句将报错:

Number myNumber = new Number(0, 1, 3.14159, forNumber);

日期格式參数说明:

yyyy 四位年份 MM 两位月份 dd 两位天 hh 两位小时数字 mm两位分钟数字(大写表示月份)ss 两位秒数

常见格式:

yyyy-MM-dd hh:mm:ss
(中间特殊符号可任意设定,一般能够有“-”,“/”," ")

数字格式化时參数说明:

java中对数字的格式化主要用#和0作为站位符,详解例如以下:

保留整数部分和3位小数:#.000

取2位整数和2位小数:00.00

当整数部分不足时,会补0,缺多少补多少个0

百分制%:即在上述格式后加入一个%符号

#.##%(小数点后的“#”作用等同于“0”)

科学计数法:用E字母,如:00.000E0

数字切割:每三位中间加入一个“,”号

import java.text.DecimalFormat;

public class TestNumberFormat {

    public static void main(String[] args) {
double pi = 3.1415927; // 圆周率
// 取一位整数
System.out.println(new DecimalFormat("0").format(pi)); // 3
// 取一位整数和两位小数
System.out.println(new DecimalFormat("0.00").format(pi)); // 3.14
// 取两位整数和三位小数,整数不足部分以 0 填补。
System.out.println(new DecimalFormat("00.000").format(pi)); // 03.142
// 取全部整数部分
System.out.println(new DecimalFormat("#").format(pi)); // 3
// 以百分例如式计数,并取两位小数
System.out.println(new DecimalFormat("#.##%").format(pi)); // 314.16% long c = 299792458; // 光速
// 显示为科学计数法。并取五位小数
System.out.println(new DecimalFormat("#.#####E0").format(c)); // 2.99792E8
// 显示为两位整数的科学计数法,并取四位小数
System.out.println(new DecimalFormat("00.####E0").format(c)); // 29.9792E7
// 每三位以逗号进行分隔。 System.out.println(new DecimalFormat(",###").format(c)); // 299,792,458
// 将格式嵌入文本
System.out.println(new DecimalFormat("光速大小为每秒 ,### 米。 ").format(c));
}
}

未完待续。还有对已存在的文件进行读取和改动操作,以及常见的format參数说明

JAVA Excel API学习案例的更多相关文章

  1. jxl(Java Excel API) 使用方法 【2】

    JAVA EXCEL API简介 Java Excel是一开放源码项目,通过它Java开发人员可以读取Excel文件的内容.创建新的Excel文件.更新已经存在的Excel文件.使用该 API非Win ...

  2. jxl(Java Excel API) 使用方法 【1】

    //   构建Workbook对象, 只读Workbook对象  //   直接从本地文档创建Workbook  //   从输入流创建Workbook Workbook workbook = nul ...

  3. java线程API学习 线程池ThreadPoolExecutor(转)

    线程池ThreadPoolExecutor继承自ExecutorService.是jdk1.5加入的新特性,将提交执行的任务在内部线程池中的可用线程中执行. 构造函数 ThreadPoolExecut ...

  4. java核心API学习

    1:java.lang  (Object.String.StringBuffer.Thread.System.ClassLoader.Class.Runtime.包装类等)

  5. Java Excel API的使用

    https://wenku.baidu.com/view/724cc9e2dd88d0d232d46a1b.html

  6. 摘:JAVA JXL API的详细使用

    转自:http://www.cr173.com/html/10377_1.html 1 开发调研1.1 需求描述MS的电子表格(Excel)是Office的重要成员,是保存统计数据的一种常用格式.作为 ...

  7. Java数据持久层框架 MyBatis之API学习八(Java API详解)

    对于MyBatis的学习而言,最好去MyBatis的官方文档:http://www.mybatis.org/mybatis-3/zh/index.html 对于语言的学习而言,马上上手去编程,多多练习 ...

  8. Java语言学习案例雷霆战机

    1.Java雷霆战机学习笔记(一)-资源加载 https://www.toutiao.com/i6631331313259381255/ 2.Java雷霆战机学习笔记(二)-音乐播放 https:// ...

  9. 第65节:Java后端的学习之Spring基础

    Java后端的学习之Spring基础 如果要学习spring,那么什么是框架,spring又是什么呢?学习spring中的ioc和bean,以及aop,IOC,Bean,AOP,(配置,注解,api) ...

随机推荐

  1. 使用python进行re拆分网页内容

    这里简短的总结一下而不是完全的罗列python的re模块,python的re具有强大的功能,如下是一个从我们学校抓取数据然后拆分的程序,代码如下: import httplib import urll ...

  2. expdp通过dblink远端导出

    环境说明: db62是源端 rac数据库 dw03为需要导入的目标端数据库单机,实例名,服务名,字符串名都为dw03 数据库版本:11.2.0.4  操作系统:rehat 6.7 1.创建dblink ...

  3. C - Twins(贪心)

    Problem description Imagine that you have a twin brother or sister. Having another person that looks ...

  4. React 16 服务端渲染的新特性

    React 16 服务端渲染的新特性 React 16 中关于服务端渲染的新特性 快速介绍React 16 服务端渲染的新特性,包括数组.性能.流等 React 16 终于来了!

  5. jQuery中样式和属性模块简单分析

    1.行内样式操作 目标:扩展框架实现行内样式的增删改查 1.1 创建 css 方法 目标:实现单个样式或者多个样式的操作 1.1.1 css方法 -获取样式 注意:使用 style 属性只能获取行内样 ...

  6. 关于出现Failed to instantiate SLF4J LoggerFactory问题原因,解决办法

    在创建spring boot 文档进行配置的时候,因为使用spring boot 父级依赖的版本 <artifactId>spring-boot-starter-parent</ar ...

  7. Openwrt PPTP Server笔记

    1.安装PPTP opkg updateopkg install kmod-mppeopkg install pptpd 2./etc/pptpd.conf option /etc/ppp/optio ...

  8. FAQ: SBS 2011. The Windows SBS Manager service terminated unexpectedly

    Symptoms The Windows SBS Manager service is stopped with EventID 7034 every half an hour on SBS 2011 ...

  9. TortoiseSvn问题研究(一)

    问题描述 今天在工作中遇到一个SVN方面的问题,牵扯出使用SVN这一段时间的一系列问题. 具体来说,是这样的: 上周五有上线分支,自己的分支需要merge: 很多项目小组都在开发这个项目,再往前好像也 ...

  10. (转) RabbitMQ学习之远程过程调用(RPC)(java)

    http://blog.csdn.net/zhu_tianwei/article/details/40887885 在一般使用RabbitMQ做RPC很容易.客户端发送一个请求消息然后服务器回复一个响 ...