json.dumps()メソッド:
このメソッドは、辞書オブジェクトを解析または読み取り用のJSONデータに変換するために使用され、 ごみ() 方法。
構文:
json。ダンプ((物体、インデント=なし、sort_keys=NS)。
このメソッドには多くのオプションの引数があります。この記事では、1つの必須引数と2つのオプション引数の使用法を示します。ここで、最初の引数は任意の辞書オブジェクトを取得するために使用される必須の引数であり、2番目の引数はインデントの単位数を定義するために使用され、3番目の引数はキーをソートするために使用されます。
json.dump()メソッド:
このメソッドは、PythonオブジェクトをJSONファイルに保存するために使用されます。それはより速いです dumps() メモリとファイルに別々に書き込むため、メソッド。
構文:
json。ごみ((辞書、fileHandler、インデント=なし)。このメソッドには、次のような多くの引数があります。 dumps() 。この記事では、3つの引数を使用して、ディクショナリオブジェクトのデータをJSONデータに変換し、そのデータをJSONファイルに格納します。ここで、最初の引数はJSONオブジェクトに変換する必要のあるディクショナリオブジェクトを取得するために使用され、2番目の引数はJSONデータが書き込まれるファイルのファイルハンドラーの名前を取得するために使用されます。 3番目の引数は、インデント単位を設定するために使用されます。
これらの2つのメソッドを使用して、辞書オブジェクトをJSONファイルまたはJSON文字列に変換する方法をこの記事の以下に示します。
例-1:を使用して辞書をJSONに変換する dumps() インデント付き
dumps()メソッドには必須パラメーターが1つあり、辞書オブジェクトを使用してデータをJSON文字列に変換できることは前述しました。次のスクリプトでは、 dict_data 特定の学生レコードのデータを含む辞書変数です。初めに、 dumps() メソッドは1つの引数との値で使用されます dict_data JSONデータに変換されます。 JSONデータでインデントが使用されていない場合、辞書とJSON形式の両方の出力は同じです。次、 dumps() メソッドは2つの引数で使用され、3はJSONデータのインデント値として使用されます。 2番目のJSON出力はインデント付きで生成されます。
#!/ usr / bin / env python3#jsonモジュールをインポートする
輸入json
#辞書を定義する
dict_data= {{ '学生証':'011894'、 '名前':「マシュー」、 'バッチ':30、 '学期':6 }
#辞書データを印刷する
印刷(('辞書出力:NS'、dict_data、 'NS')。
#インデントなしで辞書をjsonオブジェクトに変換する
json_data=json。ダンプ((dict_data)。
#jsonデータを出力する
印刷(('インデントなしのJSON出力:NS'、json_data、 'NS')。
#インデント付きのjsonオブジェクトに辞書を変換する
json_data=json。ダンプ((dict_data、インデント=3)。
#インデント付きのjsonデータを出力
印刷(('インデント付きのJSON出力:NS'、json_data)。
出力:
スクリプトの実行後、次の出力が表示されます。
例-2:sort_keysでdumps()を使用して辞書をJSONに変換する
JSONデータのキーは、を使用して並べ替えることができます sort_keys dumps()の引数。この引数のデフォルト値はFalseです。次のスクリプトでは、辞書オブジェクトは使用せずにJSONデータに変換されます sort_keys と使用 sort_keys この引数の使用法を表示します。最初のdumps()メソッドはインデント値5で使用され、出力にはインデント5を使用したJSONデータが表示されます。2番目のdumps()メソッドでは、sort_keysが使用され、キー値の並べ替えにTrueに設定されます。最後のJSON出力には、キー値を並べ替えた後のデータが表示されます。
#!/ usr / bin / env python3#jsonモジュールをインポートする
輸入json
#辞書を定義する
dict_data= {{'名前':「マディソン」、'月':'5月'、'年':2020、「販売」:[1000、 2100、 3500、 1200]}
#辞書データを印刷する
印刷(('辞書出力:NS'、dict_data、 'NS')。
#リストデータを含む辞書をjsonに変換します
json_data=json。ダンプ((dict_data、インデント= 5)。
#jsonデータを出力する
印刷(('インデント付きのJSON出力:NS'、json_data)。
#キーを並べ替えて、リストデータを含む辞書をjsonに変換します
json_data=json。ダンプ((dict_data、インデント= 5、sort_keys= NS)。
#キーに基づいてソートされたjsonデータを出力します
印刷(('インデント付きのソートされたJSON出力:NS'、json_data)。
出力:
スクリプトの実行後、次の出力が表示されます。最初のJSON出力は、ディクショナリで定義されているキー値を示し、2番目のJSON出力は、ソートされた順序でキー値を示します。
例-3:辞書をJSONデータに変換し、JSONファイルに保存する
辞書から変換した後にJSONデータをファイルに保存する場合は、次を使用する必要があります dump() 方法。この例では、辞書オブジェクトをJSONデータに変換し、データをJSONファイルに保存する方法を示します。ここでは、 ごみ() メソッドは3つの引数を使用します。最初の引数は、前に定義されたディクショナリオブジェクトを取ります。 2番目の引数は、JSONファイルを作成する前に定義されたファイルハンドラー変数を取ります。 3番目の引数は、インデント値を定義します。新しく書き込まれたJSONの内容は、後で出力として出力されます。
#!/ usr / bin / env python3#jsonモジュールをインポートする
輸入json
#辞書を定義する
dict_data= {{ 「c-101」:「PHPプログラミング」、 「c-102」:「Bashプログラミング」、 「c-103」:
「Pythonプログラミング」、
「c-104」:'オブジェクト指向プログラミング' }
#辞書データを印刷する
印刷(('辞書出力:NS'、dict_data、 'NS')。
#jsonファイル名を設定します
jsonFile= 'course_list.json'
#jsonデータを書き込むためのjsonファイルを開く
と 開いた((jsonFile、 'の')。 なのでfileHandler1:
json。ごみ((dict_data、fileHandler1、インデント= 2)。
#読み取り用にjsonファイルを開く
fileHandler2= 開いた((jsonFile)。
印刷(('JSONファイルの内容:NS'、fileHandler2。読んだ(()。)。
出力:
スクリプトの実行後、次の出力が表示されます。
結論:
さまざまなプログラミングタスクを簡単にするために、辞書データをJSONデータに変換する必要があります。 JSONを使用すると、あるスクリプトから別のスクリプトにデータを簡単に転送できるため、このデータ変換は重要です。このチュートリアルが、Pythonユーザーが辞書データをJSONデータに変換し、スクリプトに適切に適用する方法を理解するのに役立つことを願っています。