您的位置:

从JSON转Java

一、JSON转XML

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,常用于Web应用程序之间的数据交换。XML(eXtensible Markup Language)也是一种用于传输和存储数据的标记语言。在一些特定的情况下,需要将JSON转换为XML格式,进行数据传输和处理。下面是一个将JSON转换为XML的示例:

public static String jsonToXml(String json) throws JSONException {
    JSONObject jsonObj = new JSONObject(json);
    String xml = "" + org.json.XML.toString(jsonObj) + "
  ";
    return xml;
}

在这个示例中,我们使用org.json库中的XML.toString方法将JSONObject转换为XML格式。其中,root节点用于将生成的XML文档进行包装。

二、JSON转换

JSON转换是指将JSON字符串转换为Java对象或将Java对象转换为JSON字符串。这在Web应用程序中很常见,特别是在与前端交互时。下面是一个使用Jackson库将JSON字符串转换为Java对象的示例:

String json = "{\"name\":\"John\", \"age\":30, \"city\":\"New York\"}";
ObjectMapper objectMapper = new ObjectMapper();
User user = objectMapper.readValue(json, User.class);

在这个示例中,我们使用Jackson库中的readValue方法将JSON字符串转换为Java对象User。其中,User类的成员变量与JSON字符串中的键值对对应。

三、JSON转Excel

JSON转Excel是将JSON格式的数据导出为Excel文件。通常情况下,我们需要使用第三方工具库来处理这个任务,例如Apache POI。下面是一个使用Apache POI将JSON格式的数据导出为Excel文件的示例:

public void jsonToExcel(String json, String filePath) throws Exception {
    JSONArray jsonArray = new JSONArray(json);
    Workbook workbook = new HSSFWorkbook();
    Sheet sheet = workbook.createSheet("Sheet1");
    
    for (int i = 0; i < jsonArray.length(); i++) {
        JSONObject jsonObject = jsonArray.getJSONObject(i);
        Row row = sheet.createRow(i);
        Iterator iterator = jsonObject.keys();
        int j = 0;
        while (iterator.hasNext()) {
            String key = (String) iterator.next();
            Cell cell = row.createCell(j++);
            cell.setCellValue(jsonObject.optString(key));
        }
    }
    FileOutputStream fileOutputStream = new FileOutputStream(filePath);
    workbook.write(fileOutputStream);
    fileOutputStream.close();
}

在这个示例中,我们将JSON数组转换为Java中的JSONArray对象,并使用Apache POI创建Excel文件。然后,在循环中遍历每个JSONObject对象,并将其转换为一行的单元格进入到Excel文件中。

四、JSON串转Map

有时,我们需要将JSON字符串转换为Java中的Map对象进行处理。下面是一个示例,将JSON字符串转换为Map对象:

public static Map jsonToMap(String json) throws JSONException {
    JSONObject jsonObject = new JSONObject(json);
    Map
    map = new HashMap<>();
    Iterator iterator = jsonObject.keys();
    while(iterator.hasNext()){
        String key = (String)iterator.next();
        String value = jsonObject.optString(key);
        map.put(key, value);
    }
    return map;
}

   
  

在这个示例中,我们将JSON字符串转换为JSONObject对象,然后使用迭代器遍历每个键值对,并将其存储在Java中的Map对象中。