iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >利用Java怎么将excel表格转换成json数据
  • 243
分享到

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

javaexceljson 2023-05-31 01:05:25 243人浏览 安东尼
摘要

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

利用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;  }}

--结束END--

本文标题: 利用Java怎么将excel表格转换成json数据

本文链接: https://www.lsjlt.com/news/222840.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL怎么更新字段长度
    要更新MySQL表中的字段长度,可以使用ALTER TABLE语句。以下是更新字段长度的示例: ALTER TABLE table_...
    99+
    2024-05-14
    mysql
  • sql如何修改表字段长度
    要修改表字段的长度,可以使用ALTER TABLE语句,然后使用MODIFY COLUMN来修改字段的长度。以下是一个示例: ALT...
    99+
    2024-05-14
    sql
  • mysql数据量太大如何解决
    有几种方法可以解决MySQL数据量过大的问题: 数据库分区:将数据库表按照某种规则进行分区,分成多个小表,可以提高查询速度和管理...
    99+
    2024-05-14
    mysql
  • MySQL单表数据量过大如何解决
    在MySQL中,当单表的数据量过大时,可以采取以下几种方法来解决问题: 使用索引:在表的字段上创建适当的索引,可以提高查询效率,...
    99+
    2024-05-14
    mysql
  • mysql导出数据量过大如何解决
    当导出的数据量过大时,可以尝试以下方法来解决问题: 使用数据库工具:使用数据库管理工具如Navicat或MySQL Workbe...
    99+
    2024-05-14
    mysql
  • mysql中log_bin的作用是什么
    在MySQL中,log_bin是二进制日志文件的名称,用于记录所有对数据库进行更改的操作,如插入、更新、删除等。这些二进制日志文件可...
    99+
    2024-05-14
    mysql
  • mysql中log_bin的特点有哪些
    log_bin是MySQL的二进制日志文件,用于记录所有对数据库的修改操作,包括插入、更新、删除等。 log_bin文件是M...
    99+
    2024-05-14
    mysql
  • mysql rpm包安装的方法是什么
    要在Linux系统上安装MySQL RPM包,可以按照以下步骤操作: 下载MySQL的RPM包:你可以从MySQL官方网站下载适...
    99+
    2024-05-14
    mysql
  • mysql rpm包安装后怎么使用
    安装MySQL RPM包后,您可以通过以下步骤来使用MySQL: 启动MySQL服务:使用以下命令来启动MySQL服务: sud...
    99+
    2024-05-14
    mysql
  • lxml中怎么处理XML命名空间默认值
    在lxml中处理XML命名空间的默认值可以通过使用xpath()方法和register_namespace()方法来实现。...
    99+
    2024-05-14
    lxml
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作