> 백엔드 개발 > 파이썬 튜토리얼 > 직렬화 및 역직렬화에 대한 자세한 소개

직렬화 및 역직렬화에 대한 자세한 소개

零下一度
풀어 주다: 2017-07-19 16:45:20
원래의
1905명이 탐색했습니다.

1. 직렬화와 역직렬화의 개념

 객체를 바이트 시퀀스로 변환하는 과정을 객체의 직렬화라고 합니다.
 바이트 시퀀스를 객체로 복원하는 프로세스를 객체 역직렬화라고 합니다.
 객체 직렬화에는 두 가지 주요 용도가 있습니다.
 1) 객체의 바이트 시퀀스를 일반적으로 파일로 하드 디스크에 영구적으로 저장합니다.
 2) 네트워크에서 객체의 바이트 시퀀스를 전송합니다.

 많은 응용 프로그램에서 특정 개체는 메모리 공간을 떠나 물리적 하드 디스크에 저장하여 장기간 보관할 수 있도록 직렬화해야 합니다. 예를 들어, 가장 일반적인 것은 웹 서버의 세션 개체입니다. 100,000명의 사용자가 동시에 액세스하면 100,000개의 세션 개체가 있을 수 있으며 이는 메모리에 너무 많을 수 있으므로 웹 컨테이너는 일부 세션을 하드에 직렬화합니다. disk를 먼저 사용하는 식으로 사용하고 싶을 때에는 하드디스크에 저장된 객체를 메모리에 복원합니다.

두 프로세스가 원격으로 통신할 때 서로 다양한 유형의 데이터를 보낼 수 있습니다. 어떤 유형의 데이터이든 바이너리 시퀀스 형태로 네트워크를 통해 전송됩니다. 송신자는 이 Java 객체를 네트워크를 통해 전송하기 전에 바이트 시퀀스로 변환해야 합니다. 수신자는 바이트 시퀀스를 Java 객체로 복원해야 합니다. json을 직렬화하는 과정은 이를 파일에 쓰고 다른 프로그래밍 언어가 이를 호출하도록 하는 것입니다: ":

"sb",

"test":"hard"}

 with

open("file", "w") as f:

  f.write(json.dumps(info))




위 코드는 json을 사용하여 info 사전 정보를 파일에 씁니다. 파일은 문자열 형식의 정보나 바이너리 파일 정보만 저장할 수 있으며, 숫자나 기타 정보는 저장할 수 없습니다. 파일에 입력되는 정보는 모두 문자열 형식이므로 주의해야 합니다.
json 역직렬화 프로세스:
import json
''
 with
open(
"file",

"r")

as f:   data = json.loads (f.read())    

print(data)

  print(type( data))

   

print(data["alex"])




 

위 코드는 아래와 같이 json 형식으로 저장된 정보를 읽습니다.

 {'test': 'hard', 'alex': 'sb'}
 
 sb
 위 코드는 문자열 정보를 사전으로 읽어오는 기능을 구현한 것입니다. 역직렬화는 먼저 원본 형식을 문자열로 변환한 다음 상호작용이 가능하도록 읽어들이는 프로세스입니다.

직렬화 및 역직렬화를 위해 다른 방법을 사용할 수도 있습니다. 다음과 같이 문자열 정보를 원래 스타일로 변환할 수 있는 eval() 함수가 있다는 것을 알고 있습니다.

info = [11 ,22 ,33,65,33]

 with open("test.text","w") as f:
  f.write(str(info)) #사용 wirte( ) 파일에는 문자열 형식의 정보만 쓸 수 있으며, 다른 유형의 정보는 쓸 수 없습니다

 with open("test.text","r") as f_obj:
  data = f_Obj.read ( )

data = eval(데이터)
Print(Type(데이터)) Print(데이터)
프로그램은 다음과 같이 진행됩니다:
함수는 직렬화와 역직렬화 과정도 구현하는데 직렬화와 역직렬화를 같은 프로그램에서 구현하기 때문에 다른 프로그램에도 eval()이 있는지는 확실하지 않지만 json은 모든 프로그래밍 언어를 지원하므로 이제 json은 일반적으로 서로 다른 프로그래밍 언어 간의 정보 상호 작용을 실현하는 데 사용됩니다.

덤프 및 로드도 위의 덤프 및 로드 기능을 구현하지만 구현 방법이 다르며 다음과 같이 구문도 약간 다릅니다.

덤프 직렬화:



import json

info = {"alex":"sb",

"test":

"hard"}

 with

open("file","w")
as f:
  json.dump(info , f)


  Load() 역직렬화:

 import json

 '' 역직렬화의 시작은 dump에서 정보를 추출하여 다양한 프로그래밍 언어의 상호 작용을 실현하는 것입니다''

 with open("file ", "r") as f:
                data = json.load(f)
                                                                               's 's ' s ' 사용 's 's 's 통해 's   사용 통해 's 사용   사용 통해 ‐ ‐ ‐‐‐‐ ‐ to 위 프로그램은 직렬화 및 역직렬화, 덤프(정보, 파일 경로), 로드(파일 경로), 정보 가져오기에서 어떤 파일을 읽을지 등의 기능을 구현합니다.

  서로 다른 프로그램 간의 데이터 교환을 실현합니다.   서로 다른 프로그램 간의 데이터 교환 또는 문자열 정보를 원래 형식으로 변환
 
eval()
함수도 매우 강력하며 다음과 같이 문자열 정보를 원본 정보로 변환할 수 있습니다. 다음:
 >>> dic = "{'alex':'sb','try':'workhard'}"
  >>> data = eval(dic)
 >> ;> data
 {'try': 'workhard', 'alex': 'sb'}

  프로그램은 한 번만 덤프하고, 한 번 로드하며, 여러 번 덤프할 수 없습니다. 덤프는 여러 파일로 구현됩니다.

위 내용은 직렬화 및 역직렬화에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