- 1、如何將json的數據轉化成csv的數據格式
- 2、java中怎麼把json轉換成對象數組
- 3、java將json格式轉換嬡雖ysql的java腳本,有沒有
- 4、如何將CSV格式轉換成JSON格式
- 5、java中json格式轉換有哪些方法
- 6、java中把json怎麼轉換成數組?
請問你是在什麼語言中?是js對象弄到java對象還是java發過來在頁面中看到的?還是其他語言c#php?如果是js到java可以用google的gson很簡單如果是java發的js給頁面直接循環就可以拿到了
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
執行環境
需要以下類庫支持
commons-lang 2.5
commons-beanutils 1.8.0
commons-collections 3.2.1
commons-logging 1.1.1
ezmorph 1.0.6
4.功能示例
這裡通過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”);
ListPerson 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}
]}
*/
ListPerson 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文件格式
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(“解析結束!”)
用自帶的解析工具
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();
}
}
}
使用原生的解析:
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運算符為數組元素分配內存空間的方式稱為動態分配方式。
以上內容參考:百度百科-數組
原創文章,作者:K2CSV,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/126427.html