基于Java实现Json文件转换为Excel文件

 更新时间:2022年12月01日 16:23:05   作者:菜鸟小于  
这篇文章主要为大家详细介绍了如何利用Java实现Json文件转换为Excel文件,文中的示例代码讲解详细,具有一定的借鉴价值,需要的可以参考一下

一. 思路

今天接到个小任务,让把json文件转换成excel文件,按照列展开.

思路:既然json已经都已经是现成的,那直接将json文件做读操作,在通过不同的key,找到对应的信息,在存到单元格中,在写操作,生成excel文档

二.jar包

涉及到的jar包,阿里的fastjson和poi的jar包

三.代码

我的json文档里数据的格式是这样的

[ 
{
        "total": 1,
        "name": "规则限制:XXXX",
        "timeStr": 1619242800000,
        "message": "XXX",
        "hehe": ""
    },
    
    {
        "total": 2,
        "name": "服务异常:XXXX",
        "timeStr": 1619240400000,
        "message": "XXX!",
        "hehe": ""
    }
]

1.先对json文件进行读操作,提取String对象,在将String对象转换为JsonArray

public static String readJsonFile(String path) {
        String jsonString = "";
        try {
            File file = new File(path);
            FileReader fileReader = new FileReader(file);
            Reader reader = new InputStreamReader(new FileInputStream(file),"utf-8");
            int ch = 0;
            StringBuffer sb = new StringBuffer();
            while ((ch = reader.read()) != -1) {
                sb.append((char) ch);
            }
            fileReader.close();
            reader.close();
            jsonString = sb.toString();
            return jsonString;
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

我试过直接读文件,出现中文乱码,所以记得用UTF-8编码,否则会是乱码

2.文件内容以String的形式获取到,这时创建excel文件,在将String转换为jsonArray形式遍历,分别插入到excel文件的单元格cell中,在做写操作

public static void main(String[] args) {
        String json = ToJson.readJsonFile("C:\\Users\\yu\\Desktop\\new.json");

        //System.out.println(json);
        //JSONObject object = JSON.parseObject(json);

        try {
            //生成excel文件存放的地址
            String uploadFile = "D:/test.xlsx";
            OutputStream excel = new FileOutputStream(uploadFile);
            XSSFWorkbook workBook = new XSSFWorkbook();
            XSSFSheet sheet = workBook.createSheet();

            XSSFRow row = null;//行
            XSSFCell cell = null;//单元格

            row = sheet.createRow(0);
            //这是创建excel上边的标题头
            String[] names = { "total", "异常", "页面名称", "信息","时间","工号"};
            for (int index = 0; index < 5; index++) {
                cell = row.createCell(index);
                cell.setCellValue(names[index]);
            }
            int count = 1;

            JSONArray dataArray = JSONArray.parseArray(json);
            for(int i = 0; i < dataArray.size();i++){
                JSONObject dataObj =  dataArray.getJSONObject(i);
                //获取不同key中的值
                String total = dataObj.getString("total");
                String name = dataObj.getString("name");
                String[] nameArray = name.split(":");//这个是通过分号获得两个值,分别写在excel中
                String name1 = nameArray[0];
                String name2 = nameArray[1];
                String timeStr = dataObj.getString("timeStr");
                String time = ToJson.stampToTime(timeStr);//这个根据时间戳转换为正常年月日,时分秒
                String message = dataObj.getString("message");
                String staffId = dataObj.getString("hehe");

                row = sheet.createRow(count);
                cell = row.createCell(0);
                cell.setCellValue(total);

                cell = row.createCell(1);
                cell.setCellValue(name1);

                cell = row.createCell(2);
                cell.setCellValue(name2);

                cell = row.createCell(3);
                cell.setCellValue(message);

                cell = row.createCell(4);
                cell.setCellValue(time);

                cell = row.createCell(5);
                cell.setCellValue(staffId);

                count++;

            }
            workBook.write(excel);

        } catch (Exception e) {
            e.printStackTrace();
        }

    }

时间戳的转换方法:

public static String  stampToTime(String stamp) {
        String sd = "";
        Date d = new Date();
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        sd = sdf.format(new Date(Long.parseLong(stamp))); // 时间戳转换日期
        return sd;
    }

运行即可获得excel文件

全部代码:

package com.china.excelToJson;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.io.*;
import java.text.SimpleDateFormat;
import java.util.Date;

public class ToJson {


    public static void main(String[] args) {
        String json = ToJson.readJsonFile("C:\\Users\\yu\\Desktop\\new.json");

        //System.out.println(json);
        //JSONObject object = JSON.parseObject(json);

        try {
            //生成excel文件存放的地址
            String uploadFile = "D:/test.xlsx";
            OutputStream excel = new FileOutputStream(uploadFile);
            XSSFWorkbook workBook = new XSSFWorkbook();
            XSSFSheet sheet = workBook.createSheet();

            XSSFRow row = null;//行
            XSSFCell cell = null;//单元格

            row = sheet.createRow(0);
            //这是创建excel上边的标题头
            String[] names = { "total", "异常", "页面名称", "信息","时间","工号"};
            for (int index = 0; index < 5; index++) {
                cell = row.createCell(index);
                cell.setCellValue(names[index]);
            }
            int count = 1;

            JSONArray dataArray = JSONArray.parseArray(json);
            for(int i = 0; i < dataArray.size();i++){
                JSONObject dataObj =  dataArray.getJSONObject(i);
                //获取不同key中的值
                String total = dataObj.getString("total");
                String name = dataObj.getString("name");
                String[] nameArray = name.split(":");//这个是通过分号获得两个值,分别写在excel中
                String name1 = nameArray[0];
                String name2 = nameArray[1];
                String timeStr = dataObj.getString("timeStr");
                String time = ToJson.stampToTime(timeStr);//这个根据时间戳转换为正常年月日,时分秒
                String message = dataObj.getString("message");
                String staffId = dataObj.getString("hehe");

                row = sheet.createRow(count);
                cell = row.createCell(0);
                cell.setCellValue(total);

                cell = row.createCell(1);
                cell.setCellValue(name1);

                cell = row.createCell(2);
                cell.setCellValue(name2);

                cell = row.createCell(3);
                cell.setCellValue(message);

                cell = row.createCell(4);
                cell.setCellValue(time);

                cell = row.createCell(5);
                cell.setCellValue(staffId);

                count++;

            }
            workBook.write(excel);

        } catch (Exception e) {
            e.printStackTrace();
        }

    }

    public static String  stampToTime(String stamp) {
        String sd = "";
        Date d = new Date();
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        sd = sdf.format(new Date(Long.parseLong(stamp))); // 时间戳转换日期
        return sd;
    }

    public static String readJsonFile(String fileName) {
        String jsonStr = "";
        try {
            File jsonFile = new File(fileName);
            FileReader fileReader = new FileReader(jsonFile);
            Reader reader = new InputStreamReader(new FileInputStream(jsonFile),"utf-8");
            int ch = 0;
            StringBuffer sb = new StringBuffer();
            while ((ch = reader.read()) != -1) {
                sb.append((char) ch);
            }
            fileReader.close();
            reader.close();
            jsonStr = sb.toString();
            return jsonStr;
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }
}

到此这篇关于基于Java实现Json文件转换为Excel文件的文章就介绍到这了,更多相关Java Json转Excel内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java中包装类和Arrays类的详细介绍

    Java中包装类和Arrays类的详细介绍

    Arrays针对于数组做操作的类,该类包含用于操作数组的各种方法(如排序和搜索),这篇文章主要给大家介绍了关于Java中包装类和Arrays类的详细介绍,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-12-12
  • 使用Java实现将ppt转换为文本

    使用Java实现将ppt转换为文本

    这篇文章主要为大家详细介绍了如何使用Java实现将ppt转换为文本,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以参考下
    2024-01-01
  • Struts2实现文件上传功能

    Struts2实现文件上传功能

    这篇文章主要为大家详细介绍了Struts2实现文件上传功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Spring自动装配之方法、构造器位置的自动注入操作

    Spring自动装配之方法、构造器位置的自动注入操作

    这篇文章主要介绍了Spring自动装配之方法、构造器位置的自动注入操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • 在mybatis中使用mapper进行if条件判断

    在mybatis中使用mapper进行if条件判断

    这篇文章主要介绍了在mybatis中使用mapper进行if条件判断,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • Java包装类的缓存机制原理实例详解

    Java包装类的缓存机制原理实例详解

    这篇文章主要介绍了Java包装类的缓存机制原理实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • Java内部类_动力节点Java学院整理

    Java内部类_动力节点Java学院整理

    内部类是指在一个外部类的内部再定义一个类。下面通过本文给大家java内部类的使用小结,需要的朋友参考下吧
    2017-04-04
  • 详解Javaweb状态管理的Session和Cookie

    详解Javaweb状态管理的Session和Cookie

    这篇文章主要介绍了Javaweb状态管理的Session和Cookie,将浏览器与web服务器之间多次交互当做一个整体来处理,并且多次交互所涉及的数据(状态)保存下来,需要的朋友可以参考下
    2023-05-05
  • 利用Java的Struts框架实现电子邮件发送功能

    利用Java的Struts框架实现电子邮件发送功能

    这篇文章主要介绍了利用Java的Struts框架实现电子邮件发送功能,Struts框架是Java的SSH三大web开发框架之一,需要的朋友可以参考下
    2015-12-12
  • jmeter设置全局变量与正则表达式提取器过程图解

    jmeter设置全局变量与正则表达式提取器过程图解

    这篇文章主要介绍了jmeter设置全局变量与正则表达式提取器过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10

最新评论