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()