POI
1. cell.getStringCellValue()
有可能会 得到一个 null,为了防止空指针,写一个工具类,如果是null,返回""。
2. workbook.write(FileOutputStream out)
out 下的 文件目录必须存在,所以写一个工具类,如果
if (!file.exist()) {
file.createNewFile();
}
3. BigDecimal、DecimalFormat
// new BigDecimal 参数必须传一个 字符串,防止精度丢失
// setScale() 保留小数点后2位,四舍五入
double value = new BigDecimal("132").setScale(2, "BigDecimal.ROUND_HALF_UP").doubleValue();
注意: 要直接用 BigDecimal里的 加减乘除来运算,不要使用 原生的运算 然后去 四舍五入。
比如: 3.05 保留一位应该是 3.1,而 3.049999 保留一位是 3.0。
3.1 DecimalFormat
我们经常要将数字进行格式化,比如取2位小数,这是最常见的。Java 提供DecimalFormat类,帮你用最快的速度将数字格式化为你需要的样子。下面是一个例子:
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));
}
}
DecimalFormat 类主要靠 # 和 0 两种占位符号来指定数字长度。0 表示如果位数不足则以 0 填充,# 表示只要有可能就把数字拉上这个位置(不会补0)。上面的例子包含了差不多所有的基本用法,如果你想了解更多,请参考 DecimalFormat 类的文档。
DecimalFormat 缺点
4. 样式
4.1 设置列宽
sheet.setColumnWidth(0, 256*width+184); // 0表示第一列