반응형
질문
이 파일에 이 JSON이 있습니다:
{
"maps": [
{
"id": "blabla",
"iscategorical": "0"
},
{
"id": "blabla",
"iscategorical": "0"
}
],
"masks": [
"id": "valore"
],
"om_points": "value",
"parameters": [
"id": "valore"
]
}
모든 JSON 데이터를 출력하기 위해 이 스크립트를 작성했습니다:
import json
from pprint import pprint
with open('data.json') as f:
data = json.load(f)
pprint(data)
하지만 이 프로그램은 예외를 발생시킵니다:
Traceback (most recent call last):
File "<pyshell#1>", line 5, in <module>
data = json.load(f)
File "/usr/lib/python3.5/json/__init__.py", line 319, in loads
return _default_decoder.decode(s)
File "/usr/lib/python3.5/json/decoder.py", line 339, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/usr/lib/python3.5/json/decoder.py", line 355, in raw_decode
obj, end = self.scan_once(s, idx)
json.decoder.JSONDecodeError: Expecting ',' delimiter: line 13 column 13 (char 213)
JSON을 구문 분석하고 그 값을 추출하는 방법은 무엇인가요?
답변
당신의 데이터는 JSON 형식이 아닙니다. "masks"
와 "parameters"
요소에 대해 []
대신 {}
를 사용해야 합니다:
[]
는 JSON 배열을 나타내며 Python에서는list
라고 합니다.{}
는 JSON 객체를 나타내며 Python에서는dict
라고 합니다.
다음은 JSON 파일의 예시입니다:
{
"maps": [
{
"id": "blabla",
"iscategorical": "0"
},
{
"id": "blabla",
"iscategorical": "0"
}
],
"masks": {
"id": "valore"
},
"om_points": "value",
"parameters": {
"id": "valore"
}
}
그러면 다음과 같이 코드를 사용할 수 있습니다:
import json
from pprint import pprint
with open('data.json') as f:
data = json.load(f)
pprint(data)
이제 데이터를 사용하여 다음과 같이 값을 찾을 수도 있습니다:
data["maps"][0]["id"]
data["masks"]["id"]
data["om_points"]
위의 코드를 시도하여 이해할 수 있는지 확인해보세요.
반응형
댓글