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

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

May 09, 2023 pm 03:43 PM
python json pickle

json モジュール

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

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

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

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

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

1

2

3

dic =' {‘string1':'hello'}' #写文件只能写入字符串 - 手动把字典变成字符串

f = open(‘hello', ‘w')

f.write(dic)

ログイン後にコピー

1

2

3

4

f_read = open(‘hello', ‘r')

data = f_read.read() #从文件中读出的都是字符串

data = eval(data) #提取出字符串中的字典

print(data[‘name'])

ログイン後にコピー

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

1

2

3

4

5

6

dic = {‘string1':'hello'}

data = json.dumps(dic)

print(data)

print(type(data)) #dumps()会把我们的变量变成一个json字符串

f = open(“new_hello”, “w”)

f.write(data)

ログイン後にコピー

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

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

1

2

3

4

# {‘string1':'hello'} ---> “{“string1”:”hello”}”

# 8 ---> “8”

# ‘hello' ---> ““hello”” – 被json包装后的数据内部只能有双引号

#[1, 2] ---> “[1, 2]”

ログイン後にコピー

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

1

2

3

4

f_read = open(“new_hello”, “r”)

data = json.loads(f_read.read()) #这个data直接就是字典类型

print(data)

print(type(data))

ログイン後にコピー

json モジュールのメソッド

1

2

json.dumps() # 把数据包装成json字符串 – 序列化

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

ログイン後にコピー

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

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

1

2

3

4

json.dump(data, f) #转换成json字符串并写入文件

#相当于 data = json.dumps(dic) + f.write(data)

data = json.load(f) #先读取文件,再提取出数据

#相当于data = json.loads(f_read.read())

ログイン後にコピー

例:

1

2

3

4

5

6

7

8

9

#----------------------------序列化

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()

ログイン後にコピー

1

2

3

4

#-----------------------------反序列化<br>

import json

f=open(&#39;序列化对象&#39;)

data=json.loads(f.read())#  等价于data=json.load(f)

ログイン後にコピー

注:

1

2

3

4

5

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 を使用できるのは重要でないデータの保存のみであり、正常に逆シリアル化できなくても問題ありません。

1

2

3

4

5

6

7

8

9

##----------------------------序列化

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()

ログイン後にコピー

1

2

3

4

5

#-------------------------反序列化

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 サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHPおよびPython:コードの例と比較 PHPおよびPython:コードの例と比較 Apr 15, 2025 am 12:07 AM

PHPとPythonには独自の利点と短所があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1.PHPは、大規模なWebアプリケーションの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンスと機械学習の分野を支配しています。

CentosでPytorchモデルを訓練する方法 CentosでPytorchモデルを訓練する方法 Apr 14, 2025 pm 03:03 PM

CentOSシステムでのPytorchモデルの効率的なトレーニングには手順が必要であり、この記事では詳細なガイドが提供されます。 1。環境の準備:Pythonおよび依存関係のインストール:Centosシステムは通常Pythonをプリインストールしますが、バージョンは古い場合があります。 YumまたはDNFを使用してPython 3をインストールし、PIP:sudoyumupdatepython3(またはsudodnfupdatepython3)、pip3install-upgradepipをアップグレードすることをお勧めします。 cuda and cudnn(GPU加速):nvidiagpuを使用する場合は、cudatoolをインストールする必要があります

CentosのPytorchのGPUサポートはどのようにサポートされていますか CentosのPytorchのGPUサポートはどのようにサポートされていますか Apr 14, 2025 pm 06:48 PM

Pytorch GPUアクセラレーションを有効にすることで、CentOSシステムでは、PytorchのCUDA、CUDNN、およびGPUバージョンのインストールが必要です。次の手順では、プロセスをガイドします。CUDAおよびCUDNNのインストールでは、CUDAバージョンの互換性が決定されます。NVIDIA-SMIコマンドを使用して、NVIDIAグラフィックスカードでサポートされているCUDAバージョンを表示します。たとえば、MX450グラフィックカードはCUDA11.1以上をサポートする場合があります。 cudatoolkitのダウンロードとインストール:nvidiacudatoolkitの公式Webサイトにアクセスし、グラフィックカードでサポートされている最高のCUDAバージョンに従って、対応するバージョンをダウンロードしてインストールします。 cudnnライブラリをインストールする:

Dockerの原則の詳細な説明 Dockerの原則の詳細な説明 Apr 14, 2025 pm 11:57 PM

DockerはLinuxカーネル機能を使用して、効率的で孤立したアプリケーションランニング環境を提供します。その作業原則は次のとおりです。1。ミラーは、アプリケーションを実行するために必要なすべてを含む読み取り専用テンプレートとして使用されます。 2。ユニオンファイルシステム(UnionFS)は、違いを保存するだけで、スペースを節約し、高速化する複数のファイルシステムをスタックします。 3.デーモンはミラーとコンテナを管理し、クライアントはそれらをインタラクションに使用します。 4。名前空間とcgroupsは、コンテナの分離とリソースの制限を実装します。 5.複数のネットワークモードは、コンテナの相互接続をサポートします。これらのコア概念を理解することによってのみ、Dockerをよりよく利用できます。

Python vs. JavaScript:コミュニティ、ライブラリ、リソース Python vs. JavaScript:コミュニティ、ライブラリ、リソース Apr 15, 2025 am 12:16 AM

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

Centosの下でPytorchバージョンを選択する方法 Centosの下でPytorchバージョンを選択する方法 Apr 14, 2025 pm 02:51 PM

CentOSでPytorchバージョンを選択する場合、次の重要な要素を考慮する必要があります。1。CUDAバージョンの互換性GPUサポート:NVIDIA GPUを使用してGPU加速度を活用したい場合は、対応するCUDAバージョンをサポートするPytorchを選択する必要があります。 NVIDIA-SMIコマンドを実行することでサポートされているCUDAバージョンを表示できます。 CPUバージョン:GPUをお持ちでない場合、またはGPUを使用したくない場合は、PytorchのCPUバージョンを選択できます。 2。PythonバージョンPytorch

ミニオペンCentosの互換性 ミニオペンCentosの互換性 Apr 14, 2025 pm 05:45 PM

MINIOオブジェクトストレージ:CENTOSシステムの下での高性能展開Minioは、Amazons3と互換性のあるGO言語に基づいて開発された高性能の分散オブジェクトストレージシステムです。 Java、Python、JavaScript、Goなど、さまざまなクライアント言語をサポートしています。この記事では、CentosシステムへのMinioのインストールと互換性を簡単に紹介します。 Centosバージョンの互換性Minioは、Centos7.9を含むがこれらに限定されない複数のCentosバージョンで検証されています。

NginxをCentosにインストールする方法 NginxをCentosにインストールする方法 Apr 14, 2025 pm 08:06 PM

NGINXのインストールをインストールするには、次の手順に従う必要があります。開発ツール、PCRE-Devel、OpenSSL-Develなどの依存関係のインストール。 nginxソースコードパッケージをダウンロードし、それを解凍してコンパイルしてインストールし、/usr/local/nginxとしてインストールパスを指定します。 nginxユーザーとユーザーグループを作成し、アクセス許可を設定します。構成ファイルnginx.confを変更し、リスニングポートとドメイン名/IPアドレスを構成します。 nginxサービスを開始します。依存関係の問題、ポート競合、構成ファイルエラーなど、一般的なエラーに注意する必要があります。パフォーマンスの最適化は、キャッシュをオンにしたり、ワーカープロセスの数を調整するなど、特定の状況に応じて調整する必要があります。

See all articles