2013-08-16 16 views
5

Python 2.6.6 と私がやっていることは、zmqとjson.loads(メッセージ)からメッセージを受け取ります。すべての混乱JSONのため申し訳ありません それは私がJSONを以下しており、Pythonで、私は私がデータを抽出できるように、それをロードしようとしています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"}}}} 

あるとして。

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が、私はまだ、このエラーを取得していますことを渡すようだ:

{ 
    "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" 
        } 
       } 
      } 
} 

そのは私に次のエラーをスロー? は、文字列からすべての新しい行とタブを削除しました。 ここには何かがありませんか?

+1

エラーを繰り返すことはできません –

+8

もうJSONを再フォーマットしないでください。誰もがそれを再フォーマットすれば、文字905がどこにあるのか分かりにくいです... –

+2

Pythonコードも投稿できますか?私のことはあなたに間違いを与えません。 – AliBZ

答えて

1

私はC++クライアントから取得していたjson文字列の末尾にヌル文字があったので、ヌル文字が削除され、すべて正常に機能します。

関連する問題