mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 05:31:20 +00:00 
			
		
		
		
	 f8316638af
			
		
	
	
		f8316638af
		
	
	
	
	
		
			
			SourceForge doesn't choke on this batch :-)
I'm not entirely sure this is 100% correct. The patch changes an
\index{persistency} to \index{presistence}, and I don't know what \index{}
does. But it seems to do so persi--er, consistently, so I hope it isn't a
problem.
		
	
			
		
			
				
	
	
		
			389 lines
		
	
	
	
		
			16 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
			
		
		
	
	
			389 lines
		
	
	
	
		
			16 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
| \section{\module{pickle} ---
 | |
|          Python object serialization}
 | |
| 
 | |
| \declaremodule{standard}{pickle}
 | |
| \modulesynopsis{Convert Python objects to streams of bytes and back.}
 | |
| % Substantial improvements by Jim Kerr <jbkerr@sr.hp.com>.
 | |
| 
 | |
| \index{persistence}
 | |
| \indexii{persistent}{objects}
 | |
| \indexii{serializing}{objects}
 | |
| \indexii{marshalling}{objects}
 | |
| \indexii{flattening}{objects}
 | |
| \indexii{pickling}{objects}
 | |
| 
 | |
| 
 | |
| The \module{pickle} module implements a basic but powerful algorithm
 | |
| for ``pickling'' (a.k.a.\ serializing, marshalling or flattening)
 | |
| nearly 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 persistence --- although \module{pickle}
 | |
| reads and writes file objects, it does not handle the issue of naming
 | |
| persistent objects, nor the (even more complicated) area of concurrent
 | |
| access to persistent objects.  The \module{pickle} module can
 | |
| transform a complex object into 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
 | |
| \refmodule{shelve}\refstmodindex{shelve} provides a simple interface
 | |
| to pickle and unpickle objects on DBM-style database files.
 | |
| 
 | |
| 
 | |
| \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
 | |
| \refmodule{cPickle}\refbimodindex{cPickle} module.  This has the same
 | |
| interface except that \class{Pickler} and \class{Unpickler} are
 | |
| factory functions, not classes (so they cannot be used as base classes
 | |
| for inheritance).
 | |
| 
 | |
| Although the \module{pickle} module can use the built-in module
 | |
| \refmodule{marshal}\refbimodindex{marshal} internally, it differs from 
 | |
| \refmodule{marshal} in the way it handles certain kinds of data:
 | |
| 
 | |
| \begin{itemize}
 | |
| 
 | |
| \item Recursive objects (objects containing references to themselves): 
 | |
|       \module{pickle} keeps track of the objects it has already
 | |
|       serialized, so later references to the same object won't be
 | |
|       serialized again.  (The \refmodule{marshal} module breaks for
 | |
|       this.)
 | |
| 
 | |
| \item Object sharing (references to the same object in different
 | |
|       places):  This is similar to self-referencing objects;
 | |
|       \module{pickle} stores the object once, and ensures that all
 | |
|       other references point to the master copy.  Shared objects
 | |
|       remain shared, which can be very important for mutable objects.
 | |
| 
 | |
| \item User-defined classes and their instances:  \refmodule{marshal}
 | |
|       does not support these at all, but \module{pickle} can save
 | |
|       and restore class instances transparently.  The class definition 
 | |
|       must be importable and live in the same module as when the
 | |
|       object was stored.
 | |
| 
 | |
| \end{itemize}
 | |
| 
 | |
| The data format used by \module{pickle} is Python-specific.  This has
 | |
| the advantage that there are no restrictions imposed by external
 | |
| 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.
 | |
| 
 | |
| By default, the \module{pickle} data format uses a printable \ASCII{}
 | |
| representation.  This is slightly more voluminous than a binary
 | |
