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 중국어 웹사이트의 기타 관련 기사를 참조하세요!