Pickle을 사용한 다중 객체 직렬화 및 역직렬화
Python에서 pickle 모듈은 객체를 직렬화 및 역직렬화하는 편리한 방법을 제공합니다. 여러 개체를 처리하시나요?
피클 파일에 여러 개체를 저장하려면 목록이나 튜플을 사용하여 집계할 수 있습니다. 예를 들어:
<code class="python">my_objects = [obj1, obj2, obj3] with open('objects.pkl', 'wb') as f: pickle.dump(my_objects, f)</code>
객체를 로드하려면 다음과 같이 하면 됩니다.
<code class="python">with open('objects.pkl', 'rb') as f: my_objects = pickle.load(f)</code>
피클 모듈은 피클되는 항목 수 저장을 지원하므로 개별적으로 로드할 수 있습니다. 그러나 더 큰 데이터 세트의 경우 모든 것을 메모리에 로드하는 것이 최적이 아닐 수 있습니다.
대안은 생성기를 사용하여 한 번에 하나씩 객체를 로드하는 것입니다.
<code class="python">def loadall(filename): with open(filename, "rb") as f: try: while True: yield pickle.load(f) except EOFError: pass</code>
이 방법으로만 필요할 때 다음 객체가 로드되어 메모리가 절약됩니다.
위 내용은 Python에서 Pickle을 사용하여 여러 개체를 직렬화 및 역직렬화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!