| representation.  The big advantage of using printable \ASCII{} (and of
 | |
| some other characteristics of \module{pickle}'s representation) is that
 | |
| 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
 | |
| \class{Pickler} constructor or the \function{dump()} and \function{dumps()}
 | |
| 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.
 | |
| 
 | |
| The \module{pickle} module doesn't handle code objects, which the
 | |
| \refmodule{marshal}\refbimodindex{marshal} module does.  I suppose
 | |
| \module{pickle} could, and maybe it should, but there's probably no
 | |
| great need for it right now (as long as \refmodule{marshal} continues
 | |
| to be used for reading and writing code objects), and at least this
 | |
| avoids the possibility of smuggling Trojan horses into a program.
 | |
| 
 | |
| For the benefit of persistence modules written using \module{pickle}, it
 | |
| supports the notion of a reference to an object outside the pickled
 | |
| data stream.  Such objects are referenced by a name, which is an
 | |
| arbitrary string of printable \ASCII{} characters.  The resolution of
 | |
| such names is not defined by the \module{pickle} module --- the
 | |
| persistent object module will have to implement a method
 | |
| \method{persistent_load()}.  To write references to persistent objects,
 | |
| the persistent module must define a method \method{persistent_id()} which
 | |
| 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.
 | |
| Furthermore, all its instance variables must be picklable.
 | |
| 
 | |
| \setindexsubitem{(pickle protocol)}
 | |
| 
 | |
| When a pickled class instance is unpickled, its \method{__init__()} method
 | |
| 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
 | |
| (minor) nuisance to have to provide a \method{__getinitargs__()} method.
 | |
| 
 | |
| If it is desirable that the \method{__init__()} method be called on
 | |
| unpickling, a class can define a method \method{__getinitargs__()},
 | |
| which should return a \emph{tuple} containing the arguments to be
 | |
| passed to the class constructor (\method{__init__()}).  This method is
 | |
| called at pickle time; the tuple it returns is incorporated in the
 | |
| pickle for the instance.
 | |
| \withsubitem{(copy protocol)}{\ttindex{__getinitargs__()}}
 | |
| \withsubitem{(instance constructor)}{\ttindex{__init__()}}
 | |
| 
 | |
| Classes can further influence how their instances are pickled --- if
 | |
| the class
 | |
| \withsubitem{(copy protocol)}{
 | |
|   \ttindex{__getstate__()}\ttindex{__setstate__()}}
 | |
| \withsubitem{(instance attribute)}{
 | |
|   \ttindex{__dict__}}
 | |
| defines the method \method{__getstate__()}, it is called and the return
 | |
| state is pickled as the contents for the instance, and if the class
 | |
| defines the method \method{__setstate__()}, it is called with the
 | |
| unpickled state.  (Note that these methods can also be used to
 | |
| implement copying class instances.)  If there is no
 | |
| \method{__getstate__()} method, the instance's \member{__dict__} is
 | |
| pickled.  If there is no \method{__setstate__()} method, the pickled
 | |
| object must be a dictionary and its items are assigned to the new
 | |
| instance's dictionary.  (If a class defines both \method{__getstate__()}
 | |
| and \method{__setstate__()}, the state object needn't be a dictionary
 | |
| --- these methods can do what they want.)  This protocol is also used
 | |
| by the shallow and deep copying operations defined in the
 | |
| \refmodule{copy}\refstmodindex{copy} module.
 | |
| 
 | |
| Note that when class instances are pickled, their class's code and
 | |
| data are not pickled along with them.  Only the instance data are
 | |
| 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
 | |
| will see many versions of a class, it may be worthwhile to put a version
 | |
| number in the objects so that suitable conversions can be made by the
 | |
| class's \method{__setstate__()} method.
 | |
| 
 | |
| 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.
 | |
| 
 | |
| \setindexsubitem{(in module pickle)}
 | |
| 
 | |
| The interface can be summarized as follows.
 | |
| 
 | |
| To pickle an object \code{x} onto a file \code{f}, open for writing:
 | |
| 
 | |
| \begin{verbatim}
 | |
| p = pickle.Pickler(f)
 | |
| p.dump(x)
 | |
| \end{verbatim}
 | |
| 
 | |
| A shorthand for this is:
 | |
| 
 | |
| \begin{verbatim}
 | |
| pickle.dump(x, f)
 | |
| \end{verbatim}
 | |
| 
 | |
