Python JSON

Note: JSON はデータを保存して交換するための構文です。

JSON は JavaScript オブジェクト表記で書かれたテキストです。

Python における JSON

Python には JSON データを扱うための組み込みパッケージ json があります。

json モジュールをインポートします:

import json

JSON 文字列がある場合、json.loads() メソッドを使用して解析できます。結果は Python の辞書になります。

import json

# いくつかの JSON:
x =  '{ "name":"John", "age":30, "city":"New York"}'

# 解析する:
y = json.loads(x)

# 結果は Python の辞書です:
print(y["age"])

結果:

30

Python オブジェクトがある場合、json.dumps() メソッドを使用して JSON 文字列に変換できます。

import json

# Python オブジェクト(辞書):
x = {
  "name": "John",
  "age": 30,
  "city": "New York"
}

# JSON に変換:
y = json.dumps(x)

# 結果は JSON 文字列です:
print(y)

結果:

{"name": "John", "age": 30, "city": "New York"}

以下の Python オブジェクトを JSON 文字列に変換できます:

  • 辞書
  • リスト
  • タプル
  • 文字列
  • 整数
  • 浮動小数点数
  • True
  • False
  • None

import json

print(json.dumps({"name": "John", "age": 30}))
print(json.dumps(["apple", "bananas"]))
print(json.dumps(("apple", "bananas")))
print(json.dumps("hello"))
print(json.dumps(42))
print(json.dumps(31.76))
print(json.dumps(True))
print(json.dumps(False))
print(json.dumps(None))

Python から JSON に変換する際、Python オブジェクトは JSON(JavaScript)の対応するデータ型に変換されます:

Python JSON
辞書 Object
リスト Array
タプル Array
文字列 String
整数 Number
浮動小数点数 Number
True true
False false
None null

すべての法的なデータ型を含む Python オブジェクトを JSON 文字列に変換します:

import json

x = {
  "name": "John",
  "age": 30,
  "married": True,
  "divorced": False,
  "children": ("Ann","Billy"),
  "pets": None,
  "cars": [
    {"model": "BMW 230", "mpg": 27.5},
    {"model": "Ford Edge", "mpg": 24.1}
  ]
}

print(json.dumps(x))

結果のフォーマットを整える

上記の例は JSON 文字列を出力しますが、インデントや改行がなく、読みやすくありません。

json.dumps() メソッドには、結果をより読みやすくするためのパラメータがあります:

インデントパラメータを使用してインデント数を定義します:

json.dumps(x, indent=4)

セパレータを定義することもできます。デフォルト値は (“, “, “: “) で、それぞれのオブジェクトを区切るためにコンマとスペースを、キーと値を区切るためにコロンとスペースを使用します:

json.dumps(x, indent=4, separators=(". ", " = "))

結果のキーの順序を整理するための sort_keys パラメータもあります:

json.dumps(x, indent=4, sort_keys=True)