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

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

1、依赖

<dependency>
  <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>2.0.12</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>3.14</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>3.14</version>
</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("文件转换成功");
    }
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值