| To unpickle an object \code{x} from a file \code{f}, open for reading:
 | |
| 
 | |
| \begin{verbatim}
 | |
| u = pickle.Unpickler(f)
 | |
| x = u.load()
 | |
| \end{verbatim}
 | |
| 
 | |
| A shorthand is:
 | |
| 
 | |
| \begin{verbatim}
 | |
| x = pickle.load(f)
 | |
| \end{verbatim}
 | |
| 
 | |
| The \class{Pickler} class only calls the method \code{f.write()} with a
 | |
| \withsubitem{(class in pickle)}{\ttindex{Unpickler}\ttindex{Pickler}}
 | |
| string argument.  The \class{Unpickler} calls the methods \code{f.read()}
 | |
| (with an integer argument) and \code{f.readline()} (without argument),
 | |
| both returning a string.  It is explicitly allowed to pass non-file
 | |
| objects here, as long as they have the right methods.
 | |
| 
 | |
| The constructor for the \class{Pickler} class has an optional second
 | |
| argument, \var{bin}.  If this is present and true, the binary
 | |
| pickle format is used; if it is absent or false, the (less efficient,
 | |
| but backwards compatible) text pickle format is used.  The
 | |
| \class{Unpickler} class does not have an argument to distinguish
 | |
| between binary and text pickle formats; it accepts either format.
 | |
| 
 | |
| The following types can be pickled:
 | |
| 
 | |
| \begin{itemize}
 | |
| 
 | |
| \item \code{None}
 | |
| 
 | |
| \item integers, long integers, floating point numbers
 | |
| 
 | |
| \item normal and Unicode strings
 | |
| 
 | |
| \item tuples, lists and dictionaries containing only picklable objects
 | |
| 
 | |
| \item functions defined at the top level of a module (by name
 | |
|       reference, not storage of the implementation)
 | |
| 
 | |
| \item built-in functions
 | |
| 
 | |
| \item classes that are defined at the top level in a module
 | |
| 
 | |
| \item instances of such classes whose \member{__dict__} or
 | |
| \method{__setstate__()} is picklable
 | |
| 
 | |
| \end{itemize}
 | |
| 
 | |
| Attempts to pickle unpicklable objects will raise the
 | |
| \exception{PicklingError} exception; when this happens, an unspecified
 | |
| number of bytes may have been written to the file.
 | |
| 
 | |
| 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
 | |
| yield references to the same object.  \emph{Warning}: this is intended
 | |
| for pickling multiple objects without intervening modifications to the
 | |
| objects or their parts.  If you modify an object and then pickle it
 | |
| again using the same \class{Pickler} instance, the object is not
 | |
| pickled again --- a reference to it is pickled and the
 | |
| \class{Unpickler} will return the old value, not the modified one.
 | |
| (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.)
 | |
| 
 | |
| Apart from the \class{Pickler} and \class{Unpickler} classes, the
 | |
| module defines the following functions, and an exception:
 | |
| 
 | |
| \begin{funcdesc}{dump}{object, file\optional{, bin}}
 | |
| Write a pickled representation of \var{object} to the open file object
 | |
| \var{file}.  This is equivalent to
 | |
| \samp{Pickler(\var{file}, \var{bin}).dump(\var{object})}.
 | |
| 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.
 | |
| \end{funcdesc}
 | |
| 
 | |
| \begin{funcdesc}{load}{file}
 | |
| Read a pickled object from the open file object \var{file}.  This is
 | |
| equivalent to \samp{Unpickler(\var{file}).load()}.
 | |
| \end{funcdesc}
 | |
| 
 | |
| \begin{funcdesc}{dumps}{object\optional{, bin}}
 | |
| Return the pickled representation of the object as a string, instead
 | |
| 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.
 | |
| \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
 | |
| \method{Pickler.dump()}.
 | |
| \end{excdesc}
 | |
| 
 | |
| 
 | |
| \begin{seealso}
 | |
|   \seemodule[copyreg]{copy_reg}{pickle interface constructor
 | |
|                                 registration}
 | |
| 
 | |
|   \seemodule{shelve}{indexed databases of objects; uses \module{pickle}}
 | |
