本文目錄一覽:
- 1、如何把這樣的json串轉換成對象
- 2、oracle clob xml json
- 3、java中json字元串怎麼轉json對象
- 4、如何把一個json文件轉換成字元串
- 5、Oracle資料庫中怎麼處理json字元串,本人小
如何把這樣的json串轉換成對象
1.簡單的解析json字元串
首先將json字元串轉換為json對象,然後再解析json對象,過程如下。
JSONObject jsonObject = JSONObject.fromObject(jsonStr);
[java] view plain copy
pre/prespan style=”white-space:pre”/span
pre/pre
根據json中的鍵得到它的值
String name = jsonObject.getString(“name”);
int num = jsonObject.getInt(“num”);
String sex = jsonObject.getString(“sex”);
int age = jsonObject.getInt(“age”);
2.將json字元串轉換為java對象
同樣先將json字元串轉換為json對象,再將json對象轉換為java對象,如下所示。
JSONObject obj = new JSONObject().fromObject(jsonStr);//將json字元串轉換為json對象
將json對象轉換為java對象
Person jb = (Person)JSONObject.toBean(obj,Person.class);//將建json對象轉換為Person對象
3.將java對象轉換為json字元串
先將java對象轉換為json對象,在將json對象轉換為json字元串
JSONObject json = JSONObject.fromObject(obj);//將java對象轉換為json對象
String str = json.toString();//將json對象轉換為字元串
完整代碼如下:
[java] view plain copy
package baz.parse;
import java.util.ArrayList;
import java.util.List;
import net.sf.json.JSON;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import net.sf.json.JSONSerializer;
import baz.bean.Person;
public class ParseJson {
private String jsonStr;
public ParseJson() {
}
public ParseJson(String str){
this.jsonStr = str;
}
/**
* 解析json字元串
*/
public void parse(){
JSONObject jsonObject = JSONObject.fromObject(jsonStr);
String name = jsonObject.getString(“name”);
int num = jsonObject.getInt(“num”);
String sex = jsonObject.getString(“sex”);
int age = jsonObject.getInt(“age”);
System.out.println(name + ” ” + num + ” ” + sex + ” ” + age);
}
//將json字元串轉換為java對象
public Person JSON2Object(){
//接收{}對象,此處接收數組對象會有異常
if(jsonStr.indexOf(“[“) != -1){
jsonStr = jsonStr.replace(“[“, “”);
}
if(jsonStr.indexOf(“]”) != -1){
jsonStr = jsonStr.replace(“]”, “”);
}
JSONObject obj = new JSONObject().fromObject(jsonStr);//將json字元串轉換為json對象
Person jb = (Person)JSONObject.toBean(obj,Person.class);//將建json對象轉換為Person對象
return jb;//返回一個Person對象
}
}
[java] view plain copy
package baz.bean;
public class Person {
private String name;
private int num;
private String sex;
private int age;
public Person() {
// TODO Auto-generated constructor stub
}
public Person(String name, int num, String sex, int age) {
super();
this.name = name;
this.num = num;
this.sex = sex;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getNum() {
return num;
}
public void setNum(int num) {
this.num = num;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
將java對象轉換為json字元串
[java] view plain copy
package baz.cons;
import net.sf.json.JSONObject;
/**
* 將java對象轉換為json字元串
* @author Administrator
*
*/
public class ConsJson {
public ConsJson() {
// TODO Auto-generated constructor stub
}
public String Object2Json(Object obj){
JSONObject json = JSONObject.fromObject(obj);//將java對象轉換為json對象
String str = json.toString();//將json對象轉換為字元串
return str;
}
}
測試類:
[java] view plain copy
package baz.test;
import java.util.List;
import baz.bean.Person;
import baz.cons.ConsJson;
import baz.parse.ParseJson;
public class Test {
public static void main(String[] args) {
//將字元串轉換為json對象,然後根據建得到相應的值
ParseJson pj = new ParseJson(“{\”name\”:\”gu\”,\”num\”:123456,\”sex\”:\”male\”,\”age\”:24}”);
pj.parse();
//將一個json字元串轉換為java對象
Person p = pj.JSON2Object();
System.out.println(“Name:” + p.getName());
System.out.println(“Num:” + p.getNum());
System.out.println(“Sex:” + p.getSex());
System.out.println(“age:” + p.getAge());
//將一個java對象轉換為Json字元串
Person p1 = new Person(“gu1″,123,”male”,23);
ConsJson cj = new ConsJson();
String str1 = cj.Object2Json(p1);
System.out.println(str1);
}
}
測試輸出如下:
gu 123456 male 24
Name:gu
Num:123456
Sex:male
age:24
{“age”:23,”name”:”gu1″,”num”:123,”sex”:”male”}
oracle clob xml json
Oracle 12.1.0.2版本有一個新功能就是可以存儲、查詢、索引JSON數據格式,而且也實現了使用SQL語句來解析JSON,非常方便。JSON數據在資料庫中以VARCHAR2, CLOB或者BLOB進行存儲。Oracle建議用戶在插入JSON數據之前,使用is_json來驗證輸入JSON數據的正確性。另外,Oracle也提供了相關的函數:
Functions:json_value, json_query, json_table.
Conditions:json_exists, is json, is not json, json_textcontains.
java中json字元串怎麼轉json對象
給你個思路:
1、將jsonstr轉為json對象 (這個可以用net.sf.json.JSONObject第三方包來實現)
2、根據refObj 這個key獲取{‘existType’:’exist’,’deptType’:’emp’,’treeNodeType’:’dept’},把獲取的這數據再轉為json.
3、將轉後的json根據existType就能取得值了 。
如何把一個json文件轉換成字元串
1、說明:
json文件本身就是字元串文件,使用open函數就可以得到文件字元串內容,如果要解析文件則使用python3通過json模塊load函數來實現。
2、代碼示例:
首先編寫一個json文件j.txt,內容如下:
{“errno”:1,”errmsg”:”操作成功!”,”data”:[]}
python代碼如下:
import json
# 讀取文件內容
whth open(‘j.txt’, ‘r’) as fr:
print(fr.read())
輸出如下:
{“errno”:1,”errmsg”:”操作成功!”,”data”:[]}
# 解析json文件
with open(‘j.txt’, ‘r’) as fr:
o = json.load(fr)
print(o[‘errno’])
print(o[‘errmsg’])
print(len(o[‘data’]))
輸出如下:
1
操作成功!
3、函數說明:
load(fp, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)
反序列化fp(一個.read()包含 – 支持類文件對象一個JSON文件),以一個Python對象。
object_hook是將與被調用的可選功能任何對象文本解碼(一個“dict“)的結果。返回值object_hook將用來代替dict。此功能可用於實現自定義解碼器(例如JSON-RPC級提示)。
object_pairs_hook是將與被調用的可選功能任何對象的結果與對的有序列表字面解碼。該的返回值object_pairs_hook將用來代替dict。
此功能可用於實現依賴於定製解碼器命令該鍵和值對被解碼(例如,collections.OrderedDict會記得插入的順序)。如果object_hook也定義了object_pairs_hook優先。
要使用自定義JSONDecoder子類,與cls指定它kwarg;否則JSONDecoder使用。
4、其它說明:
也可以使用json.loads函數來直接處理字元串,方法如下:
o=json.loads(‘{“errno”:0,”errmsg”:”操作成功!”,”data”:[]}’)
Oracle資料庫中怎麼處理json字元串,本人小
Oracle 12.1.0.2版本有一個新功能就是可以存儲、查詢、索引JSON數據格式,而且也實現了使用SQL語句來解析JSON,非常方便。JSON數據在資料庫中以VARCHAR2, CLOB或者BLOB進行存儲。Oracle建議用戶在插入JSON數據之前,使用is_json來驗證輸入JSON數據的正確性。另外,Oracle也提供了相關的函數:
Functions:json_value, json_query, json_table.
Conditions:json_exists, is json, is not json, json_textcontains.
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/245606.html