欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于Java實(shí)現(xiàn)Json文件轉(zhuǎn)換為Excel文件

 更新時間:2022年12月01日 16:23:05   作者:菜鳥小于  
這篇文章主要為大家詳細(xì)介紹了如何利用Java實(shí)現(xiàn)Json文件轉(zhuǎn)換為Excel文件,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,需要的可以參考一下

一. 思路

今天接到個小任務(wù),讓把json文件轉(zhuǎn)換成excel文件,按照列展開.

思路:既然json已經(jīng)都已經(jīng)是現(xiàn)成的,那直接將json文件做讀操作,在通過不同的key,找到對應(yīng)的信息,在存到單元格中,在寫操作,生成excel文檔

二.jar包

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

三.代碼

我的json文檔里數(shù)據(jù)的格式是這樣的

[ 
{
        "total": 1,
        "name": "規(guī)則限制:XXXX",
        "timeStr": 1619242800000,
        "message": "XXX",
        "hehe": ""
    },
    
    {
        "total": 2,
        "name": "服務(wù)異常:XXXX",
        "timeStr": 1619240400000,
        "message": "XXX!",
        "hehe": ""
    }
]

1.先對json文件進(jìn)行讀操作,提取String對象,在將String對象轉(zhuǎn)換為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;
        }
    }

我試過直接讀文件,出現(xiàn)中文亂碼,所以記得用UTF-8編碼,否則會是亂碼

2.文件內(nèi)容以String的形式獲取到,這時創(chuàng)建excel文件,在將String轉(zhuǎn)換為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);
            //這是創(chuàng)建excel上邊的標(biāo)題頭
            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);//這個根據(jù)時間戳轉(zhuǎn)換為正常年月日,時分秒
                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();
        }

    }

時間戳的轉(zhuǎn)換方法:

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))); // 時間戳轉(zhuǎn)換日期
        return sd;
    }

運(yùn)行即可獲得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);
            //這是創(chuàng)建excel上邊的標(biāo)題頭
            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);//這個根據(jù)時間戳轉(zhuǎn)換為正常年月日,時分秒
                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))); // 時間戳轉(zhuǎn)換日期
        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;
        }
    }
}

到此這篇關(guān)于基于Java實(shí)現(xiàn)Json文件轉(zhuǎn)換為Excel文件的文章就介紹到這了,更多相關(guān)Java Json轉(zhuǎn)Excel內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JAVA IO的3種類型區(qū)別解析

    JAVA IO的3種類型區(qū)別解析

    這篇文章主要介紹了JAVA IO的3種類型解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • Java switch多值匹配操作詳解

    Java switch多值匹配操作詳解

    這篇文章主要介紹了Java switch多值匹配操作詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • Java基礎(chǔ)教程之String深度分析

    Java基礎(chǔ)教程之String深度分析

    這篇文章主要給大家介紹了關(guān)于Java基礎(chǔ)教程之String的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • java根據(jù)富文本生成pdf文件過程解析

    java根據(jù)富文本生成pdf文件過程解析

    這篇文章主要介紹了java根據(jù)富文本生成pdf文件過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • Java生成UUID的常用方式示例代碼

    Java生成UUID的常用方式示例代碼

    UUID保證對在同一時空中的所有機(jī)器都是唯一的,通常平臺會提供生成的API,按照開放軟件基金會(OSF)制定的標(biāo)準(zhǔn)計算,用到了以太網(wǎng)卡地址、納秒級時間、芯片ID碼和許多可能的數(shù)字,下面這篇文章主要給大家介紹了關(guān)于Java生成UUID的常用方式,需要的朋友可以參考下
    2023-05-05
  • Java實(shí)現(xiàn)SSH模式加密

    Java實(shí)現(xiàn)SSH模式加密

    這篇文章主要介紹了Java實(shí)現(xiàn)SSH模式加密的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • Java排序算法中的選擇排序算法實(shí)現(xiàn)

    Java排序算法中的選擇排序算法實(shí)現(xiàn)

    這篇文章主要介紹了Java排序算法中的選擇排序算法實(shí)現(xiàn),選擇排序算法的實(shí)現(xiàn)思路類似插入排序,分已排序區(qū)間和未排序區(qū)間,選擇排序每次會從未排序區(qū)間中找到最小(大)的元素,將其放到已排序區(qū)間的末尾,需要的朋友可以參考下
    2023-12-12
  • socket編程時的發(fā)送與接收數(shù)據(jù)時的問題解析

    socket編程時的發(fā)送與接收數(shù)據(jù)時的問題解析

    這篇文章主要為大家介紹了socket編程時的發(fā)送與接收數(shù)據(jù)時的問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • spring學(xué)習(xí)之@SessionAttributes實(shí)例解析

    spring學(xué)習(xí)之@SessionAttributes實(shí)例解析

    這篇文章主要介紹了spring學(xué)習(xí)之@SessionAttributes實(shí)例解析,分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • Java超詳細(xì)分析繼承與重寫的特點(diǎn)

    Java超詳細(xì)分析繼承與重寫的特點(diǎn)

    繼承是Java面向?qū)ο缶幊讨械囊婚T。繼承是子類繼承父類的特征和行為,或者是繼承父類得方法,使的子類具有父類得的特性和行為。重寫是子類對父類的允許訪問的方法實(shí)行的過程進(jìn)行重新編寫,返回值和形參都不能改變。就是對原本的父類進(jìn)行重新編寫,但是外部接口不能被重寫
    2022-05-05

最新評論