{ "metadata": { "name": "", "signature": "sha256:2ee198570cab9f1784cf9171922e35c844f43331d9224e8979a52e7fbab030af" }, "nbformat": 3, "nbformat_minor": 0, "worksheets": [ { "cells": [ { "cell_type": "heading", "level": 1, "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "IPython and IPython Notebook" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "IPython is \"**an enhanced Interactive Python shell**\". IPython is elegant and has extensively useful features. Some of the thoughtfully crafted ones include tab completion, object introspection, a powerful history mechanism, inline editing of source code, integration with the Python debugger, the %run mechanism, macros, the ability to create multiple profiles, and system shell access.\n", "\n", "We will try to address some of them in this Notebook (kind of meta if you think about it) and the later part of the Notebook is going to be focussed on the cool stuff that you can do with the IPython Notebook in specific." ] }, { "cell_type": "code", "collapsed": false, "input": [ "from __future__ import division\n", "\n", "import numpy as np\n", "import scipy as sp\n", "import matplotlib as mpl\n", "import matplotlib.pyplot as plt\n", "\n", "#IPython magic command for inline plotting\n", "%matplotlib inline\n", "#a better plot shape for IPython\n", "mpl.rcParams['figure.figsize']=[15,3]" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "**Terribly useful commands**" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n", "The four most helpful commands, as well as their brief description, is shown to you in a banner, every time you start IPython:\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\n", "\t\n", "
CommandDescription
?Introduction and overview of IPython\u2019s features.
%quickrefQuick reference.
helpPython\u2019s own help system.
object?\tDetails about \u2018object\u2019, use \u2018object??\u2019 for extra details.
\n", "\n" ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Tab Completion" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "A very powerful feature in IPython is tab completion." ] }, { "cell_type": "code", "collapsed": false, "input": [ "xmen='Text'" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "You can use it to autocomplete your variables. Of course, a good Python editor should also be able to this. " ] }, { "cell_type": "code", "collapsed": false, "input": [ "x" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "You can also use this to get attributes of built-in objects " ] }, { "cell_type": "code", "collapsed": false, "input": [ "import struct #This module performs conversions between Python values and C structs represented as Python strings." ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "struct._" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Tab completion also extends to user-defined objects. In order to make your class attributes open to tab completion you would need to define a `__dir__` member method in your class definition. " ] }, { "cell_type": "code", "collapsed": false, "input": [ "class Shout(object):\n", " def __init__(self, text,number):\n", " self.text = text\n", " self.number=number\n", " \n", " def __dir__(self):\n", " return ['text','number']\n" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "s=Shout('Hi',2)" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "s.text" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Another useful trick to use help on an object is to use the **?** . It internally invokes `help()`. Typing object_name? will print all sorts of details about any object, including docstrings, function definition lines (for call arguments) and constructor details for classes." ] }, { "cell_type": "code", "collapsed": false, "input": [ "s?" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Magic command system" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "IPython has a set of predefined **magic functions** that you can call with a command line style syntax. There are two kinds of magics, line-oriented and cell-oriented. Line magics are prefixed with the % character and work much like OS command-line calls: they get as an argument the rest of the line, where arguments are passed without parentheses or quotes. Cell magics are prefixed with a double %%, and they are functions that get as an argument not only the rest of the line, but also the lines below it in a separate argument." ] }, { "cell_type": "code", "collapsed": false, "input": [ "#Line magic\n", "%cd" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "%lsmagic #Lists all magics available" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "%pprint?" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "**%timeit**" ] }, { "cell_type": "code", "collapsed": false, "input": [ "#Line magic\n", "%timeit range(100)" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "%%timeit x = range(100)\n", " min(x)\n", " max(x)\n", "#Cell Magic" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "%%timeit a = np.random.rand(100, 100)\n", "np.linalg.eigvals(a)" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The **%%capture** magic can be used to capture the stdout/err of any block of python code, either to discard it (if it's noise to you) or to store it in a variable for later use:" ] }, { "cell_type": "code", "collapsed": false, "input": [ "%%capture capt\n", "from __future__ import print_function\n", "import sys\n", "print('Hello stdout')\n", "print('and stderr', file=sys.stderr)" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "capt.stdout, capt.stderr" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "capt.show()" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The **%%writefile** magic writes the cell contents as a named file:" ] }, { "cell_type": "code", "collapsed": false, "input": [ "%%writefile foo.py\n", "print('Hello world')" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Now you can use the **%run** command to run your aforewritten script." ] }, { "cell_type": "code", "collapsed": false, "input": [ "%run foo.py" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "**%%script** cell magic, which lets you run a cell in a subprocess of any interpreter on your system, such as: bash, ruby, perl, zsh, R, etc.\n" ] }, { "cell_type": "code", "collapsed": false, "input": [ "%%script python\n", "import sys\n", "print 'hello from Python %s' % sys.version" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "%%script bash\n", "echo \"hello from $BASH\"" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "%%bash\n", "echo \"hello from $BASH\"" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "!echo \"hello from $BASH\"" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "---\n", "**Exercise**\n", "\n", "Using the magic commands,\n", "\n", "- write a python script to find the average of an array of [1,2,...100] \n", "- save it into a Python script \n", "- execute the saved script." ] }, { "cell_type": "code", "collapsed": false, "input": [], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "---\n", "**%who** and **%whos** magic functions list objects, functions, etc. that have been added in the current namespace, as well as modules that have been imported. **%who** lists names of such objects, while **%whos** additionally lists type and data information " ] }, { "cell_type": "code", "collapsed": false, "input": [ "%who" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "%whos" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "**%hist** presents a list of the last several input command lines." ] }, { "cell_type": "code", "collapsed": false, "input": [ "%hist" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "**%edit** This will open an editor (whatever the shell variable EDITOR is set to, see above, or vi/vim if no variable is set) containing the specified material, based on what arguments are provided, and will execute that code once the editor is exited. " ] }, { "cell_type": "code", "collapsed": false, "input": [ "%edit #use in IPython shell" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Put the following in that script and close it.\n", "\n", " print (\"Edited Foo\")" ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "IPython's Rich Display System" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Using the `__repr__` command, you can use the following representations in IPython.`__repr__ `is used to print a human readable presentation of an object. In this case it prints the class name and some other attributes. A simple example:\n", "\n", "- HTML\n", "- JSON\n", "- PNG\n", "- JPEG\n", "- SVG\n", "- $\\LaTeX$" ] }, { "cell_type": "heading", "level": 3, "metadata": {}, "source": [ "Display imports" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The `display` function can be used for displaying various representations.Calling display on an object will send all possible representations to the Notebook and the Notebook uses the richest available one." ] }, { "cell_type": "code", "collapsed": false, "input": [ "from IPython.display import display" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "from IPython.display import display_pretty, display_html, display_jpeg, display_png, display_json, display_latex, display_svg" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "**Images**\n" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The `Image` class can be used to display image formats such as JPEG,PNG,SVG etc. " ] }, { "cell_type": "code", "collapsed": false, "input": [ "from IPython.display import Image\n", "i=Image(url='')" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "j=Image(url='https://www.python.org/images/python-logo.gif')" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "i" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "j" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "You can also use `i=Image(file='filename.png')`." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "**Embedding images**" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "By default images are embedded in the Notebook document i.e. available offline. However, it is possible to explicitly tell IPython to store only the link to the image.\n", "\n", "![](http://www.svgopen.org/2003/papers/WhyCompileSvg/myButterfly.png)" ] }, { "cell_type": "code", "collapsed": false, "input": [ "from IPython.display import Image\n", "\n", "# by default Image data are embedded\n", "Embed=Image('http://www.svgopen.org/2003/papers/WhyCompileSvg/myButterfly.png')\n", "\n", "# if kwarg `url` is given, the embedding is assumed to be false\n", "SoftLinked = Image(url='http://www.svgopen.org/2003/papers/WhyCompileSvg/myButterfly.png')" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "Embed" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "SoftLinked" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "**Linking to other Python Files**" ] }, { "cell_type": "code", "collapsed": false, "input": [ "from IPython.display import FileLink, FileLinks\n", "FileLink('coding.ipynb')" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "If you wish to link all the files in your current directory you can use the following command:" ] }, { "cell_type": "code", "collapsed": false, "input": [ "FileLinks('.')" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "**Videos**" ] }, { "cell_type": "code", "collapsed": false, "input": [ "from IPython.display import YouTubeVideo\n", "# a talk about IPython at Sage Days at U. Washington, Seattle.\n", "# Video credit: William Stein.\n", "YouTubeVideo('Fi30zjQhtWY')" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "YouTubeVideo('Fi30zjQhtWY',start='120')" ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "from IPython.display import HTML\n", "from base64 import b64encode\n", "video = open(\"VideoDemo.m4v\", \"rb\").read()\n", "video_encoded = b64encode(video)\n", "video_tag = '