>백엔드 개발 >파이썬 튜토리얼 >Pickle을 사용하여 Python에서 객체를 저장하는 방법

Pickle을 사용하여 Python에서 객체를 저장하는 방법

藏色散人
藏色散人원래의
2019-01-18 09:29:473269검색

Pickle은 기본적으로 Python 라이브러리의 일부이며 사용자 세션 간의 지속성이 필요할 때마다 중요한 모듈입니다. 모듈로서 pickle은 프로세스 간에 Python 객체를 저장하는 기능을 제공합니다.

Pickle을 사용하여 Python에서 객체를 저장하는 방법

세션 간에 정보를 저장해야 하는 데이터베이스, 게임, 포럼 또는 기타 애플리케이션을 프로그래밍하는 경우 피클은 식별자와 설정을 저장하는 데 도움이 됩니다. 피클 모듈은 부울 값, 문자열 및 바이트 배열, 목록, 사전, 함수 등과 같은 데이터 유형을 저장할 수 있습니다.

참고: 피클의 개념은 직렬화, 마샬링 및 평면화라고도 합니다. 그러나 키는 항상 동일합니다. 나중에 검색할 수 있도록 객체를 파일에 저장하세요. pickle은 객체를 긴 바이트 스트림에 작성하여 이를 달성합니다.

Python의 Pickle 샘플 코드

객체를 파일에 쓰려면 다음 구문의 코드를 사용하세요.

import pickle 
object = Object() 
filehandler = open(filename, 'w') 
pickle.dump(object, filehandler)

다음은 실제 예입니다.

import pickle 
import math 
object_pi = math.pi 
file_pi = open('filename_pi.obj', 'w') 
pickle.dump(object_pi, file_pi)

이 코드 조각은 object_pi의 내용을 파일 핸들러에 씁니다. file_pi, 파일 핸들러 file_pi는 실행 디렉터리의 filename_pi.obj 파일에 바인딩됩니다.

객체의 값을 메모리에 복원하려면 파일에서 객체를 로드하세요. 사용하기 위해 피클을 가져오지 않았다고 가정하고 먼저 가져옵니다.

import pickle 
filehandler = open(filename, 'r') 
object = pickle.load(filehandler)

다음 코드는 pi 값을 복원합니다.

import pickle 
file_pi2 = open('filename_pi.obj', 'r') 
object_pi2 = pickle.load(file_pi2)

그런 다음 객체를 다시 사용할 준비가 됩니다. 이번에는 object_pi2입니다. 물론 원한다면 원래 이름을 다시 사용할 수도 있습니다. 이 예에서는 명확성을 위해 다른 이름을 사용합니다.

Pickle에 관한 사항

pickle 모듈을 사용할 때 다음 사항에 유의하세요.

pickle 프로토콜은 Python에만 적용됩니다. 언어 간 호환성이 보장되지는 않습니다. Perl, PHP, Java 또는 기타 언어에서 유용하게 사용할 수 있도록 정보를 전송할 수 없을 가능성이 높습니다.

다른 Python 버전 간 호환성은 보장되지 않습니다. 모든 Python 데이터 구조가 모듈에 의해 직렬화될 수 있는 것은 아니기 때문에 비호환성이 존재합니다.

기본적으로 최신 버전의 피클 프로토콜이 사용됩니다. 수동으로 변경하지 않는 한 그대로 유지됩니다.

위 내용은 Pickle을 사용하여 Python에서 객체를 저장하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.