| 
									
										
										
										
											1998-08-10 19:42:37 +00:00
										 |  |  | \section{\module{pickle} --- | 
					
						
							|  |  |  |          Python object serialization.} | 
					
						
							| 
									
										
										
										
											1998-07-23 17:59:49 +00:00
										 |  |  | \declaremodule{standard}{pickle} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \modulesynopsis{Convert Python objects to streams of bytes and back.} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | \index{persistency} | 
					
						
							|  |  |  | \indexii{persistent}{objects} | 
					
						
							|  |  |  | \indexii{serializing}{objects} | 
					
						
							|  |  |  | \indexii{marshalling}{objects} | 
					
						
							|  |  |  | \indexii{flattening}{objects} | 
					
						
							|  |  |  | \indexii{pickling}{objects} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | The \module{pickle} module implements a basic but powerful algorithm for | 
					
						
							| 
									
										
										
										
											1995-03-13 10:03:32 +00:00
										 |  |  | ``pickling'' (a.k.a.\ serializing, marshalling or flattening) nearly | 
					
						
							| 
									
										
										
										
											1995-03-28 13:35:14 +00:00
										 |  |  | arbitrary Python objects.  This is the act of converting objects to a | 
					
						
							|  |  |  | stream of bytes (and back: ``unpickling''). | 
					
						
							|  |  |  | This is a more primitive notion than | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | persistency --- although \module{pickle} reads and writes file objects, | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | it does not handle the issue of naming persistent objects, nor the | 
					
						
							|  |  |  | (even more complicated) area of concurrent access to persistent | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | objects.  The \module{pickle} module can transform a complex object into | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | a byte stream and it can transform the byte stream into an object with | 
					
						
							|  |  |  | the same internal structure.  The most obvious thing to do with these | 
					
						
							|  |  |  | byte streams is to write them onto a file, but it is also conceivable | 
					
						
							|  |  |  | to send them across a network or store them in a database.  The module | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \module{shelve} provides a simple interface to pickle and unpickle | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | objects on ``dbm''-style database files. | 
					
						
							| 
									
										
										
										
											1997-12-15 21:56:05 +00:00
										 |  |  | \refstmodindex{shelve} | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \strong{Note:} The \module{pickle} module is rather slow.  A | 
					
						
							|  |  |  | reimplementation of the same algorithm in \C{}, which is up to 1000 times | 
					
						
							|  |  |  | faster, is available as the \module{cPickle}\refbimodindex{cPickle} | 
					
						
							| 
									
										
										
										
											1998-01-09 22:36:51 +00:00
										 |  |  | module.  This has the same interface except that \code{Pickler} and | 
					
						
							|  |  |  | \code{Unpickler} are factory functions, not classes (so they cannot be | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | used as base classes for inheritance). | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | Unlike the built-in module \module{marshal}, \module{pickle} handles | 
					
						
							|  |  |  | the following correctly: | 
					
						
							| 
									
										
										
										
											1997-12-15 21:56:05 +00:00
										 |  |  | \refbimodindex{marshal} | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | \begin{itemize} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | \item recursive objects (objects containing references to themselves) | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | \item object sharing (references to the same object in different places) | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | \item user-defined classes and their instances | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | \end{itemize} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | The data format used by \module{pickle} is Python-specific.  This has | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | the advantage that there are no restrictions imposed by external | 
					
						
							| 
									
										
										
										
											1998-01-09 22:36:51 +00:00
										 |  |  | standards such as XDR%
 | 
					
						
							|  |  |  | \index{XDR} | 
					
						
							|  |  |  | \index{External Data Representation} | 
					
						
							|  |  |  | (which can't represent pointer sharing); however | 
					
						
							|  |  |  | it means that non-Python programs may not be able to reconstruct | 
					
						
							|  |  |  | pickled Python objects. | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | By default, the \module{pickle} data format uses a printable \ASCII{} | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | representation.  This is slightly more voluminous than a binary | 
					
						
							|  |  |  | representation.  The big advantage of using printable \ASCII{} (and of | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | some other characteristics of \module{pickle}'s representation) is that | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | for debugging or recovery purposes it is possible for a human to read | 
					
						
							|  |  |  | the pickled file with a standard text editor. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | A binary format, which is slightly more efficient, can be chosen by | 
					
						
							|  |  |  | specifying a nonzero (true) value for the \var{bin} argument to the | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \class{Pickler} constructor or the \function{dump()} and \function{dumps()} | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | functions.  The binary format is not the default because of backwards | 
					
						
							|  |  |  | compatibility with the Python 1.4 pickle module.  In a future version, | 
					
						
							|  |  |  | the default may change to binary. | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | The \module{pickle} module doesn't handle code objects, which the | 
					
						
							|  |  |  | \module{marshal} module does.  I suppose \module{pickle} could, and maybe | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | it should, but there's probably no great need for it right now (as | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | long as \module{marshal} continues to be used for reading and writing | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | code objects), and at least this avoids the possibility of smuggling | 
					
						
							|  |  |  | Trojan horses into a program. | 
					
						
							| 
									
										
										
										
											1997-12-15 21:56:05 +00:00
										 |  |  | \refbimodindex{marshal} | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | For the benefit of persistency modules written using \module{pickle}, it | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | supports the notion of a reference to an object outside the pickled | 
					
						
							|  |  |  | data stream.  Such objects are referenced by a name, which is an | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | arbitrary string of printable \ASCII{} characters.  The resolution of | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | such names is not defined by the \module{pickle} module --- the | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | persistent object module will have to implement a method | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \method{persistent_load()}.  To write references to persistent objects, | 
					
						
							|  |  |  | the persistent module must define a method \method{persistent_id()} which | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | returns either \code{None} or the persistent ID of the object. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | There are some restrictions on the pickling of class instances. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | First of all, the class must be defined at the top level in a module. | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | Furthermore, all its instance variables must be picklable. | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \setindexsubitem{(pickle protocol)} | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | When a pickled class instance is unpickled, its \method{__init__()} method | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | is normally \emph{not} invoked.  \strong{Note:} This is a deviation | 
					
						
							|  |  |  | from previous versions of this module; the change was introduced in | 
					
						
							|  |  |  | Python 1.5b2.  The reason for the change is that in many cases it is | 
					
						
							|  |  |  | desirable to have a constructor that requires arguments; it is a | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | (minor) nuisance to have to provide a \method{__getinitargs__()} method. | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | If it is desirable that the \method{__init__()} method be called on | 
					
						
							|  |  |  | unpickling, a class can define a method \method{__getinitargs__()}, | 
					
						
							| 
									
										
										
										
											1998-01-09 22:36:51 +00:00
										 |  |  | which should return a \emph{tuple} containing the arguments to be | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | passed to the class constructor (\method{__init__()}).  This method is | 
					
						
							| 
									
										
										
										
											1997-12-30 17:44:48 +00:00
										 |  |  | called at pickle time; the tuple it returns is incorporated in the | 
					
						
							|  |  |  | pickle for the instance. | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \ttindex{__getinitargs__()} | 
					
						
							|  |  |  | \ttindex{__init__()} | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | Classes can further influence how their instances are pickled --- if the class | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | defines the method \method{__getstate__()}, it is called and the return | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | state is pickled as the contents for the instance, and if the class | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | defines the method \method{__setstate__()}, it is called with the | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | unpickled state.  (Note that these methods can also be used to | 
					
						
							|  |  |  | implement copying class instances.)  If there is no | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \method{__getstate__()} method, the instance's \member{__dict__} is | 
					
						
							|  |  |  | pickled.  If there is no \method{__setstate__()} method, the pickled | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | object must be a dictionary and its items are assigned to the new | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | instance's dictionary.  (If a class defines both \method{__getstate__()} | 
					
						
							|  |  |  | and \method{__setstate__()}, the state object needn't be a dictionary | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | --- these methods can do what they want.)  This protocol is also used | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | by the shallow and deep copying operations defined in the \module{copy} | 
					
						
							|  |  |  | module.\refstmodindex{copy} | 
					
						
							|  |  |  | \ttindex{__getstate__()} | 
					
						
							|  |  |  | \ttindex{__setstate__()} | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | \ttindex{__dict__} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Note that when class instances are pickled, their class's code and | 
					
						
							| 
									
										
										
										
											1995-03-13 10:03:32 +00:00
										 |  |  | data are not pickled along with them.  Only the instance data are | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | pickled.  This is done on purpose, so you can fix bugs in a class or | 
					
						
							|  |  |  | add methods and still load objects that were created with an earlier | 
					
						
							|  |  |  | version of the class.  If you plan to have long-lived objects that | 
					
						
							| 
									
										
										
										
											1995-03-13 10:03:32 +00:00
										 |  |  | will see many versions of a class, it may be worthwhile to put a version | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | number in the objects so that suitable conversions can be made by the | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | class's \method{__setstate__()} method. | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | When a class itself is pickled, only its name is pickled --- the class | 
					
						
							|  |  |  | definition is not pickled, but re-imported by the unpickling process. | 
					
						
							|  |  |  | Therefore, the restriction that the class must be defined at the top | 
					
						
							|  |  |  | level in a module applies to pickled classes as well. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \setindexsubitem{(in module pickle)} | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | The interface can be summarized as follows. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | To pickle an object \code{x} onto a file \code{f}, open for writing: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | p = pickle.Pickler(f) | 
					
						
							|  |  |  | p.dump(x) | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | A shorthand for this is: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | pickle.dump(x, f) | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | To unpickle an object \code{x} from a file \code{f}, open for reading: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | u = pickle.Unpickler(f) | 
					
						
							| 
									
										
										
										
											1995-04-10 11:34:00 +00:00
										 |  |  | x = u.load() | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | A shorthand is: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | x = pickle.load(f) | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | The \class{Pickler} class only calls the method \code{f.write()} with a | 
					
						
							|  |  |  | string argument.  The \class{Unpickler} calls the methods \code{f.read()} | 
					
						
							| 
									
										
										
										
											1998-01-09 22:36:51 +00:00
										 |  |  | (with an integer argument) and \code{f.readline()} (without argument), | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | both returning a string.  It is explicitly allowed to pass non-file | 
					
						
							|  |  |  | objects here, as long as they have the right methods. | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | \ttindex{Unpickler} | 
					
						
							|  |  |  | \ttindex{Pickler} | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | The constructor for the \class{Pickler} class has an optional second | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | argument, \var{bin}.  If this is present and nonzero, the binary | 
					
						
							|  |  |  | pickle format is used; if it is zero or absent, the (less efficient, | 
					
						
							|  |  |  | but backwards compatible) text pickle format is used.  The | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \class{Unpickler} class does not have an argument to distinguish | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | between binary and text pickle formats; it accepts either format. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | The following types can be pickled: | 
					
						
							|  |  |  | \begin{itemize} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \item \code{None} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \item integers, long integers, floating point numbers | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \item strings | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \item tuples, lists and dictionaries containing only picklable objects | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | \item classes that are defined at the top level in a module | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \item instances of such classes whose \member{__dict__} or | 
					
						
							|  |  |  | \method{__setstate__()} is picklable | 
					
						
							| 
									
										
										
										
											1995-02-15 15:53:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | \end{itemize} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | Attempts to pickle unpicklable objects will raise the | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \exception{PicklingError} exception; when this happens, an unspecified | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | number of bytes may have been written to the file. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | It is possible to make multiple calls to the \method{dump()} method of | 
					
						
							|  |  |  | the same \class{Pickler} instance.  These must then be matched to the | 
					
						
							|  |  |  | same number of calls to the \method{load()} method of the | 
					
						
							|  |  |  | corresponding \class{Unpickler} instance.  If the same object is | 
					
						
							|  |  |  | pickled by multiple \method{dump()} calls, the \method{load()} will all | 
					
						
							| 
									
										
										
										
											1998-01-09 22:36:51 +00:00
										 |  |  | yield references to the same object.  \emph{Warning}: this is intended | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | for pickling multiple objects without intervening modifications to the | 
					
						
							|  |  |  | objects or their parts.  If you modify an object and then pickle it | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | again using the same \class{Pickler} instance, the object is not | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | pickled again --- a reference to it is pickled and the | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \class{Unpickler} will return the old value, not the modified one. | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | (There are two problems here: (a) detecting changes, and (b) | 
					
						
							|  |  |  | marshalling a minimal set of changes.  I have no answers.  Garbage | 
					
						
							|  |  |  | Collection may also become a problem here.) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | Apart from the \class{Pickler} and \class{Unpickler} classes, the | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | module defines the following functions, and an exception: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-03-17 06:33:25 +00:00
										 |  |  | \begin{funcdesc}{dump}{object, file\optional{, bin}} | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | Write a pickled representation of \var{obect} to the open file object | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | \var{file}.  This is equivalent to | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | \samp{Pickler(\var{file}, \var{bin}).dump(\var{object})}. | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | If the optional \var{bin} argument is present and nonzero, the binary | 
					
						
							|  |  |  | pickle format is used; if it is zero or absent, the (less efficient) | 
					
						
							|  |  |  | text pickle format is used. | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{funcdesc}{load}{file} | 
					
						
							|  |  |  | Read a pickled object from the open file object \var{file}.  This is | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | equivalent to \samp{Unpickler(\var{file}).load()}. | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | \begin{funcdesc}{dumps}{object\optional{, bin}} | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | Return the pickled representation of the object as a string, instead | 
					
						
							| 
									
										
										
										
											1997-12-09 20:45:08 +00:00
										 |  |  | of writing it to a file.  If the optional \var{bin} argument is | 
					
						
							|  |  |  | present and nonzero, the binary pickle format is used; if it is zero | 
					
						
							|  |  |  | or absent, the (less efficient) text pickle format is used. | 
					
						
							| 
									
										
										
										
											1995-03-17 16:07:09 +00:00
										 |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{funcdesc}{loads}{string} | 
					
						
							|  |  |  | Read a pickled object from a string instead of a file.  Characters in | 
					
						
							|  |  |  | the string past the pickled object's representation are ignored. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{excdesc}{PicklingError} | 
					
						
							|  |  |  | This exception is raised when an unpicklable object is passed to | 
					
						
							|  |  |  | \code{Pickler.dump()}. | 
					
						
							|  |  |  | \end{excdesc} | 
					
						
							| 
									
										
										
										
											1998-03-06 21:27:14 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{seealso} | 
					
						
							|  |  |  | \seemodule[copyreg]{copy_reg}{pickle interface constructor | 
					
						
							|  |  |  | registration} | 
					
						
							| 
									
										
										
										
											1998-04-04 06:20:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | \seemodule{shelve}{indexed databases of objects; uses \module{pickle}} | 
					
						
							| 
									
										
										
										
											1998-04-11 20:43:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | \seemodule{copy}{shallow and deep object copying} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \seemodule{marshal}{high-performance serialization of built-in types} | 
					
						
							| 
									
										
										
										
											1998-03-06 21:27:14 +00:00
										 |  |  | \end{seealso} | 
					
						
							| 
									
										
										
										
											1998-04-11 20:05:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-08-10 19:42:37 +00:00
										 |  |  | \section{\module{cPickle} --- | 
					
						
							|  |  |  |          Alternate implementation of \module{pickle}.} | 
					
						
							| 
									
										
										
										
											1998-07-23 17:59:49 +00:00
										 |  |  | \declaremodule{builtin}{cPickle} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \modulesynopsis{Faster version of \module{pickle}, but not subclassable.} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-11 20:05:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | % This section was written by Fred L. Drake, Jr. <fdrake@acm.org>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The \module{cPickle} module provides a similar interface and identical | 
					
						
							|  |  |  | functionality as the \module{pickle} module, but can be up to 1000 | 
					
						
							|  |  |  | times faster since it is implemented in \C{}.  The only other | 
					
						
							|  |  |  | important difference to note is that \function{Pickler()} and | 
					
						
							|  |  |  | \function{Unpickler()} are functions and not classes, and so cannot be | 
					
						
							|  |  |  | subclassed.  This should not be an issue in most cases. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The format of the pickle data is identical to that produced using the | 
					
						
							|  |  |  | \module{pickle} module, so it is possible to use \module{pickle} and | 
					
						
							|  |  |  | \module{cPickle} interchangably with existing pickles. | 
					
						
							| 
									
										
										
										
											1999-01-06 23:34:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | (Since the pickle data format is actually a tiny stack-oriented | 
					
						
							|  |  |  | programming language, and there are some freedoms in the encodings of | 
					
						
							|  |  |  | certain objects, it's possible that the two modules produce different | 
					
						
							|  |  |  | pickled data for the same input objects; however they will always be | 
					
						
							|  |  |  | able to read each others pickles back in.) |