javajson转csv(Java json转对象)

发布时间:2023-12-08

javajson转csv(Java json转对象)

更新:<time datetime="2022-11-09 04:20">2022-11-09 04:20</time>

本文目录一览:

1、如何将json的数据转化成csv的数据格式
2、java中怎么把json转换成对象数组
3、java将json格式转换嫒雖ysql的java脚本,有没有
4、如何将CSV格式转换成JSON格式
5、java中json格式转换有哪些方法
6、java中把json怎么转换成数组?

如何将json的数据转化成csv的数据格式

请问你是在什么语言中?是js对象弄到java对象还是java发过来在页面中看到的?还是其他语言c#php?如果是js到java可以用google的gson很简单如果是java发的js给页面直接循环就可以拿到了

java中怎么把json转换成对象数组

1、使用原生的解析:

String json = "...";
JSONArray array= new JSONArray(json);
//遍历数组里的值,得到每个独立的对象,然后获取对应的值设置到声明好的对象中,最终创建对象完成后添加到集合中,如我自己代码里的片段:
for (int j = 0; j < array.length(); j++) {
    obj = array.getJSONObject(j);
    Data data = new Data();
    data.setThumbnail(obj.getString("thumbnail"));
    data.setTitle(obj.getString("title"));
    data.setUrl(obj.getString("url"));
    mDataList.add(data);
}

2、使用第三方包如Gson,但是这个你得保证你的JSON字符串个z

java将json格式转换嫒雖ysql的java脚本,有没有

执行环境 需要以下类库支持

  • commons-lang 2.5
  • commons-beanutils 1.8.0
  • commons-collections 3.2.1
  • commons-logging 1.1.1
  • ezmorph 1.0.6

功能示例

这里通过JUnit-Case例子给出代码示例

