我正在解析维基百科 API 数据,但不知道如何处理每个新搜索请求的序列化名称的更改。它始终是“pages”数组的第一项 (1156934)。我正在使用 Q204873 wiki 数据代码发出请求来获取页面标题,例如“碳酸铵”。但在请求之前我不知道维基百科 pageID (1156934)。
我的 gson 模型有明显的问题(1156934 适合这里,但当我在新的搜索查询期间使用不同的 wikidata Q 代码发出请求时,它会发生变化):
public class WikiPageList {
@SerializedName("WikiPage") //PROBLEM
private WikiPage wikiPage;
public void setWikiPage(WikiPage wikiPage){
this.wikiPage = wikiPage;
}
public WikiPage getWikiPage(){
return wikiPage;
}
@Override
public String toString(){
return
"WikiPageList{" +
"WikiPage = '" + wikiPage + '\'' +
"}";
}
}
如何仅反序列化页面数组的第一项?我还可以提供多个 Q 代码来接收多个标题,但如何为每个数组项使用相同的 gson 模型?
最佳答案
当你不知道json中的数据键值时,可以使用HashMap
像下面这样使用
@SerializedName(“页面”) 公共(public) HashMap 页面
您还可以使用自定义解串器来使其工作
https://futurestud.io/tutorials/gson-advanced-custom-deserialization-basics
关于android - 将动态序列化名称与 gson 匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51689484/