2013-08-16 29 views
5

Python 2.6.6 並且我所做的是從zmq和json.loads(message)接收消息。 對不起,所有的混亂的JSON,因爲它是Json.loads引發ValueError

{"mouhter_id":"one_keert","header":{"header_version":"1","message_type":"one_keert","session_id":"428c0ebd497b9dfcc3170da0d1e0628e","timestamp":1376616699,"src_path":"*/dc/occ1/bell000/lcd_one_mtmt/26866","dst_path":"*/dc/lkjhgvd/lkjhgvd/fegtault/24068"},"payload":{"destHardwareId":"","command":{"id":"bmclmc1","params":{"keylen":"396","key":"AAAAIM0XlJxAEiX6t1KSyuQh+gCnP1Jmu3lkTZvxhiOUogyMAAABDC0tLS0tQkVHSU4gUFVCTElDIEtFWS0tLS0tCk1JR2JNQkFHQnlxR1NNNDlBZ0VHQlN1QkJBQWpBNEdHQUFRQjAxaTZkOG5xVTBnQVBIdHhFMDZqNEI0UDF4TXoKVTVYYy83RnZCVzBtTFI3WlQxRTRxUmw3VEx0OVcwSi85OU5XRzF3NU14Um1oK2dubEJxTTFkNytadU1BNU1NdgpFbmNHcmFpNU1UcHo3elE0cm9CQWZFOVA0czFvM0dRaThSRlVSbFJMdWl2Ym1jempkcVdCYVlEUjNCUU9IOU96ClRWOHFhUnpCN3l0T1NnS09yZzA9Ci0tLS0tRU5EIFBVQkxJQyBLRVktLS0tLQoAAABAg7od/LedQJ8MEBvKQjcBWM2ObdIeSDd/2VygDn0XFwBgUpYiWgum7FE8O51E0Xv3/R6ibvgSPFblqHqLDBNzOgAAAAAAAAAAAAAAAAAAAAAAAAAA"}}}} 

我有以下JSON和蟒蛇我試圖加載它,這樣我可以提取數據。

{ 
    "e_id": "1231231", 
    "header": { 
       "h_version": "1", 
       "m_type": "abc", 
       "s_id": "ffsfsd", 
       "timestamp": 1376614509, 
       "s_path": "*/dc/s1/De620/cpmgmt/25804", 
       "d_path": "*/dc/sfer/sfer/kelt/23642" 
       }, 
"payload": { 
"dereId": "", 
"cond":  { 
       "id": "srcstg1", 
       "pams": { 
        "keen": "396", 
        "ke":        "AAAAICZJsxIYABq3JXFRJ7ouZtoLDOLIJBnrw03uASQTiK+nAAABDC0tLS0tQkVHSU4gUFVCTElDIEtFWS0tLS0tCk1JR2JNQkFHQnlxR1NNNDlBZ0VHQlN1QkJBQWpBNEdHQUFRQkR2SEZLNVZZdUg3ZUFMRitLeWhLbWl0TEdEMzAKZmJOakNHYkVNRW1Geld4cFgzZXJ0RjhKSjdjMWZ6cFRhekJGRkpDNW5vR3FycWl2M3VGbGNuMitjUUlCUC9LaQo4V0h4ZVNBVkQ3R2lNTXJHMEVGYTBrOWNucnd5MEtWeU93MEVYcmwyQUNJcXg5enZBV3NLeERhUjRlRzRZVi9jCjB2cVlKcEh1OXNMbE9jWDJJVW89Ci0tLS0tRU5EIFBVQkxJQyBLRVktLS0tLQoAAABA+T4YOvY1ynTIlAUn8xI+/0c+2EAPRFF1uHx8jBP7uuNkb/wnRZl0hJWx6NAOd0kHuh2RdIXXMhXChaEWRNxq6wAAAAAAAAAAAAAAAAAAAAAAAAAA" 
        } 
       } 
      } 
} 

它扔我下面的錯誤:

raise ValueError(errmsg("Extra data", s, end, len(s))) 
ValueError: Extra data: line 1 column 904 - line 1 column 905 (char 904 - 905) 

我已經使用jsonlint檢查文件的有效性,似乎傳遞了validation.But我仍然得到這個錯誤? 已從字符串中刪除所有新行和製表符。 什麼東西在這裏不見了?

+1

無法重複錯誤 –

+8

請不要重新格式化JSON了,要知道char 905的位置在每個人只是重新格式化的時候都有點困難...... –

+2

你能發佈你的python代碼嗎?我不會給你你的錯誤。 – AliBZ

回答

1

在json字符串的末尾有一個空字符,我從C++客戶端獲取它,所以剛剛刪除了空字符,現在所有工作都很好。

相關問題