package com.mai.json;
import static org.junit.Assert.assertEquals;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import net.sf.ezmorph.Morpher;
import net.sf.ezmorph.MorpherRegistry;
import net.sf.ezmorph.bean.BeanMorpher;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import net.sf.json.util.JSONUtils;
import org.apache.commons.beanutils.PropertyUtils;
import org.junit.Test;
public class JsonLibTest {
    /*
     * 普通类型、List、Collection等都是用JSONArray解析
     * 
     * Map、自定义类型是用JSONObject解析
     * 可以将Map理解成一个对象,里面的key/value对可以理解成对象的属性/属性值
     * 即{key1:value1,key2,value2......}
     * 
     * 1.JSONObject是一个name:values集合,通过它的get(key)方法取得的是key后对应的value部分(字符串)
     * 通过它的getJSONObject(key)可以取到一个JSONObject,-- 转换成map,
     * 通过它的getJSONArray(key) 可以取到一个JSONArray ,
     */
    // 一般数组转换成JSON
    @Test
    public void testArrayToJSON() {
        boolean[] boolArray = new boolean[] { true, false, true };
        JSONArray jsonArray = JSONArray.fromObject(boolArray);
        System.out.println(jsonArray);
        // prints [true,false,true]
    }
    // Collection对象转换成JSON
    @Test
    public void testListToJSON() {
        List list = new ArrayList();
        list.add("first");
        list.add("second");
        JSONArray jsonArray = JSONArray.fromObject(list);
        System.out.println(jsonArray);
        // prints ["first","second"]
    }
    // 字符串json转换成json, 根据情况是用JSONArray或JSONObject
    @Test
    public void testJsonStrToJSON() {
        JSONArray jsonArray = JSONArray.fromObject("['json','is','easy']");
        System.out.println(jsonArray);
        // prints ["json","is","easy"]
    }
    // Map转换成json, 是用jsonObject
    @Test
    public void testMapToJSON() {
        Map map = new HashMap();
        map.put("name", "json");
        map.put("bool", Boolean.TRUE);
        map.put("int", new Integer(1));
        map.put("arr", new String[] { "a", "b" });
        map.put("func", "function(i){ return this.arr[i]; }");
        JSONObject jsonObject = JSONObject.fromObject(map);
        System.out.println(jsonObject);
    }
    // 复合类型bean转成成json
    @Test
    public void testBeadToJSON() {
        MyBean bean = new MyBean();
        bean.setId("001");
        bean.setName("银行卡");
        bean.setDate(new Date());
        List cardNum = new ArrayList();
        cardNum.add("农行");
        cardNum.add("工行");
        cardNum.add("建行");
        cardNum.add(new Person("test"));
        bean.setCardNum(cardNum);
        JSONObject jsonObject = JSONObject.fromObject(bean);
        System.out.println(jsonObject);
    }
    // 普通类型的json转换成对象
    @Test
    public void testJSONToObject() throws Exception {
        String json = "{name=\"json\",bool:true,int:1,double:2.2,func:function(a){ return a; },array:[1,2]}";
        JSONObject jsonObject = JSONObject.fromObject(json);
        System.out.println(jsonObject);
        Object bean = JSONObject.toBean(jsonObject);
        assertEquals(jsonObject.get("name"), PropertyUtils.getProperty(bean, "name"));
        assertEquals(jsonObject.get("bool"), PropertyUtils.getProperty(bean, "bool"));
        assertEquals(jsonObject.get("int"), PropertyUtils.getProperty(bean, "int"));
        assertEquals(jsonObject.get("double"), PropertyUtils.getProperty(bean, "double"));
        assertEquals(jsonObject.get("func"), PropertyUtils.getProperty(bean, "func"));
        System.out.println(PropertyUtils.getProperty(bean, "name"));
        System.out.println(PropertyUtils.getProperty(bean, "bool"));
        System.out.println(PropertyUtils.getProperty(bean, "int"));
        System.out.println(PropertyUtils.getProperty(bean, "double"));
        System.out.println(PropertyUtils.getProperty(bean, "func"));
        System.out.println(PropertyUtils.getProperty(bean, "array"));
        List arrayList = (List) JSONArray.toCollection(jsonObject.getJSONArray("array"));
        for (Object object : arrayList) {
            System.out.println(object);
        }
    }
    // 将json解析成复合类型对象, 包含List
    @Test
    public void testJSONToBeanHavaList() {
        String json = "{list:[{name:'test1'},{name:'test2'}],map:{test1:{name:'test1'},test2:{name:'test2'}}}";
        // String json = "{list:[{name:'test1'},{name:'test2'}]}";
        Map classMap = new HashMap();
        classMap.put("list", Person.class);
        MyBeanWithPerson diyBean = (MyBeanWithPerson) JSONObject.toBean(JSONObject.fromObject(json),
                MyBeanWithPerson.class, classMap);
        System.out.println(diyBean);
        List list = diyBean.getList();
        for (Object o : list) {
            if (o instanceof Person) {
                Person p = (Person) o;
                System.out.println(p.getName());
            }
        }
    }
    // 将json解析成复合类型对象, 包含Map
    @Test
    public void testJSONToBeanHavaMap() {
        // 把Map看成一个对象
        String json = "{list:[{name:'test1'},{name:'test2'}],map:{testOne:{name:'test1'},testTwo:{name:'test2'}}}";
        Map classMap = new HashMap();
        classMap.put("list", Person.class);
        classMap.put("map", Map.class);
        // 使用暗示,直接将json解析为指定自定义对象,其中List完全解析,Map没有完全解析
        MyBeanWithPerson diyBean = (MyBeanWithPerson) JSONObject.toBean(JSONObject.fromObject(json),
                MyBeanWithPerson.class, classMap);
        System.out.println(diyBean);
        System.out.println("do the list release");
        List<Person> list = diyBean.getList();
        for (Person o : list) {
            Person p = (Person) o;
            System.out.println(p.getName());
        }
        System.out.println("do the map release");
        // 先往注册器中注册变换器,需要用到ezmorph包中的类
        MorpherRegistry morpherRegistry = JSONUtils.getMorpherRegistry();
        Morpher dynaMorpher = new BeanMorpher(Person.class, morpherRegistry);
        morpherRegistry.registerMorpher(dynaMorpher);
        Map map = diyBean.getMap();
        /* 这里的map没进行类型暗示,故按默认的,里面存的为net.sf.ezmorph.bean.MorphDynaBean类型的对象 */
        System.out.println(map);
        /*
         * 输出: {testOne=net.sf.ezmorph.bean.MorphDynaBean@f73c1[
         * {name=test1} ], testTwo=net.sf.ezmorph.bean.MorphDynaBean@186c6b2[
         * {name=test2} ]}
         */
        List<Person> output = new ArrayList();
        for (Iterator i = map.values().iterator(); i.hasNext();) {
            // 使用注册器对指定DynaBean进行对象变换
            output.add((Person) morpherRegistry.morph(Person.class, i.next()));
        }
        for (Person p : output) {
            System.out.println(p.getName());
            /*
             * 输出: test1 test2
             */
        }
    }
}

