Я пытаюсь десериализовать строку JSON в JObject с помощью Newtosoft.Json под Raspbian с моно. Но он не может десериализовать Float.Newtonsoft.JSON Mono Float Deserialize Exception
Dim myStationJSON As String
myStationJSON = myWC.DownloadString("https://api.netatmo.com/api/getstationsdata?access_token=" & myToken.Token.access_token)
Dim myJSON As Newtonsoft.Json.Linq.JObject
Dim myStationName As String = ""
Dim opts As New Newtonsoft.Json.JsonSerializerSettings
opts.FloatParseHandling = Newtonsoft.Json.FloatParseHandling.Double
myJSON = Newtonsoft.Json.JsonConvert.DeserializeObject(myStationJSON, opts)
Я получаю это исключение:
Newtonsoft.Json.JsonReaderException: Входная строка '-0.2' не является допустимым числом. Path 'body.devices [0] .modules [0] .dashboard_data.Temperature', строка 1, позиция 329. в Newtonsoft.Json.JsonTextReader.ParseNumber (ReadType readType) [0x00000] в: 0 на Newtonsoft.Json. JsonTextReader.ParseValue() [0x00000] в: 0 в Newtonsoft.Json.JsonTextReader.Read() [0x00000] в: 0 в Newtonsoft.Json.JsonWriter.WriteToken (считыватель Newtonsoft.Json.JsonReader, булева writeChildren, булевой writeDateConstructorAsDate , Boolean writeComments) [0x00000] in: 0 at Newtonsoft.Json.Linq.JTokenWriter.WriteToken (Newtonsoft.Json.JsonReader reader, Boolean writeChildren, Boolean writeDateConstructorAsDate, логические writeComments) [0x00000] в: 0 на Newtonsoft.Json. Сериализация. JsonSerializerInternalReader.CreateJObject (Newtonsoft.Json.JsonReader reader) [0x00000] в: 0 в Newtonsoft.Json.Serialization.JsonSerializerInternalReader.CreateObject (Newtonsoft.Json.JsonReader reader, System.Type objectType, Newtonsoft.Json.Serialization.JsonContract contract, Newtonsoft.Json.Serialization.JsonProperty member, Newtonsoft.Json.Serialization.JsonContainerContract containerContract , Newtonsoft.Json.Serialization.JsonProperty containerMember, System.Object existingValue) [0x00000] в: 0 в Newtonsoft.Json.Serialization.JsonSerializerInternalReader.CreateValueInternal (Newtonsoft.Json.JsonReader reader, System.Type objectType, Newtonsoft.Json.Serialization .JsonContract contract, Newtonsoft.Json.Serialization.JsonProperty member, Newtonsoft.Json.Serialization.JsonContainerContract containerContract, Newtonsoft.Json.Serialization.JsonProperty containerMember, System.Object existingValue) [0x00000] в: 0 на Newtonsoft.Json.Serialization. JsonSerializerInternalReader.Deserialize (Newtonsoft.Json.Js onReader читателя, System.Type OBJECTTYPE, Boolean checkAdditionalContent) [0x00000] в: 0
JSON:
{
"body": {
"devices": [
{
"_id": "XXX",
"cipher_id": "enc:16:XXX",
"last_status_store": 1483489982,
"modules": [
{
"_id": "XXX",
"type": "NAModule1",
"last_message": 1483489978,
"last_seen": 1483489933,
"dashboard_data": {
"time_utc": 1483489933,
"Temperature": -0.2,
"temp_trend": "stable",
"Humidity": 89,
"date_max_temp": 1483489933,
"date_min_temp": 1483484498,
"min_temp": -0.4,
"max_temp": -0.2
},
"data_type": [
"Temperature",
"Humidity"
],
"module_name": "Außen",
"last_setup": 1384606905,
"battery_vp": 5870,
"battery_percent": 95,
"rf_status": 81,
"firmware": 43
},
{
"_id": "XXXX",
"type": "NAModule4",
"last_message": 1483489978,
"last_seen": 1483489933,
"dashboard_data": {
"time_utc": 1483489933,
"Temperature": 21.7,
"temp_trend": "stable",
"Humidity": 38,
"CO2": 1139,
"date_max_temp": 1483489933,
"date_min_temp": 1483485422,
"min_temp": 21.5,
"max_temp": 21.7
},
"data_type": [
"Temperature",
"CO2",
"Humidity"
],
"module_name": "Schlafzimmer",
"last_setup": 1414704430,
"battery_vp": 4876,
"battery_percent": 38,
"rf_status": 79,
"firmware": 43
}
],
"place": {
"altitude": 210,
"city": "XXX",
"country": "DE",
"timezone": "Europe/XXX",
"location": [
3.12345675665,
12.12345667899
]
},
"station_name": "XXX",
"type": "NAMain",
"dashboard_data": {
"AbsolutePressure": 993.7,
"time_utc": 1483489969,
"Noise": 51,
"Temperature": 21.8,
"temp_trend": "stable",
"Humidity": 44,
"Pressure": 1021.2,
"pressure_trend": "down",
"CO2": 1069,
"date_max_temp": 1483484530,
"date_min_temp": 1483485740,
"min_temp": 21.6,
"max_temp": 21.8
},
"data_type": [
"Temperature",
"CO2",
"Humidity",
"Noise",
"Pressure"
],
"co2_calibrating": false,
"date_setup": 1384607020,
"last_setup": 1384607020,
"module_name": "Wohnzimmer",
"firmware": 102,
"last_upgrade": 1440006125,
"wifi_status": 62,
"friend_users": [
"XXXX"
]
}
],
"user": {
"mail": "[email protected]",
"administrative": {
"country": "DE",
"reg_locale": "de-DE",
"lang": "de-DE",
"unit": 0,
"windunit": 0,
"pressureunit": 0,
"feel_like_algo": 0
}
}
},
"status": "ok",
"time_exec": 0.050105810165405,
"time_server": 1483490016
}
В Windows он работает просто отлично.
Можете ли вы [изменить] ваш вопрос включить JSON в вопрос, чтобы у нас был полный [mcve]? – dbc
Просто добавил JSON. – TimeO84