我正在使用IntelliJ和Gooks Books API,并且在使用json simple时使用Java进行编码。我正在编写一个程序,用户可以在终端中键入书名,API返回5本书和每本书的信息。该API返回有关书籍的大量信息,但我只希望它返回书籍标题,作者和出版商。我是使用APis和JSON的新手,所以我不知道我的错误是否可能来自语法或逻辑错误。
例如,我输入“哈利波特”,这是API返回的一部分
{
"kind": "books#volumes",
"totalItems": 1832,
"items": [
{
"kind": "books#volume",
"id": "cvRFvgAACAAJ",
"etag": "mfbVxWEkveo",
"selfLink": "https://www.googleapis.com/books/v1/volumes/cvRFvgAACAAJ",
"volumeInfo": {
"title": "Harry Potter and the Cursed Child",
"subtitle": "Parts one and two",
"authors": [
"Jack Thorne",
"J. K. Rowling",
"John Tiffany"
],
"publisher": "THORNDIKE Press",
"publishedDate": "2016",
"description": "\"Thorndike Press large print the literacy bridge.\"",
"industryIdentifiers": [
{
"type": "ISBN_10",
"identifier": "1410496201"
},
{
"type": "ISBN_13",
"identifier": "9781410496201"
}
],
"readingModes": {
"text": false,
"image": false
},
"pageCount": 407,
"printType": "BOOK",
"categories": [
"Good and evil"
],
我已经读到,检索特定信息的一种方法是创建一个JSONArray并使来自API的信息成为JSONObjects。我能够成功解析数据,因此每个JSONObject都是一本书及其全部信息,但是我不知道如何仅打印出我想要的特定信息。
这是我的一些代码。从TODO开始的代码是我遇到麻烦的地方
String inline = ""; //gets the JSON data and makes it a String
Scanner sc = new Scanner(url.openStream()); //reads JSON data
while (sc.hasNext())
{
inline += sc.nextLine();
}
sc.close();
JSONParser parse = new JSONParser();
JSONObject jObj = (JSONObject)parse.parse(inline);
JSONArray theJArray = (JSONArray)jObj.get("items");
for (int i = 0; i < theJArray.size(); i++)
{
JSONObject secondJObj = (JSONObject)theJArray.get(i);
System.out.println("The secondJobj: " + secondJObj); //one object is one book and its info
JSONArray specificArr = (JSONArray)secondJObj.get("author"); //TODO
System.out.println("The specificArr is: " + specificArr); //returns null
System.out.println("The specific section: " + secondJObj.get("author")); //returns null
}
据我了解,所有内容都在“ items”数组下,因此“ authors”数组是另一个数组内的一个数组。如何访问“作者”数组中的信息?
我还需要这本书的书名和出版商,我知道这些不是数组,因此与从“作者”数组中调用信息不同。如何仅从键“ title”和“ publisher”的值中检索“ items”数组中的信息?
答案 0 :(得分:0)
在上面的代码中我可以看到您的努力,但是author
在volumeInfo
JsonObject内部
"volumeInfo": {
"title": "Harry Potter and the Cursed Child",
"subtitle": "Parts one and two",
"authors": [
"Jack Thorne",
"J. K. Rowling",
"John Tiffany"
],
因此,在for循环中,首先需要将volumeInfo
设为JSONObject
,然后将author
设为JSONArray
for (int i = 0; i < theJArray.size(); i++)
{
JSONObject secondJObj = (JSONObject)theJArray.get(i);
System.out.println("The secondJobj: " + secondJObj); //one object is one book and its info
JSONObject volInfo = (JSONObject)secondJObj.get("volumeInfo"); //TODO
// then get author
JSONArray specificArr = (JSONArray)volInfo.get("author");
}