| 
 | |
|   \seemodule{copy}{shallow and deep object copying}
 | |
| 
 | |
|   \seemodule{marshal}{high-performance serialization of built-in types}
 | |
| \end{seealso}
 | |
| 
 | |
| 
 | |
| \subsection{Example \label{pickle-example}}
 | |
| 
 | |
| Here's a simple example of how to modify pickling behavior for a
 | |
| class.  The \class{TextReader} class opens a text file, and returns
 | |
| the line number and line contents each time its \method{readline()}
 | |
| method is called. If a \class{TextReader} instance is pickled, all
 | |
| attributes \emph{except} the file object member are saved. When the
 | |
| instance is unpickled, the file is reopened, and reading resumes from
 | |
| the last location. The \method{__setstate__()} and
 | |
| \method{__getstate__()} methods are used to implement this behavior.
 | |
| 
 | |
| \begin{verbatim}
 | |
| # illustrate __setstate__ and __getstate__  methods
 | |
| # used in pickling.
 | |
| 
 | |
| class TextReader:
 | |
|     "Print and number lines in a text file."
 | |
|     def __init__(self,file):
 | |
|         self.file = file
 | |
|         self.fh = open(file,'r')
 | |
|         self.lineno = 0
 | |
| 
 | |
|     def readline(self):
 | |
|         self.lineno = self.lineno + 1
 | |
|         line = self.fh.readline()
 | |
|         if not line:
 | |
|             return None
 | |
|         return "%d: %s" % (self.lineno,line[:-1])
 | |
| 
 | |
|     # return data representation for pickled object
 | |
|     def __getstate__(self):
 | |
|         odict = self.__dict__    # get attribute dictionary
 | |
|         del odict['fh']          # remove filehandle entry
 | |
|         return odict
 | |
| 
 | |
|     # restore object state from data representation generated 
 | |
|     # by __getstate__
 | |
|     def __setstate__(self,dict):
 | |
|         fh = open(dict['file'])  # reopen file
 | |
|         count = dict['lineno']   # read from file...
 | |
|         while count:             # until line count is restored
 | |
|             fh.readline()
 | |
|             count = count - 1
 | |
|         dict['fh'] = fh          # create filehandle entry
 | |
|         self.__dict__ = dict     # make dict our attribute dictionary
 | |
| \end{verbatim}
 | |
| 
 | |
| A sample usage might be something like this:
 | |
| 
 | |
| \begin{verbatim}
 | |
| >>> import TextReader
 | |
| >>> obj = TextReader.TextReader("TextReader.py")
 | |
| >>> obj.readline()
 | |
| '1: #!/usr/local/bin/python'
 | |
| >>> # (more invocations of obj.readline() here)
 | |
| ... obj.readline()
 | |
| '7: class TextReader:'
 | |
| >>> import pickle
 | |
| >>> pickle.dump(obj,open('save.p','w'))
 | |
| 
 | |
|   (start another Python session)
 | |
| 
 | |
| >>> import pickle
 | |
| >>> reader = pickle.load(open('save.p'))
 | |
| >>> reader.readline()
 | |
| '8:     "Print and number lines in a text file."'
 | |
| \end{verbatim}
 | |
| 
 | |
| 
 | |
| \section{\module{cPickle} ---
 | |
|          Alternate implementation of \module{pickle}}
 | |
| 
 | |
| \declaremodule{builtin}{cPickle}
 | |
| \modulesynopsis{Faster version of \refmodule{pickle}, but not subclassable.}
 | |
| \moduleauthor{Jim Fulton}{jfulton@digicool.com}
 | |
| \sectionauthor{Fred L. Drake, Jr.}{fdrake@acm.org}
 | |
| 
 | |
| 
 | |
| The \module{cPickle} module provides a similar interface and identical
 | |
| functionality as the \refmodule{pickle}\refstmodindex{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
 | |
| \refmodule{pickle} module, so it is possible to use \refmodule{pickle} and
 | |
| \module{cPickle} interchangeably with existing pickles.
 | |
| 
 | |
| (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 other's pickles back in.)
 |