diff options
Diffstat (limited to 'Doc')
-rw-r--r-- | Doc/lib/libfuncs.tex | 38 |
1 files changed, 21 insertions, 17 deletions
diff --git a/Doc/lib/libfuncs.tex b/Doc/lib/libfuncs.tex index feac346..98b4cfd 100644 --- a/Doc/lib/libfuncs.tex +++ b/Doc/lib/libfuncs.tex @@ -1057,26 +1057,30 @@ class C(B): \begin{funcdesc}{type}{object} Return the type of an \var{object}. The return value is a - type\obindex{type} object. The standard module - \module{types}\refstmodindex{types} defines names for all built-in - types that don't already have built-in names. - For instance: + type\obindex{type} object. The \function{isinstance()} built-in + function is recommended for testing the type of an object. + + With three arguments, \function{type} functions as a constructor + as detailed below. +\end{funcdesc} + +\begin{funcdesc}{type}{name, bases, dict} + Return a new type object. This is essentially a dynamic form of the + \keyword{class} statement. The \var{name} string is the class name + and becomes the \member{__name__} attribute; the \var{bases} tuple + itemizes the base classes and becomes the \member{__bases__} + attribute; and the \var{dict} dictionary is the namespace containing + definitions for class body and becomes the \member{__dict__} + attribute. For example, the following two statements create + identical \class{type} objects: \begin{verbatim} ->>> import types ->>> x = 'abc' ->>> if type(x) is str: print "It's a string" -... -It's a string ->>> def f(): pass -... ->>> if type(f) is types.FunctionType: print "It's a function" -... -It's a function + >>> class X(object): + ... a = 1 + ... + >>> X = type('X', (object,), dict(a=1)) \end{verbatim} - - The \function{isinstance()} built-in function is recommended for - testing the type of an object. +\versionadded{2.2} \end{funcdesc} \begin{funcdesc}{unichr}{i} |