Java将Json文件并转换成Excel表格

Java将Json文件并转换成Excel表格

1、依赖

<dependency>
  <groupId>com.alibabagroupId>
    <artifactId>fastjsonartifactId>
    <version>2.0.12version>
dependency>
<dependency>
    <groupId>org.apache.poigroupId>
    <artifactId>poiartifactId>
    <version>3.14version>
dependency>
<dependency>
    <groupId>org.apache.poigroupId>
    <artifactId>poi-ooxmlartifactId>
    <version>3.14version>
dependency>

2、核心类、方法

2.1、创建Excel表及表单

// 创建Excel文件
HSSFWorkbook wb = new HSSFWorkbook();
// 创建Excel表单,表单名为sheet(可以用wb创建多个HSSFSheet,最后都是将wb写入文件中)
HSSFSheet sheet = wb.createSheet("sheet");

2.2、创建行和列

// 创建行
HSSFRow row= sheet.createRow("rowNum");
// 创建改行的列
HSSFCell cell = row.createCell("colNum");
// 给列设置值
cell.setCellValue("value");

3、示例

public class DataConverge {
    public static void main(String[] args) throws IOException {
        File file = new File("C:\\zsh\\projectInSchool\\traffic\\result");
        File[] files = file.listFiles();
        // excel行号
        int rowNum = 0;
        // 创建Excel文件
        HSSFWorkbook wb = new HSSFWorkbook();
        // 创建Excel表单,表单名为sheet(可以用wb创建多个HSSFSheet,最后都是将wb写入文件中)
        HSSFSheet sheet = wb.createSheet("sheet");
        // 设置Excel表头
        HSSFRow rowTtile = sheet.createRow(rowNum++);
        rowTtile.createCell(0).setCellValue("日期");
        rowTtile.createCell(1).setCellValue("区域名称");
        rowTtile.createCell(2).setCellValue("交通指数");
        rowTtile.createCell(3).setCellValue("拥堵等级");
        rowTtile.createCell(4).setCellValue("平均速度");

        // 上一个数据的日期,用于去重
        String preDate = "";

        for (File f : files) {
            // 获取文件名,这里的文件名是时间戳
            String dateTimeStamp = f.getName().split("\\.")[0];
            // 时间戳字符串形式转换成日期形式
            String date = new SimpleDateFormat("yyyy-MM-dd").format(Long.parseLong(dateTimeStamp));

            // 读取文件
            FileInputStream fis  = new FileInputStream(f);
            InputStreamReader isr = new InputStreamReader(fis,"UTF-8");
            BufferedReader reader = new BufferedReader(isr);
            // 文件内容:json字符串
            StringBuilder sb = new StringBuilder();
            int ch = 0;
            while ((ch = reader.read()) != -1) {
                sb.append((char) ch);
            }
            reader.close();

            // 将json字符串转换成json对象
            JSONObject jsonObject = JSONObject.parseObject(sb.toString());

            // 如果当前时间段和上一条数据的相同,则认定为重复数据,跳过
            if(preDate.equals(jsonObject.get("time"))) {
                continue;
            }
            preDate = jsonObject.get("time").toString();

            JSONArray items = jsonObject.getJSONArray("items");
            for (Object item : items) {
                JSONObject itemJson = (JSONObject) item;
                HSSFRow rowContent = sheet.createRow(rowNum++);
                rowContent.createCell(0).setCellValue(date+ " " +jsonObject.get("time"));
                rowContent.createCell(1).setCellValue(itemJson.getString("place"));
                rowContent.createCell(2).setCellValue(itemJson.getString("indicator"));
                rowContent.createCell(3).setCellValue(itemJson.getString("level"));
                rowContent.createCell(4).setCellValue(itemJson.getString("speed"));
            }
            FileOutputStream outputStream = new FileOutputStream("C:\\zsh\\projectInSchool\\traffic\\result.xls");
            wb.write(outputStream);
            fis.close();
            isr.close();
            outputStream.close();
        }
        wb.close();
        System.out.println("文件转换成功");
    }
}

你可能感兴趣的:(后端项目学习记录,excel,java,开发语言)