ホームページ >バックエンド開発 >Python チュートリアル >Pythonのjsonモジュールとpickleモジュールの使い方

Pythonのjsonモジュールとpickleモジュールの使い方

王林
王林転載
2023-05-09 15:43:14870ブラウズ

json モジュール

json は、C と Python 間など、言語間での異なる言語間でのデータ交換に使用されます。 Pickle は Python と Python 間のデータ交換にのみ使用できます。

シリアル化と逆シリアル化

オブジェクト (変数) をメモリから保存可能または転送可能に変更するプロセスはシリアル化と呼ばれ、Python では pickling と呼ばれ、他の言語では pickling と呼ばれます。シリアル化、マーシャリング、フラット化などと呼ばれ、すべて同じ意味です。シリアル化後、シリアル化されたコンテンツをディスクに書き込んだり、ネットワーク経由で他のマシンに送信したりできます。次に、変数の内容をシリアル化されたオブジェクトからメモリに再読み取ることを、逆シリアル化、つまりアンピックリングと呼びます。

異なるプログラミング言語間でオブジェクトを転送したい場合は、オブジェクトを XML などの標準形式にシリアル化する必要がありますが、JSON は文字列として表現されるため、より良い方法は JSON にシリアル化することです。すべての言語で読むことができ、簡単にディスクに保存したり、ネットワーク経由で送信したりできます。 JSON は標準形式であり、XML よりも高速であるだけでなく、Web ページで直接読み取ることもできるため、非常に便利です。

JSON で表されるオブジェクトは、標準の JavaScript 言語オブジェクトです。JSON と Python の間で対応するデータ型は次のとおりです。ファイル Data-Dictionary

dic =' {‘string1':'hello'}' #写文件只能写入字符串 - 手动把字典变成字符串
f = open(‘hello', ‘w')
f.write(dic)
f_read = open(‘hello', ‘r')
data = f_read.read() #从文件中读出的都是字符串
data = eval(data) #提取出字符串中的字典
print(data[‘name'])

json は上記の関数を実装します - json は任意の言語でデータを送信できますPythonのjsonモジュールとpickleモジュールの使い方

dic = {‘string1':'hello'}
data = json.dumps(dic)
print(data)
print(type(data)) #dumps()会把我们的变量变成一个json字符串
f = open(“new_hello”, “w”)
f.write(data)

json 文字列と手動で追加した文字列 ’’ には違いがあります。これは json 文字列仕様に従います。つまり、文字列は二重引用符で囲まれます。

ダンプは、渡したデータ型を二重引用符で囲まれた文字列に変換します。

# {‘string1':'hello'} ---> “{“string1”:”hello”}”
# 8 ---> “8”
# ‘hello' ---> ““hello”” – 被json包装后的数据内部只能有双引号
#[1, 2] ---> “[1, 2]”

保存または送信するときに、データを json 文字列に変換します。これにより、一般的な言語を実現できます

f_read = open(“new_hello”, “r”)
data = json.loads(f_read.read()) #这个data直接就是字典类型
print(data)
print(type(data))

json モジュールのメソッド

json.dumps() # 把数据包装成json字符串 – 序列化
json.loads() # 从json字符串中提取出原来的数据 – 反序列化

C で json 解析を使用する場合、リスト l = [1, 2, 3] を Python の json 文字列にラップし、保存または送信します。 C 言語の対応するデータ構造を取得します。抽出されたデータは配列 buf[3] = {1, 2, 3} です。

これは、ダンプとロードを一緒に使用しなければならないという意味ではありません。json 文字列が json 仕様に準拠している限り、データ構造の処理と抽出にロードを使用できます。ダンプが有効であるかどうかは関係ありません。使用されているかどうか。

json.dump(data, f) #转换成json字符串并写入文件
#相当于 data = json.dumps(dic) + f.write(data)
data = json.load(f) #先读取文件,再提取出数据
#相当于data = json.loads(f_read.read())

例:

#----------------------------序列化
import json
dic={'name':'alvin','age':23,'sex':'male'}
print(type(dic))#<class &#39;dict&#39;>
j=json.dumps(dic)
print(type(j))#<class &#39;str&#39;>
f=open(&#39;序列化对象&#39;,&#39;w&#39;)
f.write(j)  #-------------------等价于json.dump(dic,f)
f.close()
#-----------------------------反序列化<br>
import json
f=open(&#39;序列化对象&#39;)
data=json.loads(f.read())#  等价于data=json.load(f)

注:

import json
#dct="{&#39;1&#39;:111}"#json 不认单引号
#dct=str({"1":111})#报错,因为生成的数据还是单引号:{&#39;one&#39;: 1}
dct=&#39;{"1":"111"}&#39;
print(json.loads(dct))

データの作成方法に関係なく、データが json 形式を満たしている限り、json.loads 形式で出力することができます。必ずしもダンプである必要はなく、データをロードできます。

pickle モジュール

Pickle の問題は、他のすべてのプログラミング言語に特有のシリアル化の問題と同じです。つまり、Python でのみ使用でき、バージョンが異なる可能性があります。 Python の 2 つは相互に互換性がないため、Pickle を使用できるのは重要でないデータの保存のみであり、正常に逆シリアル化できなくても問題ありません。

##----------------------------序列化
import pickle
dic={&#39;name&#39;:&#39;alvin&#39;,&#39;age&#39;:23,&#39;sex&#39;:&#39;male&#39;}
print(type(dic))#<class &#39;dict&#39;>
j=pickle.dumps(dic)
print(type(j))#<class &#39;bytes&#39;>
f=open(&#39;序列化对象_pickle&#39;,&#39;wb&#39;)#注意是w是写入str,wb是写入bytes,j是&#39;bytes&#39;
f.write(j)  #-------------------等价于pickle.dump(dic,f)
f.close()
#-------------------------反序列化
import pickle
f=open(&#39;序列化对象_pickle&#39;,&#39;rb&#39;)
data=pickle.loads(f.read())#  等价于data=pickle.load(f)
print(data[&#39;age&#39;])

pickle と json の使い方は同じで、学名は両方ともシリアライゼーションと呼ばれますが、json のシリアル化の結果は文字列であり、pickle のシリアル化の結果はバイトです。つまり、形式は異なりますが、内容は同じですが、pickle でシリアル化されるのはバイト、つまりファイルに書き込まれるデータはバイトなので、open がファイルを開くときは、 wb バイナリの形式で開くことができます。 pickle でファイルに書き込まれた内容は読めません(文字が乱れていますが、コンピュータは認識できます)が、json で書き込まれたデータは読み取れます。 pickle はより多くのデータ型をサポートし、pickle は関数とクラスをシリアル化できます。 json はこれら 2 つのシリアル化をサポートしていませんが、json は依然としてほとんどのシナリオで使用されます。

以上がPythonのjsonモジュールとpickleモジュールの使い方の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。