java生成并导出JSON文件到本地

32 篇文章 0 订阅
23 篇文章 0 订阅

参考

https://blog.csdn.net/Dhjie_king/article/details/103074705

创建json文件工具类

CreateJsonFileUtils.java文件

package com.wei.utils;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.io.Writer;
/**
 * 生成JSON文件
 * @author Dhjie
 *
 */
public class CreateJsonFileUtils {

    /**
     * 生成.json格式文件
     * 参数说明:
     * jsonString:json的字符串 ;filePath:要把生成的json文件放到什么位置;fileName:给json文件的命名
     * 返回值为布尔值:flag,默认为true,代表是否生成json文件成功
     */
    public static boolean createJsonFile(String jsonString, String filePath, String fileName) {
        // 标记文件生成是否成功
        boolean flag = true;

        // 拼接文件完整路径
        String fullPath = filePath + File.separator + fileName + ".json";

        // 生成json格式文件
        try {
            // 保证创建一个新文件
            File file = new File(fullPath);
            if (!file.getParentFile().exists()) { // 如果父目录不存在,创建父目录
                file.getParentFile().mkdirs();
            }
            if (file.exists()) { // 如果已存在,删除旧文件
                file.delete();
            }
            file.createNewFile();

            // 格式化json字符串
            jsonString = JsonFormatTool.formatJson(jsonString);

            // 将格式化后的字符串写入文件
            Writer write = new OutputStreamWriter(new FileOutputStream(file), "UTF-8");
            write.write(jsonString);
            write.flush();
            write.close();
        } catch (Exception e) {
            flag = false;
            e.printStackTrace();
        }

        // 返回是否成功的标记
        return flag;
    }

}

JSON格式化工具类

JsonFormatTool.java文件

package com.wei.utils;
/**
 * json格式化
 * @author Dhjie
 *
 */
public class JsonFormatTool {
    /**
     * 单位缩进字符串。
     */
    private static String SPACE = "   ";

    /**
     * 返回格式化JSON字符串。
     * 
     * @param json 未格式化的JSON字符串。
     * @return 格式化的JSON字符串。
     */
    public static String formatJson(String json) {
        StringBuffer result = new StringBuffer();

        int length = json.length();
        int number = 0;
        char key = 0;

        // 遍历输入字符串。
        for (int i = 0; i < length; i++) {
            // 1、获取当前字符。
            key = json.charAt(i);

            // 2、如果当前字符是前方括号、前花括号做如下处理:
            if ((key == '[') || (key == '{')) {
                // (1)如果前面还有字符,并且字符为“:”,打印:换行和缩进字符字符串。
                if ((i - 1 > 0) && (json.charAt(i - 1) == ':')) {
                    result.append('\n');
                    result.append(indent(number));
                }

                // (2)打印:当前字符。
                result.append(key);

                // (3)前方括号、前花括号,的后面必须换行。打印:换行。
                result.append('\n');

                // (4)每出现一次前方括号、前花括号;缩进次数增加一次。打印:新行缩进。
                number++;
                result.append(indent(number));

                // (5)进行下一次循环。
                continue;
            }

            // 3、如果当前字符是后方括号、后花括号做如下处理:
            if ((key == ']') || (key == '}')) {
                // (1)后方括号、后花括号,的前面必须换行。打印:换行。
                result.append('\n');

                // (2)每出现一次后方括号、后花括号;缩进次数减少一次。打印:缩进。
                number--;
                result.append(indent(number));

                // (3)打印:当前字符。
                result.append(key);

                // (4)如果当前字符后面还有字符,并且字符不为“,”,打印:换行。
                if (((i + 1) < length) && (json.charAt(i + 1) != ',')) {
                    result.append('\n');
                }

                // (5)继续下一次循环。
                continue;
            }

            // 4、如果当前字符是逗号。逗号后面换行,并缩进,不改变缩进次数。
            if ((key == ',')) {
            	// 1、获取当前字符。
                //char beforeKey = json.charAt(i-1);
                //System.out.println(beforeKey);
                
                result.append(key);
                result.append('\n');
                result.append(indent(number));
                continue;
            }

            // 5、打印:当前字符。
            result.append(key);
        }

        return result.toString();
    }

    /**
     * 返回指定次数的缩进字符串。每一次缩进三个空格,即SPACE。
     * 
     * @param number 缩进次数。
     * @return 指定缩进次数的字符串。
     */
    private static String indent(int number) {
        StringBuffer result = new StringBuffer();
        for (int i = 0; i < number; i++) {
            result.append(SPACE);
        }
        return result.toString();
    }
}

**注意!**
上面代码中的

            // 4、如果当前字符是逗号。逗号后面换行,并缩进,不改变缩进次数。
            if ((key == ',')) {
            	// 1、获取当前字符。
                char beforeKey = json.charAt(i-1);
                System.out.println(beforeKey);
                
                result.append(key);
                result.append('\n');
                result.append(indent(number));
                continue;
            }

由于我导出的json文件中,主要是从数据库拿出来的博客、文章的详细情况,里面有个字段是存储的文章详情,如果只是简单地判断当前字符是就换行并缩进,容易引起错误(我问着里面也可能有这个字符),json文件的格式不正确!

由于我的本意是想用前端来获取并解析json文件的,这样由于json文件的内部错误是解析不到的

所以我把上面这部分代码注释掉了,当然你也可以进行改进,比如你去判断一下当前字符的前一个和后一个是否是英文状态的双引号,如果是的话,再换行处理

  • 1
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
以下是Java代码示例,通过json数据导出excel表,并返回下载url: ```java import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStream; import java.util.ArrayList; import java.util.LinkedHashMap; import java.util.List; import java.util.Map; import java.util.UUID; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import com.alibaba.fastjson.JSON; public class ExcelExportUtil { public static String exportToExcel(String jsonData) throws IOException { // 解析json数据 List<Map<String, Object>> dataList = JSON.parseObject(jsonData, List.class); // 创建excel工作簿 Workbook workbook = new HSSFWorkbook(); // 创建第一个sheet页 Sheet sheet = workbook.createSheet("Sheet1"); // 创建表头 Row headerRow = sheet.createRow(0); int cellIndex = 0; for (String key : dataList.get(0).keySet()) { Cell cell = headerRow.createCell(cellIndex++); cell.setCellValue(key); } // 填充数据 int rowIndex = 1; for (Map<String, Object> data : dataList) { Row row = sheet.createRow(rowIndex++); cellIndex = 0; for (Object value : data.values()) { Cell cell = row.createCell(cellIndex++); if (value instanceof Number) { cell.setCellValue(((Number) value).doubleValue()); } else { cell.setCellValue(value.toString()); } } } // 生成文件名 String fileName = UUID.randomUUID().toString() + ".xls"; // 保存excel文件 File file = new File(fileName); OutputStream os = new FileOutputStream(file); workbook.write(os); os.close(); // 返回下载url String url = file.toURI().toURL().toString(); return url; } public static void main(String[] args) throws IOException { // 测试数据 List<Map<String, Object>> dataList = new ArrayList<Map<String, Object>>(); Map<String, Object> data1 = new LinkedHashMap<String, Object>(); data1.put("name", "张三"); data1.put("age", 20); data1.put("gender", "男"); dataList.add(data1); Map<String, Object> data2 = new LinkedHashMap<String, Object>(); data2.put("name", "李四"); data2.put("age", 25); data2.put("gender", "女"); dataList.add(data2); // 导出excel并返回下载url String url = exportToExcel(JSON.toJSONString(dataList)); System.out.println(url); } } ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值