usage.py
652 lines
| 30.5 KiB
| text/x-python
|
PythonLexer
/ IPython / usage.py
fperez
|
r0 | # -*- coding: utf-8 -*- | ||
#***************************************************************************** | ||||
# Copyright (C) 2001-2004 Fernando Perez. <fperez@colorado.edu> | ||||
# | ||||
# Distributed under the terms of the BSD License. The full license is in | ||||
# the file COPYING, distributed as part of this software. | ||||
#***************************************************************************** | ||||
vivainio
|
r824 | # $Id: usage.py 2710 2007-09-04 21:10:10Z vivainio $ | ||
fperez
|
r0 | |||
from IPython import Release | ||||
__author__ = '%s <%s>' % Release.authors['Fernando'] | ||||
__license__ = Release.license | ||||
__version__ = Release.version | ||||
__doc__ = """ | ||||
IPython -- An enhanced Interactive Python | ||||
========================================= | ||||
A Python shell with automatic history (input and output), dynamic object | ||||
introspection, easier configuration, command completion, access to the system | ||||
shell and more. | ||||
IPython can also be embedded in running programs. See EMBEDDING below. | ||||
USAGE | ||||
ipython [options] files | ||||
If invoked with no options, it executes all the files listed in | ||||
sequence and drops you into the interpreter while still acknowledging | ||||
any options you may have set in your ipythonrc file. This behavior is | ||||
different from standard Python, which when called as python -i will | ||||
only execute one file and will ignore your configuration setup. | ||||
Please note that some of the configuration options are not available at | ||||
the command line, simply because they are not practical here. Look into | ||||
your ipythonrc configuration file for details on those. This file | ||||
typically installed in the $HOME/.ipython directory. | ||||
For Windows users, $HOME resolves to C:\\Documents and | ||||
Settings\\YourUserName in most instances, and _ipython is used instead | ||||
of .ipython, since some Win32 programs have problems with dotted names | ||||
in directories. | ||||
In the rest of this text, we will refer to this directory as | ||||
IPYTHONDIR. | ||||
SPECIAL THREADING OPTIONS | ||||
The following special options are ONLY valid at the beginning of the | ||||
command line, and not later. This is because they control the initial- | ||||
ization of ipython itself, before the normal option-handling mechanism | ||||
is active. | ||||
fperez
|
r550 | -gthread, -qthread, -q4thread, -wthread, -pylab | ||
fperez
|
r0 | |||
Only ONE of these can be given, and it can only be given as the | ||||
first option passed to IPython (it will have no effect in any | ||||
other position). They provide threading support for the GTK, QT | ||||
and WXWidgets toolkits, and for the matplotlib library. | ||||
fperez
|
r550 | With any of the first four options, IPython starts running a | ||
fperez
|
r0 | separate thread for the graphical toolkit's operation, so that | ||
you can open and control graphical elements from within an | ||||
fperez
|
r550 | IPython command line, without blocking. All four provide | ||
essentially the same functionality, respectively for GTK, QT3, | ||||
QT4 and WXWidgets (via their Python interfaces). | ||||
fperez
|
r0 | |||
fperez
|
r91 | Note that with -wthread, you can additionally use the -wxversion | ||
option to request a specific version of wx to be used. This | ||||
requires that you have the 'wxversion' Python module installed, | ||||
which is part of recent wxPython distributions. | ||||
fperez
|
r0 | If -pylab is given, IPython loads special support for the mat- | ||
plotlib library (http://matplotlib.sourceforge.net), allowing | ||||
interactive usage of any of its backends as defined in the | ||||
user's .matplotlibrc file. It automatically activates GTK, QT | ||||
or WX threading for IPyhton if the choice of matplotlib backend | ||||
requires it. It also modifies the %run command to correctly | ||||
execute (without blocking) any matplotlib-based script which | ||||
calls show() at the end. | ||||
fperez
|
r550 | -tk The -g/q/q4/wthread options, and -pylab (if matplotlib is | ||
fperez
|
r0 | configured to use GTK, QT or WX), will normally block Tk | ||
graphical interfaces. This means that when GTK, QT or WX | ||||
threading is active, any attempt to open a Tk GUI will result in | ||||
a dead window, and possibly cause the Python interpreter to | ||||
crash. An extra option, -tk, is available to address this | ||||
issue. It can ONLY be given as a SECOND option after any of the | ||||
fperez
|
r550 | above (-gthread, -qthread, q4thread, -wthread or -pylab). | ||
fperez
|
r0 | |||
If -tk is given, IPython will try to coordinate Tk threading | ||||
with GTK, QT or WX. This is however potentially unreliable, and | ||||
you will have to test on your platform and Python configuration | ||||
to determine whether it works for you. Debian users have | ||||
reported success, apparently due to the fact that Debian builds | ||||
all of Tcl, Tk, Tkinter and Python with pthreads support. Under | ||||
other Linux environments (such as Fedora Core 2/3), this option | ||||
has caused random crashes and lockups of the Python interpreter. | ||||
Under other operating systems (Mac OSX and Windows), you'll need | ||||
to try it to find out, since currently no user reports are | ||||
available. | ||||
There is unfortunately no way for IPython to determine at run- | ||||
time whether -tk will work reliably or not, so you will need to | ||||
do some experiments before relying on it for regular work. | ||||
A WARNING ABOUT SIGNALS AND THREADS | ||||
When any of the thread systems (GTK, QT or WX) are active, either | ||||
directly or via -pylab with a threaded backend, it is impossible to | ||||
interrupt long-running Python code via Ctrl-C. IPython can not pass | ||||
the KeyboardInterrupt exception (or the underlying SIGINT) across | ||||
threads, so any long-running process started from IPython will run to | ||||
completion, or will have to be killed via an external (OS-based) | ||||
mechanism. | ||||
To the best of my knowledge, this limitation is imposed by the Python | ||||
interpreter itself, and it comes from the difficulty of writing | ||||
portable signal/threaded code. If any user is an expert on this topic | ||||
and can suggest a better solution, I would love to hear about it. In | ||||
the IPython sources, look at the Shell.py module, and in particular at | ||||
the runcode() method. | ||||
REGULAR OPTIONS | ||||
After the above threading options have been given, regular options can | ||||
follow in any order. All options can be abbreviated to their shortest | ||||
non-ambiguous form and are case-sensitive. One or two dashes can be | ||||
used. Some options have an alternate short form, indicated after a |. | ||||
Most options can also be set from your ipythonrc configuration file. | ||||
See the provided examples for assistance. Options given on the comman- | ||||
dline override the values set in the ipythonrc file. | ||||
fperez
|
r44 | All options with a [no] prepended can be specified in negated form | ||
(using -nooption instead of -option) to turn the feature off. | ||||
fperez
|
r0 | |||
-h, --help | ||||
Show summary of options. | ||||
-pylab This can only be given as the first option passed to IPython (it | ||||
will have no effect in any other position). It adds special sup- | ||||
port for the matplotlib library (http://matplotlib.source- | ||||
forge.net), allowing interactive usage of any of its backends as | ||||
vivainio
|
r271 | defined in the user's .matplotlibrc file. It automatically | ||
fperez
|
r0 | activates GTK or WX threading for IPyhton if the choice of mat- | ||
plotlib backend requires it. It also modifies the @run command | ||||
to correctly execute (without blocking) any matplotlib-based | ||||
script which calls show() at the end. | ||||
fperez
|
r84 | -autocall <val> | ||
Make IPython automatically call any callable object even if you | ||||
didn't type explicit parentheses. For example, 'str 43' becomes | ||||
'str(43)' automatically. The value can be '0' to disable the | ||||
feature, '1' for 'smart' autocall, where it is not applied if | ||||
there are no more arguments on the line, and '2' for 'full' | ||||
autocall, where all callable objects are automatically called | ||||
(even if no arguments are present). The default is '1'. | ||||
fperez
|
r0 | |||
fperez
|
r44 | -[no]autoindent | ||
fperez
|
r0 | Turn automatic indentation on/off. | ||
fperez
|
r44 | -[no]automagic | ||
fperez
|
r0 | Make magic commands automatic (without needing their first char- | ||
fperez
|
r54 | acter to be %). Type %magic at the IPython prompt for more | ||
fperez
|
r0 | information. | ||
fperez
|
r54 | -[no]autoedit_syntax | ||
When a syntax error occurs after editing a file, automatically | ||||
open the file to the trouble causing line for convenient fixing. | ||||
fperez
|
r0 | |||
fperez
|
r44 | -[no]banner | ||
fperez
|
r0 | Print the intial information banner (default on). | ||
-c <command> | ||||
vivainio
|
r271 | Execute the given command string, and set sys.argv to ['c']. | ||
fperez
|
r0 | This is similar to the -c option in the normal Python inter- | ||
preter. | ||||
-cache_size|cs <n> | ||||
Size of the output cache (maximum number of entries to hold in | ||||
memory). The default is 1000, you can change it permanently in | ||||
your config file. Setting it to 0 completely disables the | ||||
caching system, and the minimum value accepted is 20 (if you | ||||
provide a value less than 20, it is reset to 0 and a warning is | ||||
vivainio
|
r271 | issued). This limit is defined because otherwise you'll spend | ||
fperez
|
r0 | more time re-flushing a too small cache than working. | ||
-classic|cl | ||||
Gives IPython a similar feel to the classic Python prompt. | ||||
-colors <scheme> | ||||
Color scheme for prompts and exception reporting. Currently | ||||
implemented: NoColor, Linux, and LightBG. | ||||
fperez
|
r44 | -[no]color_info | ||
fperez
|
r0 | IPython can display information about objects via a set of func- | ||
tions, and optionally can use colors for this, syntax highlight- | ||||
ing source code and various other elements. However, because | ||||
vivainio
|
r271 | this information is passed through a pager (like 'less') and | ||
fperez
|
r0 | many pagers get confused with color codes, this option is off by | ||
default. You can test it and turn it on permanently in your | ||||
vivainio
|
r271 | ipythonrc file if it works for you. As a reference, the 'less' | ||
fperez
|
r0 | pager supplied with Mandrake 8.2 works ok, but that in RedHat | ||
vivainio
|
r271 | 7.2 doesn't. | ||
fperez
|
r0 | |||
Test it and turn it on permanently if it works with your system. | ||||
The magic function @color_info allows you to toggle this inter- | ||||
actively for testing. | ||||
fperez
|
r44 | -[no]confirm_exit | ||
fperez
|
r0 | Set to confirm when you try to exit IPython with an EOF (Con- | ||
trol-D in Unix, Control-Z/Enter in Windows). Note that using the | ||||
magic functions @Exit or @Quit you can force a direct exit, | ||||
bypassing any confirmation. | ||||
fperez
|
r44 | -[no]debug | ||
fperez
|
r0 | Show information about the loading process. Very useful to pin | ||
down problems with your configuration files or to get details | ||||
about session restores. | ||||
fperez
|
r44 | -[no]deep_reload | ||
fperez
|
r0 | IPython can use the deep_reload module which reloads changes in | ||
modules recursively (it replaces the reload() function, so you | ||||
vivainio
|
r271 | don't need to change anything to use it). deep_reload() forces a | ||
fperez
|
r0 | full reload of modules whose code may have changed, which the | ||
default reload() function does not. | ||||
When deep_reload is off, IPython will use the normal reload(), | ||||
but deep_reload will still be available as dreload(). This fea- | ||||
ture is off by default [which means that you have both normal | ||||
reload() and dreload()]. | ||||
-editor <name> | ||||
Which editor to use with the @edit command. By default, IPython | ||||
will honor your EDITOR environment variable (if not set, vi is | ||||
the Unix default and notepad the Windows one). Since this editor | ||||
is invoked on the fly by IPython and is meant for editing small | ||||
code snippets, you may want to use a small, lightweight editor | ||||
here (in case your default EDITOR is something like Emacs). | ||||
-ipythondir <name> | ||||
The name of your IPython configuration directory IPYTHONDIR. | ||||
This can also be specified through the environment variable | ||||
IPYTHONDIR. | ||||
fperez
|
r60 | -log|l Generate a log file of all input. The file is named | ||
ipython_log.py in your current directory (which prevents logs | ||||
from multiple IPython sessions from trampling each other). You | ||||
can use this to later restore a session by loading your logfile | ||||
as a file to be executed with option -logplay (see below). | ||||
fperez
|
r0 | |||
-logfile|lf | ||||
fperez
|
r60 | Specify the name of your logfile. | ||
fperez
|
r0 | |||
-logplay|lp | ||||
Replay a previous log. For restoring a session as close as pos- | ||||
vivainio
|
r271 | sible to the state you left it in, use this option (don't just | ||
fperez
|
r0 | run the logfile). With -logplay, IPython will try to reconstruct | ||
the previous working environment in full, not just execute the | ||||
commands in the logfile. | ||||
When a session is restored, logging is automatically turned on | ||||
again with the name of the logfile it was invoked with (it is | ||||
vivainio
|
r271 | read from the log header). So once you've turned logging on for | ||
fperez
|
r0 | a session, you can quit IPython and reload it as many times as | ||
you want and it will continue to log its history and restore | ||||
from the beginning every time. | ||||
Caveats: there are limitations in this option. The history vari- | ||||
vivainio
|
r271 | ables _i*,_* and _dh don't get restored properly. In the future | ||
fperez
|
r0 | we will try to implement full session saving by writing and | ||
vivainio
|
r271 | retrieving a failed because of inherent limitations of Python's | ||
fperez
|
r0 | Pickle module, so this may have to wait. | ||
fperez
|
r44 | -[no]messages | ||
fperez
|
r0 | Print messages which IPython collects about its startup process | ||
(default on). | ||||
fperez
|
r44 | -[no]pdb | ||
fperez
|
r0 | Automatically call the pdb debugger after every uncaught excep- | ||
tion. If you are used to debugging using pdb, this puts you | ||||
automatically inside of it after any call (either in IPython or | ||||
in code called by it) which triggers an exception which goes | ||||
uncaught. | ||||
fperez
|
r44 | -[no]pprint | ||
fperez
|
r0 | IPython can optionally use the pprint (pretty printer) module | ||
for displaying results. pprint tends to give a nicer display of | ||||
nested data structures. If you like it, you can turn it on per- | ||||
manently in your config file (default off). | ||||
-profile|p <name> | ||||
Assume that your config file is ipythonrc-<name> (looks in cur- | ||||
rent dir first, then in IPYTHONDIR). This is a quick way to keep | ||||
and load multiple config files for different tasks, especially | ||||
if you use the include option of config files. You can keep a | ||||
vivainio
|
r271 | basic IPYTHONDIR/ipythonrc file and then have other 'profiles' | ||
fperez
|
r0 | which include this one and load extra things for particular | ||
tasks. For example: | ||||
1) $HOME/.ipython/ipythonrc : load basic things you always want. | ||||
2) $HOME/.ipython/ipythonrc-math : load (1) and basic math- | ||||
related modules. | ||||
3) $HOME/.ipython/ipythonrc-numeric : load (1) and Numeric and | ||||
plotting modules. | ||||
Since it is possible to create an endless loop by having circu- | ||||
lar file inclusions, IPython will stop if it reaches 15 recur- | ||||
sive inclusions. | ||||
-prompt_in1|pi1 <string> | ||||
Specify the string used for input prompts. Note that if you are | ||||
vivainio
|
r271 | using numbered prompts, the number is represented with a '\#' in | ||
the string. Don't forget to quote strings with spaces embedded | ||||
fperez
|
r302 | in them. Default: 'In [\#]: '. | ||
fperez
|
r0 | |||
vivainio
|
r271 | Most bash-like escapes can be used to customize IPython's | ||
fperez
|
r0 | prompts, as well as a few additional ones which are IPython-spe- | ||
cific. All valid prompt escapes are described in detail in the | ||||
Customization section of the IPython HTML/PDF manual. | ||||
-prompt_in2|pi2 <string> | ||||
fperez
|
r302 | Similar to the previous option, but used for the continuation | ||
prompts. The special sequence '\D' is similar to '\#', but with | ||||
all digits replaced dots (so you can have your continuation | ||||
prompt aligned with your input prompt). Default: ' .\D.: ' | ||||
vivainio
|
r271 | (note three spaces at the start for alignment with 'In [\#]'). | ||
fperez
|
r0 | |||
-prompt_out|po <string> | ||||
String used for output prompts, also uses numbers like | ||||
vivainio
|
r271 | prompt_in1. Default: 'Out[\#]:'. | ||
fperez
|
r0 | |||
-quick Start in bare bones mode (no config file loaded). | ||||
-rcfile <name> | ||||
Name of your IPython resource configuration file. normally | ||||
IPython loads ipythonrc (from current directory) or | ||||
IPYTHONDIR/ipythonrc. If the loading of your config file fails, | ||||
IPython starts with a bare bones configuration (no modules | ||||
loaded at all). | ||||
fperez
|
r44 | -[no]readline | ||
fperez
|
r0 | Use the readline library, which is needed to support name com- | ||
pletion and command history, among other things. It is enabled | ||||
by default, but may cause problems for users of X/Emacs in | ||||
Python comint or shell buffers. | ||||
vivainio
|
r271 | Note that emacs 'eterm' buffers (opened with M-x term) support | ||
IPython's readline and syntax coloring fine, only 'emacs' (M-x | ||||
fperez
|
r0 | shell and C-c !) buffers do not. | ||
-screen_length|sl <n> | ||||
Number of lines of your screen. This is used to control print- | ||||
ing of very long strings. Strings longer than this number of | ||||
lines will be sent through a pager instead of directly printed. | ||||
The default value for this is 0, which means IPython will auto- | ||||
detect your screen size every time it needs to print certain | ||||
vivainio
|
r271 | potentially long strings (this doesn't change the behavior of | ||
the 'print' keyword, it's only triggered internally). If for | ||||
some reason this isn't working well (it needs curses support), | ||||
specify it yourself. Otherwise don't change the default. | ||||
fperez
|
r0 | |||
-separate_in|si <string> | ||||
vivainio
|
r271 | Separator before input prompts. Default '0. | ||
fperez
|
r0 | |||
-separate_out|so <string> | ||||
Separator before output prompts. Default: 0 (nothing). | ||||
-separate_out2|so2 <string> | ||||
Separator after output prompts. Default: 0 (nothing). | ||||
vivainio
|
r271 | -nosep Shorthand for '-separate_in 0 -separate_out 0 -separate_out2 0'. | ||
fperez
|
r0 | Simply removes all input/output separators. | ||
-upgrade | ||||
Allows you to upgrade your IPYTHONDIR configuration when you | ||||
install a new version of IPython. Since new versions may | ||||
include new command lines options or example files, this copies | ||||
updated ipythonrc-type files. However, it backs up (with a .old | ||||
extension) all files which it overwrites so that you can merge | ||||
back any custimizations you might have in your personal files. | ||||
-Version | ||||
Print version information and exit. | ||||
fperez
|
r91 | -wxversion <string> | ||
Select a specific version of wxPython (used in conjunction with | ||||
-wthread). Requires the wxversion module, part of recent | ||||
wxPython distributions. | ||||
fperez
|
r0 | -xmode <modename> | ||
Mode for exception reporting. The valid modes are Plain, Con- | ||||
text, and Verbose. | ||||
vivainio
|
r271 | - Plain: similar to python's normal traceback printing. | ||
fperez
|
r0 | |||
- Context: prints 5 lines of context source code around each | ||||
line in the traceback. | ||||
- Verbose: similar to Context, but additionally prints the vari- | ||||
ables currently visible where the exception happened (shortening | ||||
their strings if too long). This can potentially be very slow, | ||||
if you happen to have a huge data structure whose string repre- | ||||
sentation is complex to compute. Your computer may appear to | ||||
freeze for a while with cpu usage at 100%. If this occurs, you | ||||
can cancel the traceback with Ctrl-C (maybe hitting it more than | ||||
once). | ||||
EMBEDDING | ||||
It is possible to start an IPython instance inside your own Python pro- | ||||
grams. In the documentation example files there are some illustrations | ||||
on how to do this. | ||||
This feature allows you to evalutate dynamically the state of your | ||||
code, operate with your variables, analyze them, etc. Note however | ||||
that any changes you make to values while in the shell do NOT propagate | ||||
back to the running code, so it is safe to modify your values because | ||||
vivainio
|
r271 | you won't break your code in bizarre ways by doing so. | ||
fperez
|
r0 | """ | ||
cmd_line_usage = __doc__ | ||||
#--------------------------------------------------------------------------- | ||||
interactive_usage = """ | ||||
IPython -- An enhanced Interactive Python | ||||
========================================= | ||||
IPython offers a combination of convenient shell features, special commands | ||||
and a history mechanism for both input (command history) and output (results | ||||
caching, similar to Mathematica). It is intended to be a fully compatible | ||||
replacement for the standard Python interpreter, while offering vastly | ||||
improved functionality and flexibility. | ||||
At your system command line, type 'ipython -help' to see the command line | ||||
options available. This document only describes interactive features. | ||||
Warning: IPython relies on the existence of a global variable called __IP which | ||||
controls the shell itself. If you redefine __IP to anything, bizarre behavior | ||||
will quickly occur. | ||||
MAIN FEATURES | ||||
* Access to the standard Python help. As of Python 2.1, a help system is | ||||
available with access to object docstrings and the Python manuals. Simply | ||||
type 'help' (no quotes) to access it. | ||||
* Magic commands: type %magic for information on the magic subsystem. | ||||
* System command aliases, via the %alias command or the ipythonrc config file. | ||||
* Dynamic object information: | ||||
Typing ?word or word? prints detailed information about an object. If | ||||
certain strings in the object are too long (docstrings, code, etc.) they get | ||||
snipped in the center for brevity. | ||||
Typing ??word or word?? gives access to the full information without | ||||
snipping long strings. Long strings are sent to the screen through the less | ||||
pager if longer than the screen, printed otherwise. | ||||
The ?/?? system gives access to the full source code for any object (if | ||||
available), shows function prototypes and other useful information. | ||||
If you just want to see an object's docstring, type '%pdoc object' (without | ||||
quotes, and without % if you have automagic on). | ||||
Both %pdoc and ?/?? give you access to documentation even on things which are | ||||
not explicitely defined. Try for example typing {}.get? or after import os, | ||||
type os.path.abspath??. The magic functions %pdef, %source and %file operate | ||||
similarly. | ||||
* Completion in the local namespace, by typing TAB at the prompt. | ||||
At any time, hitting tab will complete any available python commands or | ||||
variable names, and show you a list of the possible completions if there's | ||||
no unambiguous one. It will also complete filenames in the current directory. | ||||
This feature requires the readline and rlcomplete modules, so it won't work | ||||
if your Python lacks readline support (such as under Windows). | ||||
* Search previous command history in two ways (also requires readline): | ||||
- Start typing, and then use Ctrl-p (previous,up) and Ctrl-n (next,down) to | ||||
search through only the history items that match what you've typed so | ||||
far. If you use Ctrl-p/Ctrl-n at a blank prompt, they just behave like | ||||
normal arrow keys. | ||||
- Hit Ctrl-r: opens a search prompt. Begin typing and the system searches | ||||
your history for lines that match what you've typed so far, completing as | ||||
much as it can. | ||||
* Persistent command history across sessions (readline required). | ||||
* Logging of input with the ability to save and restore a working session. | ||||
* System escape with !. Typing !ls will run 'ls' in the current directory. | ||||
* The reload command does a 'deep' reload of a module: changes made to the | ||||
module since you imported will actually be available without having to exit. | ||||
* Verbose and colored exception traceback printouts. See the magic xmode and | ||||
xcolor functions for details (just type %magic). | ||||
* Input caching system: | ||||
IPython offers numbered prompts (In/Out) with input and output caching. All | ||||
input is saved and can be retrieved as variables (besides the usual arrow | ||||
key recall). | ||||
The following GLOBAL variables always exist (so don't overwrite them!): | ||||
_i: stores previous input. | ||||
_ii: next previous. | ||||
_iii: next-next previous. | ||||
_ih : a list of all input _ih[n] is the input from line n. | ||||
Additionally, global variables named _i<n> are dynamically created (<n> | ||||
being the prompt counter), such that _i<n> == _ih[<n>] | ||||
For example, what you typed at prompt 14 is available as _i14 and _ih[14]. | ||||
You can create macros which contain multiple input lines from this history, | ||||
for later re-execution, with the %macro function. | ||||
The history function %hist allows you to see any part of your input history | ||||
by printing a range of the _i variables. Note that inputs which contain | ||||
magic functions (%) appear in the history with a prepended comment. This is | ||||
because they aren't really valid Python code, so you can't exec them. | ||||
* Output caching system: | ||||
For output that is returned from actions, a system similar to the input | ||||
cache exists but using _ instead of _i. Only actions that produce a result | ||||
(NOT assignments, for example) are cached. If you are familiar with | ||||
Mathematica, IPython's _ variables behave exactly like Mathematica's % | ||||
variables. | ||||
The following GLOBAL variables always exist (so don't overwrite them!): | ||||
_ (one underscore): previous output. | ||||
__ (two underscores): next previous. | ||||
___ (three underscores): next-next previous. | ||||
Global variables named _<n> are dynamically created (<n> being the prompt | ||||
counter), such that the result of output <n> is always available as _<n>. | ||||
Finally, a global dictionary named _oh exists with entries for all lines | ||||
which generated output. | ||||
* Directory history: | ||||
Your history of visited directories is kept in the global list _dh, and the | ||||
magic %cd command can be used to go to any entry in that list. | ||||
* Auto-parentheses and auto-quotes (adapted from Nathan Gray's LazyPython) | ||||
1. Auto-parentheses | ||||
Callable objects (i.e. functions, methods, etc) can be invoked like | ||||
this (notice the commas between the arguments): | ||||
>>> callable_ob arg1, arg2, arg3 | ||||
and the input will be translated to this: | ||||
--> callable_ob(arg1, arg2, arg3) | ||||
You can force auto-parentheses by using '/' as the first character | ||||
of a line. For example: | ||||
>>> /globals # becomes 'globals()' | ||||
Note that the '/' MUST be the first character on the line! This | ||||
won't work: | ||||
>>> print /globals # syntax error | ||||
In most cases the automatic algorithm should work, so you should | ||||
rarely need to explicitly invoke /. One notable exception is if you | ||||
are trying to call a function with a list of tuples as arguments (the | ||||
parenthesis will confuse IPython): | ||||
In [1]: zip (1,2,3),(4,5,6) # won't work | ||||
but this will work: | ||||
In [2]: /zip (1,2,3),(4,5,6) | ||||
------> zip ((1,2,3),(4,5,6)) | ||||
Out[2]= [(1, 4), (2, 5), (3, 6)] | ||||
IPython tells you that it has altered your command line by | ||||
displaying the new command line preceded by -->. e.g.: | ||||
In [18]: callable list | ||||
-------> callable (list) | ||||
2. Auto-Quoting | ||||
You can force auto-quoting of a function's arguments by using ',' as | ||||
the first character of a line. For example: | ||||
>>> ,my_function /home/me # becomes my_function("/home/me") | ||||
If you use ';' instead, the whole argument is quoted as a single | ||||
string (while ',' splits on whitespace): | ||||
>>> ,my_function a b c # becomes my_function("a","b","c") | ||||
>>> ;my_function a b c # becomes my_function("a b c") | ||||
Note that the ',' MUST be the first character on the line! This | ||||
won't work: | ||||
>>> x = ,my_function /home/me # syntax error | ||||
""" | ||||
vivainio
|
r154 | |||
quick_reference = r""" | ||||
IPython -- An enhanced Interactive Python - Quick Reference Card | ||||
================================================================ | ||||
obj?, obj??, ?obj,??obj : Get help, or more help for object | ||||
?os.p* : List names in os starting with p | ||||
vivainio
|
r824 | Magic functions are prefixed by %, and typically take their arguments without | ||
parentheses, quotes or even commas for convenience. | ||||
Example magic function calls: | ||||
vivainio
|
r154 | %alias d ls -F : 'd' is now an alias for 'ls -F' | ||
alias d ls -F : Works if 'alias' not a python name | ||||
alist = %alias : Get list of aliases to 'alist' | ||||
vivainio
|
r824 | cd /usr/share : Obvious. cd -<tab> to choose from visited dirs. | ||
%cd?? : See help AND source for magic %cd | ||||
vivainio
|
r154 | |||
System commands: | ||||
!cp a.txt b/ : System command escape, calls os.system() | ||||
vivainio
|
r203 | cp a.txt b/ : after %rehashx, most system commands work without ! | ||
vivainio
|
r154 | cp ${f}.txt $bar : Variable expansion in magics and system commands | ||
vivainio
|
r203 | files = !ls /usr : Capture sytem command output | ||
vivainio
|
r154 | files.s, files.l, files.n: "a b c", ['a','b','c'], 'a\nb\nc' | ||
History: | ||||
_i, _ii, _iii : Previous, next previous, next next previous input | ||||
vivainio
|
r503 | _i4, _ih[2:5] : Input history line 4, lines 2-4 | ||
exec _i81 : Execute input history line #81 again | ||||
vivainio
|
r811 | %rep 81 : Edit input history line #81 | ||
vivainio
|
r154 | _, __, ___ : previous, next previous, next next previous output | ||
_dh : Directory history | ||||
_oh : Output history | ||||
vivainio
|
r824 | %hist : Command history. '%hist -g foo' search history for 'foo' | ||
vivainio
|
r154 | |||
Autocall: | ||||
vivainio
|
r203 | f 1,2 : f(1,2) | ||
/f 1,2 : f(1,2) (forced autoparen) | ||||
vivainio
|
r154 | ,f 1 2 : f("1","2") | ||
;f 1 2 : f("1 2") | ||||
vivainio
|
r824 | Remember: TAB completion works in many contexts, not just file names | ||
or python names. | ||||
The following magic functions are currently available: | ||||
vivainio
|
r154 | """ | ||