gpt4 book ai didi

Java-使用jakson将json转换为复杂对象

转载 作者:行者123 更新时间:2023-11-30 02:15:07 25 4
gpt4 key购买 nike

这可能会重复问题,但我已经搜索了很多解决方案,但没有运气。我有一个如下所示的类(class):

public class RestartMapState {

public RestartMapState(List<MapStepData> vMapStepData, List<AbstractMap.SimpleEntry<String,String>> vResolvedParameters, String vJobID){
this.vJobID=vJobID;
this.vResolvedParameters = vResolvedParameters;
this.vMapStepData = vMapStepData;
}

public RestartMapState(){}

private List<MapStepData> vMapStepData;
public void setvMapStepData(List<MapStepData> mapStepData){ this.vMapStepData = mapStepData; }
public List<MapStepData> getvMapStepData(){
return this.vMapStepData;
}

private List<AbstractMap.SimpleEntry<String,String>> vResolvedParameters;
public List<AbstractMap.SimpleEntry<String,String>> getvResolvedParameters(){ return this.vResolvedParameters; }
public void setvResolvedParameters(List<AbstractMap.SimpleEntry<String,String>> resolvedParameters){ this.vResolvedParameters = resolvedParameters; }

private String vJobID;
public String getvJobID(){ return this.vJobID; }
public void setvJobID(String jobID){ this.vJobID = jobID; }
}

当我尝试使用以下代码将其转换为 json 时,我得到了 json 文件。

RestartMapState vRestartMapState = new RestartMapState(vRemainingStepsToBeExecuted, vMapResolvedParameters, vMapExCtx.getvJobID());
try {
vObjectMapper.writerWithDefaultPrettyPrinter().writeValue(stateFile, vRestartMapState);
} catch (JsonGenerationException e) {
isSerialized = false;
e.printStackTrace();
} catch (JsonMappingException e) {
isSerialized = false;
e.printStackTrace();
} catch (IOException e) {
isSerialized = false;
e.printStackTrace();
}

我的 JSON 文件如下所示:

{
"vMapStepData" : [ {
"dependsOn" : null,
"orderIndex" : 0,
"name" : "Step1",
"mapStepId" : 167119,
"sqlstatements" : {
"sqlstatement" : [ {
"value" : "-- Map Step (Step1)\nCREATE TABLE ##!sessionid##Step1\n AS\nSELECT currency_nbr AS currency_nbr,...",
"orderIndex" : 1,
"isQuery" : false,
"flags" : [ "PartOfCore" ]
} ]
}
}, {
"dependsOn" : null,
"orderIndex" : 1,
"name" : "Step2",
"mapStepId" : 237822,
"sqlstatements" : {
"sqlstatement" : [ {
"value" : "\n\n-- Map Step (Step2)\nCREATE TABLE ##!sessionid##Step2\n AS\nSELECT country_cd AS ....",
"orderIndex" : 1,
"isQuery" : false,
"flags" : [ "PartOfCore" ]
} ]
}
} ],
"vResolvedParameters" : [ {
"key" : "##RUNDATE##",
"value" : "2018045"
}, {
"key" : "##julian##",
"value" : "2018033"
} ],
"vJobID" : "10012"
}

但是当我尝试将相同的 json 文件反序列化为 RestartMapState 类型的对象时,我收到以下错误。

org.codehaus.jackson.map.JsonMappingException: No suitable constructor found for type [simple type, class java.util.AbstractMap$SimpleEntry<java.lang.String,java.lang.String>]: can not instantiate from JSON object (need to add/enable type information?)
at [Source: C:\Users\vkukk1\.MAP_STATE_System_Test_Group_Vasu_Test_2_10012.json; line: 30, column: 5] (through reference chain: com.aexp.idn.magellan.RestartMapState["vResolvedParameters"]) RestartMapState vRestartMapState = null;

有人可以帮我解决这个问题吗?我做错了什么?

最佳答案

AbstractMap.SimpleEntry没有默认构造函数(无参数)并且无法反序列化。
您应该更改 vResolvedParameters 的通用类型来自AbstractMap.SimpleEntry<String,String>到其他类型:

private List<Pair<String, String>> vResolvedParameters;
public List<Pair<String, String>> getvResolvedParameters() {
return this.vResolvedParameters;
}
public void setvResolvedParameters(List<Pair<String, String>> resolvedParameters) {
this.vResolvedParameters = resolvedParameters;
}

哪里Pair是:

private static class Pair<K, V> {
private K key;
private V value;

public K getKey() {
return key;
}
public void setKey(K key) {
this.key = key;
}
public V getValue() {
return value;
}
public void setValue(V value) {
this.value = value;
}
...
}

您可以使用Pair来自许多其他库的实现。

或者如果值为 "key"是独一无二的,您可以更改 vResolvedParameters输入 Map<String,String> 。但你的 JSON 格式将从:

...
"vResolvedParameters" : [ {
"key" : "##RUNDATE##",
"value" : "2018045"
}, {
"key" : "##julian##",
"value" : "2018033"
} ],
...

至:

...
"vResolvedParameters": {
"##RUNDATE##": "2018045",
"##julian##": "2018033"
},
...

Related qestion

关于Java-使用jakson将json转换为复杂对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48801033/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com