JAVA生成并导出json文件

将一个list集合转换成json文件并导出:

package com.ruoyi.writeJson;



import net.sf.json.JSONArray;

import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class WriteJsonTest {
    public static void main(String[] args) {
        // 数据集合:
        List<Object> ffList = new ArrayList<Object>();
      
        Map<String, Object> ffMap = new HashMap<>();
            ffMap.put("ffName", "xfs_111");
            ffMap.put("latitude", "latitude");
            ffMap.put("longitude", "longitude");
            ffMap.put("status", (int)(Math.random() * 6 + 1));
            ffList.add(ffMap)
        // 将集合数据转换为json字符串(当然map集合亦可以):
        JSONArray jsonObject = JSONArray.fromObject(ffList);
        String jsonString1 = jsonObject.toString();
        CreateFileUtil.createJsonFile(jsonString1, "/fileStorage/download/json", "ffList");
    }
}

package com.ruoyi.writeJson;

import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.io.Writer;

public class CreateFileUtil {
    /**
     * 生成.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();

            if(jsonString.indexOf("'")!=-1){  
                //将单引号转义一下,因为JSON串中的字符串类型可以单引号引起来的  
                jsonString = jsonString.replaceAll("'", "\\'");  
            }  
            if(jsonString.indexOf("\"")!=-1){  
                //将双引号转义一下,因为JSON串中的字符串类型可以单引号引起来的  
                jsonString = jsonString.replaceAll("\"", "\\\"");  
            }  
              
            if(jsonString.indexOf("\r\n")!=-1){  
                //将回车换行转换一下,因为JSON串中字符串不能出现显式的回车换行  
                jsonString = jsonString.replaceAll("\r\n", "\\u000d\\u000a");  
            }  
            if(jsonString.indexOf("\n")!=-1){  
                //将换行转换一下,因为JSON串中字符串不能出现显式的换行  
                jsonString = jsonString.replaceAll("\n", "\\u000a");  
            }  
            
            // 格式化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;
    }
       
}
package com.ruoyi.writeJson;

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 == ',')) {
                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();
    }
}

注意 需要导入maven jar

 <dependency>
   <groupId>net.sf.json-lib</groupId>
     <artifactId>json-lib</artifactId>
     <version>2.4</version>
     <classifier>jdk15</classifier>
 </dependency>

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是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); } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值