2017-08-15 49 views
1

我試圖從REST API解析JSON,並且當該數據的關鍵字是大寫格式時無法訪問數據。無法解析包含Groovy中的大寫鍵的JSON

{ 
    "body": { 
     "devices": [{ 
      "_id": "xxxxxxxxxx", 
      "cipher_id": "xxxxxxxx", 
      "last_status_store": 1502808369, 
      "modules": [{ 
       "_id": "xxxxxxx", 
       "type": "xxxxxxx", 
       "last_message": 1502808365, 
       "last_seen": 1502808359, 
       "dashboard_data": { 
        "time_utc": 1502808359, 
        "Temperature": 18.9, 
        "temp_trend": "down", 
        "Humidity": 27, 
        "date_max_temp": 1502804720, 
        "date_min_temp": 1502808359, 
        "min_temp": 18.9, 
        "max_temp": 22.2 
       }, 
       "data_type": [ 
        "Temperature", 
        "Humidity" 
       ], 
       "last_setup": 1502731328, 
       "battery_vp": 6354, 
       "battery_percent": 100, 
       "rf_status": 67, 
       "firmware": 44 
      }], 
      "place": { 
       "altitude": 63.395306309052, 
       "city": "xxxxxx", 
       "country": "US", 
       "timezone": "America/New_York", 
       "location": [-72.532673, 
        42.0425917 
       ] 
      }, 
      "station_name": "xxxxxxxxxxx", 
      "type": "NAMain", 
      "dashboard_data": { 
       "AbsolutePressure": 1004.6, 
       "time_utc": 1502808354, 
       "Noise": 50, 
       "Temperature": 22.7, 
       "temp_trend": "up", 
       "Humidity": 69, 
       "Pressure": 1012.1, 
       "pressure_trend": "stable", 
       "CO2": 0, 
       "date_max_temp": 1502808290, 
       "date_min_temp": 1502801263, 
       "min_temp": 21.3, 
       "max_temp": 22.7 
      }, 
      "data_type": [ 
       "Temperature", 
       "CO2", 
       "Humidity", 
       "Noise", 
       "Pressure" 
      ], 
      "co2_calibrating": false, 
      "date_setup": 1502731277, 
      "last_setup": 1502731277, 
      "module_name": "Indoor", 
      "firmware": 132, 
      "last_upgrade": 1502731279, 
      "wifi_status": 51 
     }] 
    }, 
    "status": "ok", 
    "time_exec": 0.019752025604248, 
    "time_server": 1502808443 
} 

我想使用Groovy Json slurper訪問JSON並執行以下命令。響應在我的調試器中恢復正常.Reponse.content是我發送到服務器的HTTPrequest的值。

def stationInfo = jsonSlurper.parseText(response.content as String) 
def outsideTemp = stationInfo.body.devices.modules.dashboard_data.Temperture  
def outsideHumidty = stationInfo.body.devices.modules.dashboard_data.Humidty  
def insideTemp = stationInfo.body.devices.dashboard_data.Temperture 

outsideTemp,outsideHumidty和insideTemp都eqaull爲 「[空]」 當我在調試器中查看。任何想法爲什麼發生這種情況,以及如何解決它?編譯器是否會假設是因爲它們是大寫的?

+0

相同難道我們假設在dashboard_data其他元件被正確地回來了? (如果是的話,你可以在你的問題中明確說明) –

+2

可能問題在於'devices'是一個數組,應該由'[index]'訪問,而你對待的是普通對象 –

+1

同上' 「模塊」# –

回答

1

你幾乎看起來那裏。

請注意,您附加的JSON似乎不是有效的,修復以便能夠工作。

def pJson = new groovy.json.JsonSlurper().parseText(response.content as String) 
println pJson.body.devices.modules.dashboard_data.Temperature.flatten() 
println pJson.body.devices.dashboard_data.Temperature.flatten() 

Temparature類似,你可以得到它Humidity正常工作。

你可以看到在demo

+0

謝謝你一噸。我也拼錯溫度和溼度,這沒有幫助。 – Maz