Python Refcard
Python Refcard
Python Refcard
5 Reference Card
(c) 2007 Michael Goerz <goerz@physik.fu-berlin.de> http://www.physik.fu-berlin.de/~goerz/ Information taken liberally from the python documentation and various other sources. You may freely modify and distribute this document.
1 Variable Types
1.1 Numbers
42 052 0x2A 42L 052L 0x2AL 42 (dec, oct, hex, short/long) 0.2 .8 4. 1.e10 1.0e-7 floating point value z = 5.0 2.0J; complex number z = complex(real, imag) complex number z.real; z.imag real and imag part of z True; False constants for boolean values abs(n) absolute value of n divmod(x, y) (x/y, x%y) hex(n) create hex string oct(n) create octal string ord(c) unicode code point of char round(x,n) round x to n decimal places cmp(x,y) x<y: -1, x==y: 0, x>y: 1 coerce(x, y) (x,y), make same type pow(x,y,z) (x**y) % z float("3.14") float from string int("42", base) int from string import math; import cmath more math functions import random; random number generators 1.2 Sequences (lists are mutable, tuples and strings are immutable) s=l=[1, "bla", [1+2J, 1.4], 4] list creation s=t=(1, "bla", [1+2J, 1.4], 4) tuple creation l=list(t); t=tuple(l) list/tuple conversion l=range(1000) list of integers (0-999) s=xrange(1000) immut. xrange-sequence i=iter(s); i.next() iterator from sequence s[2][0] get list element (1+2J) s[-2][-1] get list element (1.4) s1+s1 sequence concat n*s1 repeat s1 n times s[i:j]; s[i:]; s[:j] slicing (i incl., j excl.) s[i:j:k] slice with stride k s[::2]; s[::-1] every 2nd Element / reverse s x in s; x not in s is x a member of s? len(s) number of elements min(s); max(s) min/max l[i:j]=['a','b','c','d'] replace slice l[i:i]=['a','b'] insert before position i l.count(x) number of occurances of x l.index(x) first index of x, or error l.append(x) append x at end of l x=l.pop() pop off last element l.extend(l2) append l2 at end of l l.insert(i,x) instert x at pos. i l.remove(x) delete first x l.reverse() reverse l l.sort(f) sort using f (default f =cmp) zip(s,t,...) [(s[0],t[0],...),..]
1.4 Sets
padding: center(w,c), ljust(w,c), lstrip(cs), rjust(w,c), rstrip(cs), strip(cs), zfill(w), expandtabs(ts) checking: isalnum, isalpha, isdigit, islower, isspace, istitle, isupper String Constants: import string digits, hexdigits, letters, lowercase, octdigits, printable, punctuation, uppercase, whitespace Regexes: import re r=re.compile(r'rx',re.ILMSUX) comile 'rx' as regex (?P<id>...) named group m=r.match(s,b,e) full match re.match(r'(?iLmsux)rx',s) direct regex usage m=r.search(s,b,e) partial match l=r.split(s,ms) split and return list l=r.findall(string) list of all matched groups s=r.sub(s,r,c) replace c counts of s with r (s,n)=r.subn(s,r,c) n is number of replacements s=re.escape(s) escape all non-alphanumerics m.start(g);m.span(g);m.end(g) group-match delimiters m.expand(s) replace \1 etc. with matches m.group(g); m.group("name") matched group no. g m.groups() list of groups m.groupdict() dict of named groups
2 Basic Syntax
if expr: statements elif expr: statements else: statements if a is b : ... if a == 1 while expr: statements else: statements while True: ... if cond: break for target in iter: statements else: statements for key,value in d.items():... break, continue print "hello world", [ expr for x in seq lc ] lc = for x in seq / if expr pass def f(params): statements def f(x, y=0): return x+y def f(*a1, **a2): statements def f(): f.variable = 1 ... return expression yield expression f(1,1), f(2), f(y=3, x=4) global v def make_adder_2(a): def add(b): return a+b return add lambda x: x+a compile(string,filename,kind) conditional object identity value identity while loop run else on normal exit do... while equivalent for loop multiple identifiers end loop / jump to next print without newline list comprehension with lc-clauses empty statement function definition optional parameter additional list of unnamed, dict of named paramters function attribute return from function make function a generator function calls bind to global variable closure lambda expression compile string into code object
String Services: string, re, struct, difflib, StringIO, cStringIO, textwrap, codecs, unicodedata, stringprep, 5 System Interaction fpformat sys.path module search path File/Directory Access: os.path, fileinput, stat, statvfs, sys.platform operating system filecmp, tempfile, glob, fnmatch, linecache, shutil, sys.stdout, stdin, stderr standard input/output/error dircache 3 Object Orientation and Modules sys.argv[1:] command line parameters Generic OS services: os, time, optparse, getopt, logging, import module as alias import module os.system(cmd) system call getpass, curses, platform, errno, ctypes from module import name1,name2 load attr. into own namespace os.startfile(f) open file with assoc. program Optional OS services: select, thread, threading, from __future__ import * activate all new features os.popen(cmd, r|w, bufsize) open pipe (file object) dummy_thread, dummy_threading, mmap, readline, reload module reinitialize module os.popen2(cmd, bufsize, b|t) (stdin, stdout) fileobjects rlcompleter module.__all__ exported attributes os.popen3(cmd, bufsize, b|t) (stdin, stdout,stderr) Data Types: datetime, calendar, collections, heapq, module.__name__ module name / "__main__" os.environ['VAR']; os.putenv[] read/write environment vars bisect, array, sets, sched, mutex, Queue, weakref, module.__dict__ module namespace glob.glob('*.txt') UserDict, UserList, UserString, types, new, copy, wildcard search __import__("name",glb,loc,fl) import module by name pprint, repr Filesystem Operations class name (superclass,...): class definition os module: access, chdir, chmod, chroot, getcwd, getenv, Numeric and Math Modules: math, cmath, decimal, random, data = value shared class data listdir, mkdir, remove, unlink, removedirs, rename, itertools, functools, operator def method(self,...): ... methods rmdir, pipe, ... Internet Data Handling: email, mailcap, mailbox, mhlib, constructor def __init__(self, x): mimetools, mimetypes, MimeWriter, mimify, multifile, shutil module: copy, copy2, copyfile, copyfileobj, call superclass constructor Super.__init__(self) rfc822, base64, binhex, binascii, quopri, uu copymode, copystat, copytree, rmtree per-instance data self.member = x os.path module: abspath, altsep, basename, commonprefix, Structured Markup Processing Tools: HTMLParser, sgmllib, destructor def __del__(self): ... htmllib, htmlentitydefs, xml.parsers.expat, xml.dom.*, curdir, defpath, dirname, exists, expanduser, __str__, __len__, __cmp__,__ some operator overloaders xml.sax.*, xml.etree.ElementTree expandvar, extsep, get[acm]time, getsize, isabs, __iter__(self): return self use next method for iterator File Formats: csv, ConfigParser, robotparser, netrc, isdir, isfile, islink, ismout, join, lexists, __call__ call interceptor xdrlib normcase, normpath, pardir, pathsep, realpath, __dict__ instance-attribute dictionary samefile, sameopenfile, samestat, sep, split, Crypto Services: hashlib, hmac, md5, sha __getattr__(self, name), get an unknown attribute splitdrive, splitext, stat, walk Compression: zlib, gzip, bz2, zipfile, tarfile __setattr__(self, name, value) set any attribute command line argument parsing: Persistence: pickle, cPickle, copy_reg, shelve, marshal, callable(object) 1 if callable, 0 otherwise restlist, opts = \ anydbm, whichdb, dbm, gdbm, dbhash, bsddb, dumbdbm, delattr(object, "name") delete name-attr. from object getopt.getopt(sys.argv[l:],\ sqlite3 del(object) unreference object/var "s:oh",\ Unix specific: posix, pwd, spwd, grp, crypt, dl, termios, dir(object) list of attr. assoc. with object ["spam=", "other", "help"]) tty, pty, fcntl, posixfile, resource, nis, syslog, getattr(object, "name", def) get name-attr. from object for o, a in opts: commands hasattr(object, "name") check if object has attr. if o in ("-s", "--lol"): spam = a IPC/Networking: subprocess, socket, signal, popen2, hash(object) return hash for object if o in ("-h", "--help"): show_help() asyncore, asynchat id(object) unique integer (mem address) Internet: webbrowser, cgi, scitb, wsgiref, urllib, isinstance(object, check for type httplib, ftplib, imaplib, nntplib, ...lib, smtpd, classOrType) 6 Input/Output uuid, urlparse, SocketServer, ...Server,, cookielib, issubclass(class1, class2) class2 subclass of class1? f=codecs.open(if,"rb","utf-8") open file with encoding Cookie, xmlrpclib iter(object, sentinel) return iterator for object file = open(infilename, "wb") open file without encoding Multimedia: audioop, imageop, aifc, sunau, wave, chunk, locals() dict of local vars of caller codecs.EncodedFile(...) wrap file into encoding colorsys, rgbimg, imghdr, sndhdr, ossaudiodev repr(object), str(object) return string-representation r, w, a, r+ read, write, append, random Tk: Tkinter, Tix, ScrolledText, turtle vars(object) return __dict__ rb, wb, ab, r+b modes without eol conversion Internationalization: gettext, locale None the NULL object file.read(N) N bytes ( entire file if no N ) Program Frameworks: cmd, shlex if __name__ == "__main__": make modul executable file.readline() the next linestring Development: pydoc, doctest, unittest, test file.readlines() list of linestring Runtime: sys, warnings, contextlib, atexit, traceback, file.write(string) write string to file qc, inspect, site, user, fpectl file.writelines(list) 4 Exception Handling write list of linestrings Custom Interpreters: code, codeop file.close() try: ... close file Try-block Restricted Execution: rexec, Bastion file.tell() except ExceptionName: current file position catch exception Importing: imp, zipimport, pkgutil, modulefinder, runpy file.seek(offset, whence) except (Ex1, ...), data: multiple, with data jump to file position Language: parser, symbol, token, keyword, tokenize, os.truncate(size) exception handling print data limit output to size tabnanny, pyclbr, py_compile, compileall, dis, os.tmpfile() pass up (re-raise) exception raise open anon temporary file pickletools, distutils if no exception occurred pickle.dump(x, file) else: ... make object persistent Windows: msilib, msvcrt, _winreq, winsound in any case x = pickle.load(file) finally: ... load object from file Misc: formatter assert expression debug assertion
evaluate expression compile and execute code execute file input from stdin input and evaluate
class MyExcept(Exception): ... define user exception raise MyExcept , data raise user exception