파 이 썬 의 서열 화 와 반 서열 화 를 분석 하 다.
실현 대상 의 서열 화 와 반 서열 화 는 python 에서 두 가지 방식 이 있 는데 그것 이 바로 json 과 pickle 이다.
그 중에서 json 은 문자열 과 python 데이터 형식 간 의 변환 에 사 용 됩 니 다.pickle 은 python 특유 의 형식 과 python 의 데이터 형식 간 의 변환 에 사 용 됩 니 다.pickle 은 python 특유 의 것 입 니 다.
1.JSON 직렬 화:json.dumps()
info = {
"name":"tj",
"age":22
}
import json
print(info)
print(type(info))
print(json.dumps(info))
print(type(json.dumps(info)))
f = open("test.txt","w")
# f.write(info) # TypeError: write() argument must be str, not dict
f.write(json.dumps(info)) # f.write(json.dumps(info)) json.dump(info, f)
f.close()
>>>
{'name': 'tj', 'age': 22}
<class 'dict'>
{"name": "tj", "age": 22}
<class 'str'>2.JSON 역 직렬 화:json.loads()
f = open("test.txt","r")
# print(f.read()["age"]) #TypeError: string indices must be integers
data = json.loads(f.read()) # data = json.loads(f.read()) data = json.load(f)
print(data["age"])
f.close()
>>>
22주의:다음 과 같은 상황 에 대해 제 이 슨 은 처리 할 수 없습니다.
import json
def hello(name):
print("hello,",name)
info = {
"name":"tj",
"age":22,
"func":hello
}
f = open("test2.txt","w")
f.write(json.dumps(info)) #TypeError: Object of type function is not JSON serializable
f.close()그래서:json 은 문자열 과 python 데이터 형식 간 의 변환 에 사 용 됩 니 다.3.pickle 직렬 화:pickle.dumps()
import pickle
def hello(name):
print("hello,",name)
info = {
"name":"tj",
"age":22,
"func":hello
}
print(pickle.dumps(info)) # pickle , wb
f = open("test2.txt","wb")
f.write(pickle.dumps(info)) # pickle.dump(info,f)
f.close()
>>>
b'\x80\x04\x957\x00\x00\x00\x00\x00\x00\x00}\x94(\x8c\x04name\x94\x8c\x04alex\x94\x8c\x03age\x94K\x16\x8c\x04func\x94\x8c\x08__main__\x94\x8c\x05hello\x94\x93\x94u.'함수 hello 에 대해 직렬 화 된 것 은 메모리 주소 가 아니 라 전체 데이터 대상 이 며 함 수 는 직렬 화 할 수 있 습 니 다.4.pickle 역 직렬 화:pickle.loads()
f = open("test2.txt","rb")
data = pickle.loads(f.read()) # data = pickle.load(f)
print(data)
print(data["name"])
print(data["func"])
>>>
{'name': 'tj', 'age': 22, 'func': <function hello at 0x00000179EF69C040>}
tj
<function hello at 0x00000179EF69C040>5.여러 차례 의 직렬 화 와 반 직렬 화1)json
import json
info = {
"name":"tj",
"age":22
}
f = open("test3.txt","w")
f.write(json.dumps(info))
info['age'] = 21
f.write(json.dumps(info))
f.close()
#
>>>
test3
test3.txt: {"name": "tj", "age": 22}{"name": "tj", "age": 21}
f = open("test3.txt","r")
# ,py3 , dumps ,py2 dumps ,
data = json.loads(f.read()) # json.decoder.JSONDecodeError
f.close()
print(data)2)pickle
import pickle
info = {
"name":"tj",
"age":22
}
f = open("test2.txt","wb")
f.write(pickle.dumps(info)) # pickle.dump(info,f)
info["sex"] = " "
f.write(pickle.dumps(info)) # pickle.dump(info,f)
f.close()
>>>
test2.txt
test2.txt: �� }�(�nametjageKu.��% }�(�nametjageK�sex u.
f = open("test2.txt","rb")
data = pickle.loads(f.read()) #
# data = pickle.loads(f.read()) # :EOFError: Ran out of input
print(data)
print(data["age"])
# print(data["sex"]) # KeyError: 'sex'왕 씨:여러 번 서열 화 할 수 없 지 않 습 니까?그럼 제 가 수정 한 데 이 터 를 파일 에 직렬 화 해서 써 야 하 는데 어 떡 하 죠?너:당연히 여러 번 서열 화 할 수 있 지.서열 화 된 데 이 터 를 여러 파일 에 쓰 면 되 잖 아.
이상 은 Python 의 직렬 화 와 반 직렬 화 에 대한 상세 한 내용 을 분석 하 는 것 입 니 다.Python 의 직렬 화 와 반 직렬 화 에 관 한 자 료 는 우리 의 다른 관련 글 을 주목 하 십시오!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Python의 None과 NULL의 차이점 상세 정보그래서 대상 = 속성 + 방법 (사실 방법도 하나의 속성, 데이터 속성과 구별되는 호출 가능한 속성 같은 속성과 방법을 가진 대상을 클래스, 즉 Classl로 분류할 수 있다.클래스는 하나의 청사진과 같아서 하나의 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.