如何将CSV格式转换成JSON格式

下面的工具可以方便的将CSV格式文件转换成json文件格式

import sys, json
tip = """
请确保:
1. CSV格式是UTF-8
2. CSV第一行是键值
用法:
python csv2json.py foobar.csv
其中foobar.csv是需要转换的源数据文件
运行环境:
Python 3.4.3
日期:
2015年12月29日
"""
print(tip)
# 获取输入数据
input_file = sys.argv[1]
lines = open(input_file, "r", encoding="utf_8_sig").readlines()
lines = [line.strip() for line in lines]
# 获取键值
keys = lines[0].split(',')
line_num = 1
total_lines = len(lines)
parsed_datas = []
while line_num < total_lines:
    values = lines[line_num].split(",")
    parsed_datas.append(dict(zip(keys, values)))
    line_num = line_num + 1
json_str = json.dumps(parsed_datas, ensure_ascii=False, indent=4)
output_file = input_file.replace("csv", "json")
# write to the file
f = open(output_file, "w", encoding="utf-8")
f.write(json_str)
f.close()
print("解析结束!")

java中json格式转换有哪些方法

用自带的解析工具

package cn.edu.bzu.json;
import java.io.FileNotFoundException;
import java.io.FileReader;
import com.google.gson.JsonArray;
import com.google.gson.JsonIOException;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
import com.google.gson.JsonSyntaxException;
public class Read {
    public static void main(String args[]) {
        JsonParser parse = new JsonParser(); // 创建json解析器
        try {
            JsonObject json = (JsonObject) parse.parse(new FileReader("weather.json")); // 创建jsonObject对象
            System.out.println("resultcode:" + json.get("resultcode").getAsInt()); // 将json数据转为为int型的数据
            System.out.println("reason:" + json.get("reason").getAsString()); // 将json数据转为为String型的数据
            JsonObject result = json.get("result").getAsJsonObject();
            JsonObject today = result.get("today").getAsJsonObject();
            System.out.println("temperature:" + today.get("temperature").getAsString());
            System.out.println("weather:" + today.get("weather").getAsString());
        } catch (JsonIOException e) {
            e.printStackTrace();
        } catch (JsonSyntaxException e) {
            e.printStackTrace();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
    }
}

java中把json怎么转换成数组?

使用原生的解析:

String json = "...";
// 遍历数组里的值,得到每个独立的对象,然后获取对应的值设置到声明好的对象中,最终创建对象完成后添加到集合中,如我自己代码里的片段:
for (int j = 0; j < array.length(); j++) {
    obj = array.getJSONObject(j);
    Data data = new Data();
    mDataList.add(data);
}

数组声明

在数组的声明格式里,“数据类型”是声明数组元素的数据类型,可以是java语言中任意的数据类型,包括简单类型和结构类型。“数组名”是用来统一这些相同数据类型的名称,其命名规则和变量的命名规则相同。 数组声明之后,接下来便是要分配数组所需要的内存,这时必须用运算符new,其中“个数”是告诉编译器,所声明的数组要存放多少个元素,所以new运算符是通知编译器根据括号里的个数,在内存中分配一块空间供该数组使用。利用new运算符为数组元素分配内存空间的方式称为动态分配方式。 以上内容参考:百度百科-数组