溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java怎么獲取JSON中某個(gè)對(duì)象的值

發(fā)布時(shí)間:2022-06-16 10:36:14 來(lái)源:億速云 閱讀:1618 作者:iii 欄目:開發(fā)技術(shù)

這篇“Java怎么獲取JSON中某個(gè)對(duì)象的值”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“Java怎么獲取JSON中某個(gè)對(duì)象的值”文章吧。

Java獲取JSON中某個(gè)對(duì)象的值

public class ChangeJson {
    public static String getString(String data, String result)  {
        JSONObject jsonObject = null;
        try {
            jsonObject = new JSONObject(data);
        } catch (JSONException e) {
            e.printStackTrace();
        }
        return jsonObject.optString(result, null);
    }
}

使用方式

現(xiàn)在String result中有如下的JSON串,要取得deptCode

{
  "status": 0,
  "data": {
    "deptId": 76,
    "deptCode": "101030000",
    "deptName": "成都工務(wù)段",
    "dirDeptCode": "100000000",
    "deptLevel": 2,
    "defaultRoleId": 1,
    "createAt": "2021-02-25 02:18:51",
    "updateAt": "2021-03-03 09:09:35",
    "defaultRoleName": "系統(tǒng)超級(jí)管理員"
  }
}
//獲取data
String data = ChangeJson.getString(result, "data");
//獲取deptCode
String deptCode= ChangeJson.getString(data , "deptCode");

Java正則表達(dá)式-獲取json某個(gè)屬性值

處理數(shù)據(jù)的時(shí)候,要匹配json數(shù)據(jù)格式的字符串某個(gè)屬性的值

json數(shù)據(jù)格式: {"flow_name":"paramName"}

要獲取到 flow_name屬性的值: paramName

要怎么處理呢?

語(yǔ)法

  • [abc]:表示字母abc中的任意一個(gè)

  • \w:除了([0-9a-zA-Z_])還包含了希臘字母,俄文的字母等;

  • \d:匹配數(shù)字

數(shù)量控制符

  • ? 表示1個(gè)或0個(gè)。換句話說,表示要不然沒有,要不然只有1個(gè)

  • + 表示1個(gè)或多個(gè)

匹配

處理思路:

{"flow_name":"paramName"}

正則表達(dá)式怎么寫? 匹配的是字符(數(shù)字,大小寫和下劃線的組合)

flow_name 是已知的,要匹配 ":"paramName" 這部分的內(nèi)容。

String patternStr = keyField+"\":\"([0-9a-zA-Z_]+)?\"";

代碼

public static void main(String[] args) {
    String info = "[{\"SYNC_930000003690\":{\"finalSYSTEMNAME\":\"PXY-CPCP配置中心\",\"P_REQUEST_ID\":\"585471439551123454\",\"finalSYSTEMTYPE\":\"BSS-PXY\",\"finalDeveloperName\":\"\",\"finaltaxtCost\":\"\",\"finalworkRemark\":\"\",\"formId\":930000003690,\"REQUEST_ID\":\"A585545039142506496\",\"finalSuplIptDays\":\"22\"}},{\"SYNC_930000003690\":{\"finalSYSTEMNAME\":\"PXY-CPCP配置中心\",\"P_REQUEST_ID\":\"585471439551123455\",\"finalSYSTEMTYPE\":\"BSS-PXY\",\"finalDeveloperName\":\"\",\"finaltaxtCost\":\"\",\"finalworkRemark\":\"\",\"formId\":930000003694,\"REQUEST_ID\":\"B585545039142506496\",\"finalSuplIptDays\":\"44\"}},{\"SYNC_930000003690\":{\"finalSYSTEMNAME\":\"PXY-CPCP配置中心\",\"P_REQUEST_ID\":\"585471439551123456\",\"finalSYSTEMTYPE\":\"BSS-PXY\",\"finalDeveloperName\":\"\",\"finaltaxtCost\":\"\",\"formId\":930000003692,\"finalworkRemark\":\"\",\"REQUEST_ID\":\"C585545039142506496\",\"finalSuplIptDays\":\"55\"}}]";
    String keyField = "P_REQUEST_ID";
    System.out.println("=====    match    "+ keyField + " =========");
    //  \w : 數(shù)字,字母 ,下劃線 0-9 a-z A-Z _
    String patternStr = keyField+"\":\"([0-9a-zA-Z_]+)?\"";
    matchJsonValue(info,patternStr);
 
    keyField = "formId";
    System.out.println("=====    match    "+ keyField + " =========");
    patternStr = keyField+"\":(\\d+)?";
    matchJsonValue(info,patternStr);
}
 
/**
 * 正則表達(dá)式 查找匹配json字符串對(duì)應(yīng)屬性的值
 * @param sourcStr 字符串
 * @param patternStr 正則表達(dá)式
 * @return 字符集
 */
public static List<String> matchJsonValue(String sourcStr, String patternStr) {
    List<String> aimList = new ArrayList<>();
    Pattern pattern = Pattern.compile(patternStr);
    Matcher matcher = pattern.matcher(sourcStr);
    while (matcher.find()) {
        System.out.println("group all: " + matcher.group(0));
        System.out.println("aim index: " + matcher.group(NumberUtils.INTEGER_ONE));
        aimList.add(matcher.group(NumberUtils.INTEGER_ONE));
    }
    return aimList;
}

結(jié)果:

=====    match    P_REQUEST_ID =========
group all: P_REQUEST_ID":"585471439551123454"
aim index: 585471439551123454
group all: P_REQUEST_ID":"585471439551123455"
aim index: 585471439551123455
group all: P_REQUEST_ID":"585471439551123456"
aim index: 585471439551123456
=====    match    formId =========
group all: formId":930000003690
aim index: 930000003690
group all: formId":930000003694
aim index: 930000003694
group all: formId":930000003692
aim index: 930000003692

以上就是關(guān)于“Java怎么獲取JSON中某個(gè)對(duì)象的值”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI