java poi 读取Excel中的手机号或电话号码,手机号变成1.8312345678E10格式数据的解决方法

Posted 秋9

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java poi 读取Excel中的手机号或电话号码,手机号变成1.8312345678E10格式数据的解决方法相关的知识,希望对你有一定的参考价值。

【现象】

共有2行数据
[张三1, 1.8312345678E10, 张三2, 1.8312345679E10]

【解决方法】

v.add(row.getCell(1)+"");

修改为:

v.add(row.getCell(1).getRawValue());

解决后输出结果为:

共有2行数据
[张三1, 18312345678, 张三2, 18312345679]

【完整代码】


import java.io.FileInputStream;
import java.io.InputStream;
import java.util.Vector;

import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class ReadExcel {
	public Vector<String> readExcel(String filePath) throws Exception {
		Vector<String> v = new Vector<String>(); // 存放读取出来的姓名和电话
		InputStream iStream = new FileInputStream(filePath);
		XSSFWorkbook workbook =new XSSFWorkbook(iStream);
		// sheet row column 下标都是从0开始的
		XSSFSheet sheet = workbook.getSheetAt(0);
		int rowNumber = sheet.getPhysicalNumberOfRows();
		System.out.println("共有" + rowNumber + "行数据");
		for (int i = 0; i < rowNumber; i++) {
			XSSFRow row = sheet.getRow(i);
			v.add(row.getCell(0)+"");
			v.add(row.getCell(1).getRawValue());
		}
		// 操作完成时,关闭对象,释放占用的内存空间
		if (iStream != null) {
			iStream.close();
		}

		return v;
	}

	/**
	 * @param args
	 * @throws Exception
	 */
	public static void main(String[] args) throws Exception {
		String filePath = "D:\\\\1\\\\抽奖数据2.xlsx";
		ReadExcel readExcel = new ReadExcel();
		System.out.println(readExcel.readExcel(filePath).toString());
	}
}

以上是关于java poi 读取Excel中的手机号或电话号码,手机号变成1.8312345678E10格式数据的解决方法的主要内容,如果未能解决你的问题,请参考以下文章

Java实现通过POI读取Excel文件提取手机号码并去重

用java的poi类读取一个excel表格的内容后再写入到一个新excel表格中的完整代码

java 关于poi读取excel颜色

poi 读取Excel 电话号码一类大数字时会变成带E的数

poi 读取Excel 电话号码一类大数字时会变成带E的数

java用poi读取Excel表格中的数据