POI原生导入读取EXCEL方法

发布时间:2020-08-07 01:51:55 作者:nineteens
来源:网络 阅读:466

  POI原生导入读取EXCEL方法

  import org.apache.poi.hssf.usermodel.*;

  import org.apache.poi.poifs.filesystem.POIFSFileSystem;

  import java.io.FileInputStream;

  import java.io.FileNotFoundException;

  import java.io.IOException;

  import java.io.InputStream;

  import java.text.SimpleDateFormat;

  import java.util.Date;

  import java.util.HashMap;

  import java.util.Map;

  public class ReadExcelUtil {

  private POIFSFileSystem fs;

  private HSSFWorkbook wb;

  private HSSFSheet sheet;

  private HSSFRow row;

  /**

  * 读取Excel表格表头的内容

  * @param is

  * @return String 表头内容的数组

  */

  public String[] readExcelTitle(InputStream is) {

  try {

  fs = new POIFSFileSystem(is);

  wb = new HSSFWorkbook(fs);

  } catch (IOException e) {

  e.printStackTrace();

  }

  sheet = wb.getSheetAt(0);

  //得到首行的row

  row = sheet.getRow(0);

  // 标题总列数

  int colNum = row.getPhysicalNumberOfCells();

  String[] title = new String[colNum];

  for (int i = 0; i < colNum; i++) {

  title[i] = getCellFormatValue(row.getCell((short) i));

  }

  return title;

  }

  /**

  * 读取Excel数据内容

  * @param is

  * @return Map 包含单元格数据内容的Map对象

  */

  public Map readExcelContent(InputStream is) {

  Map content = new HashMap();

  String str = "";

  String strCell = "";

  try {

  fs = new POIFSFileSystem(is);

  wb = new HSSFWorkbook(fs);

  } catch (IOException e) {

  e.printStackTrace();

  }

  sheet = wb.getSheetAt(0);

  // 得到总行数

  int rowNum = sheet.getLastRowNum();

  //由于第0行和第一行已经合并了 在这里索引从2开始

  row = sheet.getRow(2);

  int colNum = row.getPhysicalNumberOfCells();

  // 正文内容应该从第二行开始,第一行为表头的标题

  for (int i = 2; i <= rowNum; i++) {

  row = sheet.getRow(i);

  int j = 0;

  while (j < colNum) {

  strCell = getStringCellValue(row.getCell(j));

  str += strCell + "-";

  // str +=row.getCell((short) j) + "^";

  j++;

  }

  content.put(i, str);

  str = "";

  }

  return content;

  }

  /**

  * 获取单元格数据内容为字符串类型的数据

  *

  * @param cell Excel单元格

  * @return String 单元格数据内容

  */

  private String getStringCellValue(HSSFCell cell) {

  String strCell = "";

  switch (cell.getCellType()) {

  case HSSFCell.CELL_TYPE_STRING:

  strCell = cell.getStringCellValue();

  break;

  case HSSFCell.CELL_TYPE_NUMERIC:

  strCell = String.valueOf((int)cell.getNumericCellValue());

  break;

  case HSSFCell.CELL_TYPE_BOOLEAN:

  strCell = String.valueOf(cell.getBooleanCellValue());

  break;

  case HSSFCell.CELL_TYPE_BLANK:

  strCell = "";

  break;

  default:

  strCell = "";

  break;

  }

  if (strCell.equals("") || strCell == null) {

  return "";

  }

  if (cell == null) {

  return "";

  }

  return strCell;

  }

  /**

  * 获取单元格数据内容为日期类型的数据

  *

  * @param cell

  * Excel单元格

  * @return String 单元格数据内容

  */

  private String getDateCellValue(HSSFCell cell) {

  String result = "";

  try {

  int cellType = cell.getCellType();

  if (cellType == HSSFCell.CELL_TYPE_NUMERIC) {

  Date date = cell.getDateCellValue();

  result = (date.getYear() + 1900) + "-" + (date.getMonth() + 1)

  + "-" + date.getDate();

  } else if (cellType == HSSFCell.CELL_TYPE_STRING) {

  String date = getStringCellValue(cell);

  result = date.replaceAll("[年月]", "-").replace("日", "").trim();

  } else if (cellType == HSSFCell.CELL_TYPE_BLANK) {

  result = "";

  }

  } catch (Exception e) {

  System.out.println("日期格式不正确!");

  e.printStackTrace();

  }

  return result;

  }

  /**

  * 根据HSSFCell类型设置数据

  * @param cell

  * @return

  */

  private String getCellFormatValue(HSSFCell cell) {

  String cellvalue = "";

  if (cell != null) {

  // 判断当前Cell的Type

  switch (cell.getCellType()) {

  // 如果当前Cell的Type为NUMERIC

  case HSSFCell.CELL_TYPE_NUMERIC:

  case HSSFCell.CELL_TYPE_FORMULA: {

  // 判断当前的cell是否为Date

  if (HSSFDateUtil.isCellDateFormatted(cell)) {

  Date date = cell.getDateCellValue();

  SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");

  cellvalue = sdf.format(date);

  }无锡妇科医院××× http://wapyyk.39.net/wx/zonghe/fc96e.html

  // 如果是纯数字

  else {

  // 取得当前Cell的数值

  cellvalue = String.valueOf(cell.getNumericCellValue());

  }

  break;

  }

  // 如果当前Cell的Type为STRIN

  case HSSFCell.CELL_TYPE_STRING:

  // 取得当前的Cell字符串

  cellvalue = cell.getRichStringCellValue().getString();

  break;

  // 默认的Cell值

  default:

  cellvalue = " ";

  }

  } else {

  cellvalue = "";

  }

  return cellvalue;

  }

  public static void main(String[] args) {

  try {

  // 对读取Excel表格标题测试

  InputStream is = new FileInputStream("d:\\test2.xls");

  ReadExcelUtil excelReader = new ReadExcelUtil();

  String[] title = excelReader.readExcelTitle(is);

  System.out.println("获得Excel表格的标题:");

  for (String s : title) {

  System.out.print(s + " ");

  }

  System.out.println();

  // 对读取Excel表格内容测试

  InputStream is2 = new FileInputStream("d:\\test2.xls");

  Map map = excelReader.readExcelContent(is2);

  System.out.println("获得Excel表格的内容:");

  //这里由于xls合并了单元格需要对索引特殊处理

  for (int i = 2; i <= map.size()+1; i++) {

  System.out.println(map.get(i));

  }

  } catch (FileNotFoundException e) {

  System.out.println("未找到指定路径的文件!");

  e.printStackTrace();

  }

  }

  }


推荐阅读:
  1. 基于 POI 封装 ExcelUtil 精简的 Excel 导入导出
  2. Java用POI导入Excel文件的方法

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

poi excel ce

上一篇:SpringCloud分布式微服务云架构 第七篇: 高可用的分布式配置中心(Config)

下一篇:mysql 用户及权限管理 小结

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》