##// END OF EJS Templates
Backport PR #13225: Fix quick reference documentation for 'exec'
Matthias Bussonnier -
Show More
@@ -1,341 +1,341 b''
1 1 # -*- coding: utf-8 -*-
2 2 """Usage information for the main IPython applications.
3 3 """
4 4 #-----------------------------------------------------------------------------
5 5 # Copyright (C) 2008-2011 The IPython Development Team
6 6 # Copyright (C) 2001-2007 Fernando Perez. <fperez@colorado.edu>
7 7 #
8 8 # Distributed under the terms of the BSD License. The full license is in
9 9 # the file COPYING, distributed as part of this software.
10 10 #-----------------------------------------------------------------------------
11 11
12 12 import sys
13 13 from IPython.core import release
14 14
15 15 cl_usage = """\
16 16 =========
17 17 IPython
18 18 =========
19 19
20 20 Tools for Interactive Computing in Python
21 21 =========================================
22 22
23 23 A Python shell with automatic history (input and output), dynamic object
24 24 introspection, easier configuration, command completion, access to the
25 25 system shell and more. IPython can also be embedded in running programs.
26 26
27 27
28 28 Usage
29 29
30 30 ipython [subcommand] [options] [-c cmd | -m mod | file] [--] [arg] ...
31 31
32 32 If invoked with no options, it executes the file and exits, passing the
33 33 remaining arguments to the script, just as if you had specified the same
34 34 command with python. You may need to specify `--` before args to be passed
35 35 to the script, to prevent IPython from attempting to parse them. If you
36 36 specify the option `-i` before the filename, it will enter an interactive
37 37 IPython session after running the script, rather than exiting. Files ending
38 38 in .py will be treated as normal Python, but files ending in .ipy can
39 39 contain special IPython syntax (magic commands, shell expansions, etc.).
40 40
41 41 Almost all configuration in IPython is available via the command-line. Do
42 42 `ipython --help-all` to see all available options. For persistent
43 43 configuration, look into your `ipython_config.py` configuration file for
44 44 details.
45 45
46 46 This file is typically installed in the `IPYTHONDIR` directory, and there
47 47 is a separate configuration directory for each profile. The default profile
48 48 directory will be located in $IPYTHONDIR/profile_default. IPYTHONDIR
49 49 defaults to to `$HOME/.ipython`. For Windows users, $HOME resolves to
50 50 C:\\Users\\YourUserName in most instances.
51 51
52 52 To initialize a profile with the default configuration file, do::
53 53
54 54 $> ipython profile create
55 55
56 56 and start editing `IPYTHONDIR/profile_default/ipython_config.py`
57 57
58 58 In IPython's documentation, we will refer to this directory as
59 59 `IPYTHONDIR`, you can change its default location by creating an
60 60 environment variable with this name and setting it to the desired path.
61 61
62 62 For more information, see the manual available in HTML and PDF in your
63 63 installation, or online at https://ipython.org/documentation.html.
64 64 """
65 65
66 66 interactive_usage = """
67 67 IPython -- An enhanced Interactive Python
68 68 =========================================
69 69
70 70 IPython offers a fully compatible replacement for the standard Python
71 71 interpreter, with convenient shell features, special commands, command
72 72 history mechanism and output results caching.
73 73
74 74 At your system command line, type 'ipython -h' to see the command line
75 75 options available. This document only describes interactive features.
76 76
77 77 GETTING HELP
78 78 ------------
79 79
80 80 Within IPython you have various way to access help:
81 81
82 82 ? -> Introduction and overview of IPython's features (this screen).
83 83 object? -> Details about 'object'.
84 84 object?? -> More detailed, verbose information about 'object'.
85 85 %quickref -> Quick reference of all IPython specific syntax and magics.
86 86 help -> Access Python's own help system.
87 87
88 88 If you are in terminal IPython you can quit this screen by pressing `q`.
89 89
90 90
91 91 MAIN FEATURES
92 92 -------------
93 93
94 94 * Access to the standard Python help with object docstrings and the Python
95 95 manuals. Simply type 'help' (no quotes) to invoke it.
96 96
97 97 * Magic commands: type %magic for information on the magic subsystem.
98 98
99 99 * System command aliases, via the %alias command or the configuration file(s).
100 100
101 101 * Dynamic object information:
102 102
103 103 Typing ?word or word? prints detailed information about an object. Certain
104 104 long strings (code, etc.) get snipped in the center for brevity.
105 105
106 106 Typing ??word or word?? gives access to the full information without
107 107 snipping long strings. Strings that are longer than the screen are printed
108 108 through the less pager.
109 109
110 110 The ?/?? system gives access to the full source code for any object (if
111 111 available), shows function prototypes and other useful information.
112 112
113 113 If you just want to see an object's docstring, type '%pdoc object' (without
114 114 quotes, and without % if you have automagic on).
115 115
116 116 * Tab completion in the local namespace:
117 117
118 118 At any time, hitting tab will complete any available python commands or
119 119 variable names, and show you a list of the possible completions if there's
120 120 no unambiguous one. It will also complete filenames in the current directory.
121 121
122 122 * Search previous command history in multiple ways:
123 123
124 124 - Start typing, and then use arrow keys up/down or (Ctrl-p/Ctrl-n) to search
125 125 through the history items that match what you've typed so far.
126 126
127 127 - Hit Ctrl-r: opens a search prompt. Begin typing and the system searches
128 128 your history for lines that match what you've typed so far, completing as
129 129 much as it can.
130 130
131 131 - %hist: search history by index.
132 132
133 133 * Persistent command history across sessions.
134 134
135 135 * Logging of input with the ability to save and restore a working session.
136 136
137 137 * System shell with !. Typing !ls will run 'ls' in the current directory.
138 138
139 139 * The reload command does a 'deep' reload of a module: changes made to the
140 140 module since you imported will actually be available without having to exit.
141 141
142 142 * Verbose and colored exception traceback printouts. See the magic xmode and
143 143 xcolor functions for details (just type %magic).
144 144
145 145 * Input caching system:
146 146
147 147 IPython offers numbered prompts (In/Out) with input and output caching. All
148 148 input is saved and can be retrieved as variables (besides the usual arrow
149 149 key recall).
150 150
151 151 The following GLOBAL variables always exist (so don't overwrite them!):
152 152 _i: stores previous input.
153 153 _ii: next previous.
154 154 _iii: next-next previous.
155 155 _ih : a list of all input _ih[n] is the input from line n.
156 156
157 157 Additionally, global variables named _i<n> are dynamically created (<n>
158 158 being the prompt counter), such that _i<n> == _ih[<n>]
159 159
160 160 For example, what you typed at prompt 14 is available as _i14 and _ih[14].
161 161
162 162 You can create macros which contain multiple input lines from this history,
163 163 for later re-execution, with the %macro function.
164 164
165 165 The history function %hist allows you to see any part of your input history
166 166 by printing a range of the _i variables. Note that inputs which contain
167 167 magic functions (%) appear in the history with a prepended comment. This is
168 168 because they aren't really valid Python code, so you can't exec them.
169 169
170 170 * Output caching system:
171 171
172 172 For output that is returned from actions, a system similar to the input
173 173 cache exists but using _ instead of _i. Only actions that produce a result
174 174 (NOT assignments, for example) are cached. If you are familiar with
175 175 Mathematica, IPython's _ variables behave exactly like Mathematica's %
176 176 variables.
177 177
178 178 The following GLOBAL variables always exist (so don't overwrite them!):
179 179 _ (one underscore): previous output.
180 180 __ (two underscores): next previous.
181 181 ___ (three underscores): next-next previous.
182 182
183 183 Global variables named _<n> are dynamically created (<n> being the prompt
184 184 counter), such that the result of output <n> is always available as _<n>.
185 185
186 186 Finally, a global dictionary named _oh exists with entries for all lines
187 187 which generated output.
188 188
189 189 * Directory history:
190 190
191 191 Your history of visited directories is kept in the global list _dh, and the
192 192 magic %cd command can be used to go to any entry in that list.
193 193
194 194 * Auto-parentheses and auto-quotes (adapted from Nathan Gray's LazyPython)
195 195
196 196 1. Auto-parentheses
197 197
198 198 Callable objects (i.e. functions, methods, etc) can be invoked like
199 199 this (notice the commas between the arguments)::
200 200
201 201 In [1]: callable_ob arg1, arg2, arg3
202 202
203 203 and the input will be translated to this::
204 204
205 205 callable_ob(arg1, arg2, arg3)
206 206
207 207 This feature is off by default (in rare cases it can produce
208 208 undesirable side-effects), but you can activate it at the command-line
209 209 by starting IPython with `--autocall 1`, set it permanently in your
210 210 configuration file, or turn on at runtime with `%autocall 1`.
211 211
212 212 You can force auto-parentheses by using '/' as the first character
213 213 of a line. For example::
214 214
215 215 In [1]: /globals # becomes 'globals()'
216 216
217 217 Note that the '/' MUST be the first character on the line! This
218 218 won't work::
219 219
220 220 In [2]: print /globals # syntax error
221 221
222 222 In most cases the automatic algorithm should work, so you should
223 223 rarely need to explicitly invoke /. One notable exception is if you
224 224 are trying to call a function with a list of tuples as arguments (the
225 225 parenthesis will confuse IPython)::
226 226
227 227 In [1]: zip (1,2,3),(4,5,6) # won't work
228 228
229 229 but this will work::
230 230
231 231 In [2]: /zip (1,2,3),(4,5,6)
232 232 ------> zip ((1,2,3),(4,5,6))
233 233 Out[2]= [(1, 4), (2, 5), (3, 6)]
234 234
235 235 IPython tells you that it has altered your command line by
236 236 displaying the new command line preceded by -->. e.g.::
237 237
238 238 In [18]: callable list
239 239 -------> callable (list)
240 240
241 241 2. Auto-Quoting
242 242
243 243 You can force auto-quoting of a function's arguments by using ',' as
244 244 the first character of a line. For example::
245 245
246 246 In [1]: ,my_function /home/me # becomes my_function("/home/me")
247 247
248 248 If you use ';' instead, the whole argument is quoted as a single
249 249 string (while ',' splits on whitespace)::
250 250
251 251 In [2]: ,my_function a b c # becomes my_function("a","b","c")
252 252 In [3]: ;my_function a b c # becomes my_function("a b c")
253 253
254 254 Note that the ',' MUST be the first character on the line! This
255 255 won't work::
256 256
257 257 In [4]: x = ,my_function /home/me # syntax error
258 258 """
259 259
260 260 interactive_usage_min = """\
261 261 An enhanced console for Python.
262 262 Some of its features are:
263 263 - Tab completion in the local namespace.
264 264 - Logging of input, see command-line options.
265 265 - System shell escape via ! , eg !ls.
266 266 - Magic commands, starting with a % (like %ls, %pwd, %cd, etc.)
267 267 - Keeps track of locally defined variables via %who, %whos.
268 268 - Show object information with a ? eg ?x or x? (use ?? for more info).
269 269 """
270 270
271 271 quick_reference = r"""
272 272 IPython -- An enhanced Interactive Python - Quick Reference Card
273 273 ================================================================
274 274
275 275 obj?, obj?? : Get help, or more help for object (also works as
276 276 ?obj, ??obj).
277 277 ?foo.*abc* : List names in 'foo' containing 'abc' in them.
278 278 %magic : Information about IPython's 'magic' % functions.
279 279
280 280 Magic functions are prefixed by % or %%, and typically take their arguments
281 281 without parentheses, quotes or even commas for convenience. Line magics take a
282 282 single % and cell magics are prefixed with two %%.
283 283
284 284 Example magic function calls:
285 285
286 286 %alias d ls -F : 'd' is now an alias for 'ls -F'
287 287 alias d ls -F : Works if 'alias' not a python name
288 288 alist = %alias : Get list of aliases to 'alist'
289 289 cd /usr/share : Obvious. cd -<tab> to choose from visited dirs.
290 290 %cd?? : See help AND source for magic %cd
291 291 %timeit x=10 : time the 'x=10' statement with high precision.
292 292 %%timeit x=2**100
293 293 x**100 : time 'x**100' with a setup of 'x=2**100'; setup code is not
294 294 counted. This is an example of a cell magic.
295 295
296 296 System commands:
297 297
298 298 !cp a.txt b/ : System command escape, calls os.system()
299 299 cp a.txt b/ : after %rehashx, most system commands work without !
300 300 cp ${f}.txt $bar : Variable expansion in magics and system commands
301 301 files = !ls /usr : Capture system command output
302 302 files.s, files.l, files.n: "a b c", ['a','b','c'], 'a\nb\nc'
303 303
304 304 History:
305 305
306 306 _i, _ii, _iii : Previous, next previous, next next previous input
307 307 _i4, _ih[2:5] : Input history line 4, lines 2-4
308 exec _i81 : Execute input history line #81 again
308 exec(_i81) : Execute input history line #81 again
309 309 %rep 81 : Edit input history line #81
310 310 _, __, ___ : previous, next previous, next next previous output
311 311 _dh : Directory history
312 312 _oh : Output history
313 313 %hist : Command history of current session.
314 314 %hist -g foo : Search command history of (almost) all sessions for 'foo'.
315 315 %hist -g : Command history of (almost) all sessions.
316 316 %hist 1/2-8 : Command history containing lines 2-8 of session 1.
317 317 %hist 1/ ~2/ : Command history of session 1 and 2 sessions before current.
318 318 %hist ~8/1-~6/5 : Command history from line 1 of 8 sessions ago to
319 319 line 5 of 6 sessions ago.
320 320 %edit 0/ : Open editor to execute code with history of current session.
321 321
322 322 Autocall:
323 323
324 324 f 1,2 : f(1,2) # Off by default, enable with %autocall magic.
325 325 /f 1,2 : f(1,2) (forced autoparen)
326 326 ,f 1 2 : f("1","2")
327 327 ;f 1 2 : f("1 2")
328 328
329 329 Remember: TAB completion works in many contexts, not just file names
330 330 or python names.
331 331
332 332 The following magic functions are currently available:
333 333
334 334 """
335 335
336 336 default_banner_parts = ["Python %s\n"%sys.version.split("\n")[0],
337 337 "Type 'copyright', 'credits' or 'license' for more information\n" ,
338 338 "IPython {version} -- An enhanced Interactive Python. Type '?' for help.\n".format(version=release.version),
339 339 ]
340 340
341 341 default_banner = ''.join(default_banner_parts)
General Comments 0
You need to be logged in to leave comments. Login now