学习笔记:Apache POI

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简述
BigDecimal用法

注意: 要直接用 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表示第一列

具体原因

猜你喜欢

转载自blog.csdn.net/weixin_45433603/article/details/105600244