文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

利用Java怎么将excel表格转换成json数据

2023-05-31 01:24

关注

利用Java怎么将excel表格转换成json数据?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

实现方法如下:

package org.duang.test;import java.io.File;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;import net.sf.json.JSONArray;import org.apache.poi.ss.usermodel.Cell;import org.apache.poi.ss.usermodel.DateUtil;import org.apache.poi.ss.usermodel.FormulaEvaluator;import org.apache.poi.ss.usermodel.Row;import org.apache.poi.ss.usermodel.Sheet;import org.apache.poi.ss.usermodel.Workbook;import org.apache.poi.ss.usermodel.WorkbookFactory;public class Excel2JSONHelper {  //常亮,用作第一种模板类型,如下图  private static final int HEADER_VALUE_TYPE_Z=1;  //第二种模板类型,如下图  private static final int HEADER_VALUE_TYPE_S=2;  public static void main(String[] args) {     File dir = new File("e:\\2003.xls");     Excel2JSONHelper excelHelper = getExcel2JSONHelper();     //dir文件,0代表是第一行为保存到数据库或者实体类的表头,一般为英文的字符串,2代表是第二种模板,      JSONArray jsonArray = excelHelper.readExcle(dir, 0, 2);     System.out.println(jsonArray.toString());;  }    private static Excel2JSONHelper getExcel2JSONHelper(){    return new Excel2JSONHelper();  }    private boolean fileNameFileter(File file){    boolean endsWith = false;    if(file != null){      String fileName = file.getName();      endsWith = fileName.endsWith(".xls") || fileName.endsWith(".xlsx");    }    return endsWith;  }    private Row getHeaderRow(Sheet sheet, int index){    Row headerRow = null;    if(sheet!=null){      headerRow = sheet.getRow(index);    }    return headerRow;  }    private Object getCellValue(Row row,int cellIndex,FormulaEvaluator formula){    Cell cell = row.getCell(cellIndex);    if(cell != null){      switch (cell.getCellType()) {      //String类型      case Cell.CELL_TYPE_STRING:        return cell.getRichStringCellValue().getString();       //number类型      case Cell.CELL_TYPE_NUMERIC:        if (DateUtil.isCellDateFormatted(cell)) {          return cell.getDateCellValue().getTime();        } else {          return cell.getNumericCellValue();        }      //boolean类型      case Cell.CELL_TYPE_BOOLEAN:        return cell.getBooleanCellValue();      //公式        case Cell.CELL_TYPE_FORMULA:        return formula.evaluate(cell).getNumberValue();      default:        return null;      }    }    return null;  }    private String getHeaderCellValue(Row headerRow,int cellIndex,int type){    Cell cell = headerRow.getCell(cellIndex);    String headerValue = null;    if(cell != null){      //第一种模板类型      if(type == HEADER_VALUE_TYPE_Z){        headerValue = cell.getRichStringCellValue().getString();        int l_bracket = headerValue.indexOf("(");        int r_bracket = headerValue.indexOf(")");        if(l_bracket == -1){          l_bracket = headerValue.indexOf("(");        }        if(r_bracket == -1){          r_bracket = headerValue.indexOf(")");        }        headerValue = headerValue.substring(l_bracket+1, r_bracket);      }else if(type == HEADER_VALUE_TYPE_S){      //第二种模板类型        headerValue = cell.getRichStringCellValue().getString();      }    }    return headerValue;  }    public JSONArray readExcle(File file,int headerIndex,int headType){    List<Map<String, Object>> lists = new ArrayList<Map<String, Object>>();    if(!fileNameFileter(file)){      return null;    }else{      try {        //加载excel表格        WorkbookFactory wbFactory = new WorkbookFactory();        Workbook wb = wbFactory.create(file);        //读取第一个sheet页        Sheet sheet = wb.getSheetAt(0);         //读取表头行        Row headerRow = getHeaderRow(sheet, headerIndex);        //读取数据        FormulaEvaluator formula = wb.getCreationHelper().createFormulaEvaluator();        for(int r = headerIndex+1; r<= sheet.getLastRowNum();r++){          Row dataRow = sheet.getRow(r);          Map<String, Object> map = new HashMap<String, Object>();          for(int h = 0; h<dataRow.getLastCellNum();h++){            //表头为key            String key = getHeaderCellValue(headerRow,h,headType);            //数据为value            Object value = getCellValue(dataRow, h, formula);            if(!key.equals("") && !key.equals("null") && key != null ){              map.put(key, value);            }          }          lists.add(map);        }      } catch (Exception e) {        e.printStackTrace();      }     }    JSONArray jsonArray = JSONArray.fromObject(lists);    return jsonArray;  }}

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