>백엔드 개발 >파이썬 튜토리얼 >Python 데이터 영구 저장: 피클 모듈의 기본 사용

Python 데이터 영구 저장: 피클 모듈의 기본 사용

高洛峰
高洛峰원래의
2016-12-16 11:38:131558검색

Python의 피클 모듈은 기본 데이터 시퀀스와 역직렬화를 구현합니다. 피클 모듈의 직렬화 연산을 통해 프로그램에서 실행 중인 객체 정보를 파일로 저장할 수 있으며, 피클 모듈의 역직렬화 연산을 통해 파일에서 마지막 프로그램이 저장한 객체를 생성할 수 있다.

기본 인터페이스:

pickle.dump(obj, file, [,protocol])
참고: 객체 obj를 파일 file에 저장합니다.
프로토콜은 직렬화에 사용되는 프로토콜 버전입니다. 0: ASCII 프로토콜, 직렬화된 개체는 인쇄 가능한 ASCII 코드로 표시됩니다. 1: 이전 바이너리 프로토콜 2: 버전 2.3에 도입된 새로운 바이너리 프로토콜. 더 효율적입니다. 그 중 프로토콜 0과 1은 이전 버전의 Python과 호환됩니다. 프로토콜의 기본값은 0입니다.
파일: 객체가 저장되는 파일류 객체입니다. File에는 write() 인터페이스가 있어야 합니다. File은 'w' 모드로 열린 파일이거나 StringIO 객체 또는 write() 인터페이스를 구현하는 다른 객체일 수 있습니다. 프로토콜>=1이면 파일 개체를 바이너리 모드로 열어야 합니다.

pickle.load(file)
참고: 파일에서 문자열을 읽고 이를 원래 Python 객체로 재구성합니다.
파일: read() 및 readline() 인터페이스가 있는 파일과 유사한 객체입니다.

 간단한 코드

#使用pickle模块将数据对象保存到文件

import pickle

data1 = {'a': [1, 2.0, 3, 4+6j],
         'b': ('string', u'Unicode string'),
         'c': None}

selfref_list = [1, 2, 3]
selfref_list.append(selfref_list)

output = open('data.pkl', 'wb')

# Pickle dictionary using protocol 0.
pickle.dump(data1, output)

# Pickle the list using the highest protocol available.
pickle.dump(selfref_list, output, -1)

output.close()
#使用pickle模块从文件中重构python对象

import pprint, pickle

pkl_file = open('data.pkl', 'rb')

data1 = pickle.load(pkl_file)
pprint.pprint(data1)

data2 = pickle.load(pkl_file)
pprint.pprint(data2)

pkl_file.close()


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