| @@ -17,9 +17,11 @@ | |||
| # version: 3.5.2 | |||
| # --- | |||
| # ## Animation | |||
| # ## Matplotlib Animation | |||
| # | |||
| # ## Method 1 | |||
| # + | |||
| # %matplotlib inline | |||
| @@ -61,3 +63,25 @@ anim = animation.FuncAnimation(fig, animate, init_func=init, | |||
| frames=100, interval=20, blit=True) | |||
| HTML(anim.to_html5_video()) | |||
| # - | |||
| # ## Method 2 | |||
| # + | |||
| # %matplotlib nbagg | |||
| import numpy as np | |||
| import matplotlib.pyplot as plt | |||
| import matplotlib.animation as animation | |||
| fig = plt.figure() | |||
| x = np.arange(0, 10, 0.1) | |||
| ims = [] | |||
| for a in range(50): | |||
| y = np.sin(x - a) | |||
| im = plt.plot(x, y, "r") | |||
| ims.append(im) | |||
| ani = animation.ArtistAnimation(fig, ims) | |||
| plt.show() | |||
| @@ -1,37 +0,0 @@ | |||
| # --- | |||
| # jupyter: | |||
| # jupytext_format_version: '1.2' | |||
| # kernelspec: | |||
| # display_name: Python 3 | |||
| # language: python | |||
| # name: python3 | |||
| # language_info: | |||
| # codemirror_mode: | |||
| # name: ipython | |||
| # version: 3 | |||
| # file_extension: .py | |||
| # mimetype: text/x-python | |||
| # name: python | |||
| # nbconvert_exporter: python | |||
| # pygments_lexer: ipython3 | |||
| # version: 3.5.2 | |||
| # --- | |||
| # + | |||
| # %matplotlib nbagg | |||
| import numpy as np | |||
| import matplotlib.pyplot as plt | |||
| import matplotlib.animation as animation | |||
| fig = plt.figure() | |||
| x = np.arange(0, 10, 0.1) | |||
| ims = [] | |||
| for a in range(50): | |||
| y = np.sin(x - a) | |||
| im = plt.plot(x, y, "r") | |||
| ims.append(im) | |||
| ani = animation.ArtistAnimation(fig, ims) | |||
| plt.show() | |||
| @@ -1,322 +0,0 @@ | |||
| % Default to the notebook output style | |||
| % Inherit from the specified cell style. | |||
| \documentclass[11pt]{article} | |||
| \usepackage[T1]{fontenc} | |||
| % Nicer default font (+ math font) than Computer Modern for most use cases | |||
| \usepackage{mathpazo} | |||
| % Basic figure setup, for now with no caption control since it's done | |||
| % automatically by Pandoc (which extracts  syntax from Markdown). | |||
| \usepackage{graphicx} | |||
| % We will generate all images so they have a width \maxwidth. This means | |||
| % that they will get their normal width if they fit onto the page, but | |||
| % are scaled down if they would overflow the margins. | |||
| \makeatletter | |||
| \def\maxwidth{\ifdim\Gin@nat@width>\linewidth\linewidth | |||
| \else\Gin@nat@width\fi} | |||
| \makeatother | |||
| \let\Oldincludegraphics\includegraphics | |||
| % Set max figure width to be 80% of text width, for now hardcoded. | |||
| \renewcommand{\includegraphics}[1]{\Oldincludegraphics[width=.8\maxwidth]{#1}} | |||
| % Ensure that by default, figures have no caption (until we provide a | |||
| % proper Figure object with a Caption API and a way to capture that | |||
| % in the conversion process - todo). | |||
| \usepackage{caption} | |||
| \DeclareCaptionLabelFormat{nolabel}{} | |||
| \captionsetup{labelformat=nolabel} | |||
| \usepackage{adjustbox} % Used to constrain images to a maximum size | |||
| \usepackage{xcolor} % Allow colors to be defined | |||
| \usepackage{enumerate} % Needed for markdown enumerations to work | |||
| \usepackage{geometry} % Used to adjust the document margins | |||
| \usepackage{amsmath} % Equations | |||
| \usepackage{amssymb} % Equations | |||
| \usepackage{textcomp} % defines textquotesingle | |||
| % Hack from http://tex.stackexchange.com/a/47451/13684: | |||
| \AtBeginDocument{% | |||
| \def\PYZsq{\textquotesingle}% Upright quotes in Pygmentized code | |||
| } | |||
| \usepackage{upquote} % Upright quotes for verbatim code | |||
| \usepackage{eurosym} % defines \euro | |||
| \usepackage[mathletters]{ucs} % Extended unicode (utf-8) support | |||
| \usepackage[utf8x]{inputenc} % Allow utf-8 characters in the tex document | |||
| \usepackage{fancyvrb} % verbatim replacement that allows latex | |||
| \usepackage{grffile} % extends the file name processing of package graphics | |||
| % to support a larger range | |||
| % The hyperref package gives us a pdf with properly built | |||
| % internal navigation ('pdf bookmarks' for the table of contents, | |||
| % internal cross-reference links, web links for URLs, etc.) | |||
| \usepackage{hyperref} | |||
| \usepackage{longtable} % longtable support required by pandoc >1.10 | |||
| \usepackage{booktabs} % table support for pandoc > 1.12.2 | |||
| \usepackage[inline]{enumitem} % IRkernel/repr support (it uses the enumerate* environment) | |||
| \usepackage[normalem]{ulem} % ulem is needed to support strikethroughs (\sout) | |||
| % normalem makes italics be italics, not underlines | |||
| % Colors for the hyperref package | |||
| \definecolor{urlcolor}{rgb}{0,.145,.698} | |||
| \definecolor{linkcolor}{rgb}{.71,0.21,0.01} | |||
| \definecolor{citecolor}{rgb}{.12,.54,.11} | |||
| % ANSI colors | |||
| \definecolor{ansi-black}{HTML}{3E424D} | |||
| \definecolor{ansi-black-intense}{HTML}{282C36} | |||
| \definecolor{ansi-red}{HTML}{E75C58} | |||
| \definecolor{ansi-red-intense}{HTML}{B22B31} | |||
| \definecolor{ansi-green}{HTML}{00A250} | |||
| \definecolor{ansi-green-intense}{HTML}{007427} | |||
| \definecolor{ansi-yellow}{HTML}{DDB62B} | |||
| \definecolor{ansi-yellow-intense}{HTML}{B27D12} | |||
| \definecolor{ansi-blue}{HTML}{208FFB} | |||
| \definecolor{ansi-blue-intense}{HTML}{0065CA} | |||
| \definecolor{ansi-magenta}{HTML}{D160C4} | |||
| \definecolor{ansi-magenta-intense}{HTML}{A03196} | |||
| \definecolor{ansi-cyan}{HTML}{60C6C8} | |||
| \definecolor{ansi-cyan-intense}{HTML}{258F8F} | |||
| \definecolor{ansi-white}{HTML}{C5C1B4} | |||
| \definecolor{ansi-white-intense}{HTML}{A1A6B2} | |||
| % commands and environments needed by pandoc snippets | |||
| % extracted from the output of `pandoc -s` | |||
| \providecommand{\tightlist}{% | |||
| \setlength{\itemsep}{0pt}\setlength{\parskip}{0pt}} | |||
| \DefineVerbatimEnvironment{Highlighting}{Verbatim}{commandchars=\\\{\}} | |||
| % Add ',fontsize=\small' for more characters per line | |||
| \newenvironment{Shaded}{}{} | |||
| \newcommand{\KeywordTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{\textbf{{#1}}}} | |||
| \newcommand{\DataTypeTok}[1]{\textcolor[rgb]{0.56,0.13,0.00}{{#1}}} | |||
| \newcommand{\DecValTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} | |||
| \newcommand{\BaseNTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} | |||
| \newcommand{\FloatTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} | |||
| \newcommand{\CharTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} | |||
| \newcommand{\StringTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} | |||
| \newcommand{\CommentTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textit{{#1}}}} | |||
| \newcommand{\OtherTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{{#1}}} | |||
| \newcommand{\AlertTok}[1]{\textcolor[rgb]{1.00,0.00,0.00}{\textbf{{#1}}}} | |||
| \newcommand{\FunctionTok}[1]{\textcolor[rgb]{0.02,0.16,0.49}{{#1}}} | |||
| \newcommand{\RegionMarkerTok}[1]{{#1}} | |||
| \newcommand{\ErrorTok}[1]{\textcolor[rgb]{1.00,0.00,0.00}{\textbf{{#1}}}} | |||
| \newcommand{\NormalTok}[1]{{#1}} | |||
| % Additional commands for more recent versions of Pandoc | |||
| \newcommand{\ConstantTok}[1]{\textcolor[rgb]{0.53,0.00,0.00}{{#1}}} | |||
| \newcommand{\SpecialCharTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} | |||
| \newcommand{\VerbatimStringTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} | |||
| \newcommand{\SpecialStringTok}[1]{\textcolor[rgb]{0.73,0.40,0.53}{{#1}}} | |||
| \newcommand{\ImportTok}[1]{{#1}} | |||
| \newcommand{\DocumentationTok}[1]{\textcolor[rgb]{0.73,0.13,0.13}{\textit{{#1}}}} | |||
| \newcommand{\AnnotationTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} | |||
| \newcommand{\CommentVarTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} | |||
| \newcommand{\VariableTok}[1]{\textcolor[rgb]{0.10,0.09,0.49}{{#1}}} | |||
| \newcommand{\ControlFlowTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{\textbf{{#1}}}} | |||
| \newcommand{\OperatorTok}[1]{\textcolor[rgb]{0.40,0.40,0.40}{{#1}}} | |||
| \newcommand{\BuiltInTok}[1]{{#1}} | |||
| \newcommand{\ExtensionTok}[1]{{#1}} | |||
| \newcommand{\PreprocessorTok}[1]{\textcolor[rgb]{0.74,0.48,0.00}{{#1}}} | |||
| \newcommand{\AttributeTok}[1]{\textcolor[rgb]{0.49,0.56,0.16}{{#1}}} | |||
| \newcommand{\InformationTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} | |||
| \newcommand{\WarningTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} | |||
| % Define a nice break command that doesn't care if a line doesn't already | |||
| % exist. | |||
| \def\br{\hspace*{\fill} \\* } | |||
| % Math Jax compatability definitions | |||
| \def\gt{>} | |||
| \def\lt{<} | |||
| % Document parameters | |||
| \title{matplotlib\_ani2} | |||
| % Pygments definitions | |||
| \makeatletter | |||
| \def\PY@reset{\let\PY@it=\relax \let\PY@bf=\relax% | |||
| \let\PY@ul=\relax \let\PY@tc=\relax% | |||
| \let\PY@bc=\relax \let\PY@ff=\relax} | |||
| \def\PY@tok#1{\csname PY@tok@#1\endcsname} | |||
| \def\PY@toks#1+{\ifx\relax#1\empty\else% | |||
| \PY@tok{#1}\expandafter\PY@toks\fi} | |||
| \def\PY@do#1{\PY@bc{\PY@tc{\PY@ul{% | |||
| \PY@it{\PY@bf{\PY@ff{#1}}}}}}} | |||
| \def\PY#1#2{\PY@reset\PY@toks#1+\relax+\PY@do{#2}} | |||
| \expandafter\def\csname PY@tok@gi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.63,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@ni\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.60,0.60,0.60}{##1}}} | |||
| \expandafter\def\csname PY@tok@ow\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.67,0.13,1.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@dl\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} | |||
| \expandafter\def\csname PY@tok@vi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} | |||
| \expandafter\def\csname PY@tok@nl\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.63,0.63,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@mb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} | |||
| \expandafter\def\csname PY@tok@m\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} | |||
| \expandafter\def\csname PY@tok@mo\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} | |||
| \expandafter\def\csname PY@tok@sa\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} | |||
| \expandafter\def\csname PY@tok@nb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@ss\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} | |||
| \expandafter\def\csname PY@tok@kp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@sx\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@kn\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@mh\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} | |||
| \expandafter\def\csname PY@tok@gu\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.50,0.00,0.50}{##1}}} | |||
| \expandafter\def\csname PY@tok@sc\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} | |||
| \expandafter\def\csname PY@tok@c1\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} | |||
| \expandafter\def\csname PY@tok@gh\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,0.50}{##1}}} | |||
| \expandafter\def\csname PY@tok@gt\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.27,0.87}{##1}}} | |||
| \expandafter\def\csname PY@tok@vm\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} | |||
| \expandafter\def\csname PY@tok@nc\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@sh\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} | |||
| \expandafter\def\csname PY@tok@gp\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,0.50}{##1}}} | |||
| \expandafter\def\csname PY@tok@nv\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} | |||
| \expandafter\def\csname PY@tok@w\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.73,0.73}{##1}}} | |||
| \expandafter\def\csname PY@tok@ne\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.82,0.25,0.23}{##1}}} | |||
| \expandafter\def\csname PY@tok@gd\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.63,0.00,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@cm\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} | |||
| \expandafter\def\csname PY@tok@k\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@bp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@gr\endcsname{\def\PY@tc##1{\textcolor[rgb]{1.00,0.00,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@sb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} | |||
| \expandafter\def\csname PY@tok@cp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.74,0.48,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@mi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} | |||
| \expandafter\def\csname PY@tok@mf\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} | |||
| \expandafter\def\csname PY@tok@il\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} | |||
| \expandafter\def\csname PY@tok@nf\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@se\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.13}{##1}}} | |||
| \expandafter\def\csname PY@tok@nt\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@si\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.53}{##1}}} | |||
| \expandafter\def\csname PY@tok@nd\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.67,0.13,1.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@cpf\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} | |||
| \expandafter\def\csname PY@tok@cs\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} | |||
| \expandafter\def\csname PY@tok@vc\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} | |||
| \expandafter\def\csname PY@tok@sd\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} | |||
| \expandafter\def\csname PY@tok@err\endcsname{\def\PY@bc##1{\setlength{\fboxsep}{0pt}\fcolorbox[rgb]{1.00,0.00,0.00}{1,1,1}{\strut ##1}}} | |||
| \expandafter\def\csname PY@tok@na\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.49,0.56,0.16}{##1}}} | |||
| \expandafter\def\csname PY@tok@s1\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} | |||
| \expandafter\def\csname PY@tok@ch\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} | |||
| \expandafter\def\csname PY@tok@s\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} | |||
| \expandafter\def\csname PY@tok@fm\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@c\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} | |||
| \expandafter\def\csname PY@tok@kd\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@ge\endcsname{\let\PY@it=\textit} | |||
| \expandafter\def\csname PY@tok@kr\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@vg\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} | |||
| \expandafter\def\csname PY@tok@go\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.53,0.53,0.53}{##1}}} | |||
| \expandafter\def\csname PY@tok@no\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.53,0.00,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@o\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} | |||
| \expandafter\def\csname PY@tok@kc\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@gs\endcsname{\let\PY@bf=\textbf} | |||
| \expandafter\def\csname PY@tok@sr\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.53}{##1}}} | |||
| \expandafter\def\csname PY@tok@nn\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} | |||
| \expandafter\def\csname PY@tok@s2\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} | |||
| \expandafter\def\csname PY@tok@kt\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.69,0.00,0.25}{##1}}} | |||
| \def\PYZbs{\char`\\} | |||
| \def\PYZus{\char`\_} | |||
| \def\PYZob{\char`\{} | |||
| \def\PYZcb{\char`\}} | |||
| \def\PYZca{\char`\^} | |||
| \def\PYZam{\char`\&} | |||
| \def\PYZlt{\char`\<} | |||
| \def\PYZgt{\char`\>} | |||
| \def\PYZsh{\char`\#} | |||
| \def\PYZpc{\char`\%} | |||
| \def\PYZdl{\char`\$} | |||
| \def\PYZhy{\char`\-} | |||
| \def\PYZsq{\char`\'} | |||
| \def\PYZdq{\char`\"} | |||
| \def\PYZti{\char`\~} | |||
| % for compatibility with earlier versions | |||
| \def\PYZat{@} | |||
| \def\PYZlb{[} | |||
| \def\PYZrb{]} | |||
| \makeatother | |||
| % Exact colors from NB | |||
| \definecolor{incolor}{rgb}{0.0, 0.0, 0.5} | |||
| \definecolor{outcolor}{rgb}{0.545, 0.0, 0.0} | |||
| % Prevent overflowing lines due to hard-to-break entities | |||
| \sloppy | |||
| % Setup hyperref package | |||
| \hypersetup{ | |||
| breaklinks=true, % so long urls are correctly broken across lines | |||
| colorlinks=true, | |||
| urlcolor=urlcolor, | |||
| linkcolor=linkcolor, | |||
| citecolor=citecolor, | |||
| } | |||
| % Slightly bigger margins than the latex defaults | |||
| \geometry{verbose,tmargin=1in,bmargin=1in,lmargin=1in,rmargin=1in} | |||
| \begin{document} | |||
| \maketitle | |||
| \begin{Verbatim}[commandchars=\\\{\}] | |||
| {\color{incolor}In [{\color{incolor}1}]:} \PY{c+c1}{\PYZsh{}\PYZpc{}matplotlib nbagg} | |||
| \PY{o}{\PYZpc{}}\PY{k}{matplotlib} nbagg | |||
| \PY{k+kn}{import} \PY{n+nn}{numpy} \PY{k}{as} \PY{n+nn}{np} | |||
| \PY{k+kn}{import} \PY{n+nn}{matplotlib}\PY{n+nn}{.}\PY{n+nn}{pyplot} \PY{k}{as} \PY{n+nn}{plt} | |||
| \PY{k+kn}{import} \PY{n+nn}{matplotlib}\PY{n+nn}{.}\PY{n+nn}{animation} \PY{k}{as} \PY{n+nn}{animation} | |||
| \PY{n}{fig} \PY{o}{=} \PY{n}{plt}\PY{o}{.}\PY{n}{figure}\PY{p}{(}\PY{p}{)} | |||
| \PY{n}{x} \PY{o}{=} \PY{n}{np}\PY{o}{.}\PY{n}{arange}\PY{p}{(}\PY{l+m+mi}{0}\PY{p}{,} \PY{l+m+mi}{10}\PY{p}{,} \PY{l+m+mf}{0.1}\PY{p}{)} | |||
| \PY{n}{ims} \PY{o}{=} \PY{p}{[}\PY{p}{]} | |||
| \PY{k}{for} \PY{n}{a} \PY{o+ow}{in} \PY{n+nb}{range}\PY{p}{(}\PY{l+m+mi}{50}\PY{p}{)}\PY{p}{:} | |||
| \PY{n}{y} \PY{o}{=} \PY{n}{np}\PY{o}{.}\PY{n}{sin}\PY{p}{(}\PY{n}{x} \PY{o}{\PYZhy{}} \PY{n}{a}\PY{p}{)} | |||
| \PY{n}{im} \PY{o}{=} \PY{n}{plt}\PY{o}{.}\PY{n}{plot}\PY{p}{(}\PY{n}{x}\PY{p}{,} \PY{n}{y}\PY{p}{,} \PY{l+s+s2}{\PYZdq{}}\PY{l+s+s2}{r}\PY{l+s+s2}{\PYZdq{}}\PY{p}{)} | |||
| \PY{n}{ims}\PY{o}{.}\PY{n}{append}\PY{p}{(}\PY{n}{im}\PY{p}{)} | |||
| \PY{n}{ani} \PY{o}{=} \PY{n}{animation}\PY{o}{.}\PY{n}{ArtistAnimation}\PY{p}{(}\PY{n}{fig}\PY{p}{,} \PY{n}{ims}\PY{p}{)} | |||
| \PY{n}{plt}\PY{o}{.}\PY{n}{show}\PY{p}{(}\PY{p}{)} | |||
| \end{Verbatim} | |||
| \begin{verbatim} | |||
| <IPython.core.display.Javascript object> | |||
| \end{verbatim} | |||
| \begin{verbatim} | |||
| <IPython.core.display.HTML object> | |||
| \end{verbatim} | |||
| % Add a bibliography block to the postdoc | |||
| \end{document} | |||
| @@ -0,0 +1,281 @@ | |||
| { | |||
| "cells": [ | |||
| { | |||
| "cell_type": "markdown", | |||
| "metadata": {}, | |||
| "source": [ | |||
| "# 2.3. Learning the basics of the distributed version control system Git" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 1, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "mkdir myproject\n", | |||
| "cd myproject" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 2, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Initialized empty Git repository in\n", | |||
| "~/git/cookbook-2nd/chapter02/myproject/.git/\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git init" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 3, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "~/git/cookbook-2nd/chapter02/myproject\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "pwd" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 4, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| ". .. .git\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "ls -a" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 5, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "git config --global user.name \"My Name\"\n", | |||
| "git config --global user.email \"me@home.com\"" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 6, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "echo \"Hello world\" > file.txt\n", | |||
| "git add file.txt" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 7, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "[master (root-commit) 02971c0] Initial commit\n", | |||
| " 1 file changed, 1 insertion(+)\n", | |||
| " create mode 100644 file.txt\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git commit -m \"Initial commit\"" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 8, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "commit 02971c0e1176cd26ec33900e359b192a27df2821\n", | |||
| "Author: My Name <me@home.com>\n", | |||
| "Date: Tue Dec 12 10:50:37 2017 +0100\n", | |||
| "\n", | |||
| " Initial commit\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git log" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 9, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "echo \"Hello world!\" > file.txt" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 10, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Hello world!\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "cat file.txt" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 11, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "diff --git a/file.txt b/file.txt\n", | |||
| "index 802992c..cd08755 100644\n", | |||
| "--- a/file.txt\n", | |||
| "+++ b/file.txt\n", | |||
| "@@ -1 +1 @@\n", | |||
| "-Hello world\n", | |||
| "+Hello world!\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git diff" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 12, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "On branch master\n", | |||
| "Changes not staged for commit:\n", | |||
| " (use \"git add <file>...\" to update what will\n", | |||
| " be committed)\n", | |||
| "\n", | |||
| " modified: file.txt\n", | |||
| "\n", | |||
| "no changes added to commit (use \"git add\")\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git status" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 13, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| " file.txt | 2 +-\n", | |||
| " 1 file changed, 1 insertion(+), 1 deletion(-)\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git diff --stat" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 14, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "[master 045df6a] Add exclamation mark to file.txt\n", | |||
| " 1 file changed, 1 insertion(+), 1 deletion(-)\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git commit -am \"Add exclamation mark to file.txt\"" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 15, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "commit 045df6a6f8a62b19f45025d15168d6d7382a8429\n", | |||
| "Author: My Name <me@home.com>\n", | |||
| "Date: Tue Dec 12 10:59:39 2017 +0100\n", | |||
| "\n", | |||
| " Add exclamation mark to file.txt\n", | |||
| "\n", | |||
| "commit 02971c0e1176cd26ec33900e359b192a27df2821\n", | |||
| "Author: My Name <me@home.com>\n", | |||
| "Date: Tue Dec 12 10:50:37 2017 +0100\n", | |||
| "\n", | |||
| " Initial commit\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git log" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 16, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "git clone https://github.com/mylogin/myproject.git" | |||
| ] | |||
| } | |||
| ], | |||
| "metadata": {}, | |||
| "nbformat": 4, | |||
| "nbformat_minor": 2 | |||
| } | |||
| @@ -0,0 +1,411 @@ | |||
| { | |||
| "cells": [ | |||
| { | |||
| "cell_type": "markdown", | |||
| "metadata": {}, | |||
| "source": [ | |||
| "# 2.4. A typical workflow with Git branching" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 1, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "/home/cyrille/git/cookbook-2nd/chapter02\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "pwd" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 2, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "cd myproject" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 3, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "git branch newidea" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 4, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "* master\n", | |||
| " newidea\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git branch" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 5, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Switched to branch 'newidea'\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git checkout newidea" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 6, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| " master\n", | |||
| "* newidea\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git branch" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 7, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "echo \"print('new')\" > newfile.py" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 8, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "print('new')\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "cat newfile.py" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 9, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "[newidea 8ebee32] Testing new idea\n", | |||
| " 1 file changed, 1 insertion(+)\n", | |||
| " create mode 100644 newfile.py\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git add newfile.py\n", | |||
| "git commit -m \"Testing new idea\"" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 10, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "file.txt newfile.py\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "ls" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 11, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Switched to branch 'master'\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git checkout master" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 12, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "file.txt\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "ls" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 13, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Updating 045df6a..8ebee32\n", | |||
| "Fast-forward\n", | |||
| " newfile.py | 1 +\n", | |||
| " 1 file changed, 1 insertion(+)\n", | |||
| " create mode 100644 newfile.py\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git merge newidea" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 14, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "file.txt newfile.py\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "ls" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 15, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "HEAD is now at 045df6 Add exclamation mark to file.txt\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git reset --hard HEAD~1" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 16, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "* master\n", | |||
| " new idea\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git branch" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 17, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Deleted branch newidea (was 8ebee32).\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git branch -D newidea" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 18, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "file.txt\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "ls" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 19, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "echo \"new line\" >> file.txt" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 20, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Hello world!\n", | |||
| "new line\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "cat file.txt" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 21, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Saved working directory and index state WIP on master:\n", | |||
| "045df6a Add exclamation mark to file.txt\n", | |||
| "HEAD is now at 045df6 Add exclamation mark to file.txt\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git stash" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 22, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Hello world!\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "cat file.txt" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 23, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "On branch master\n", | |||
| "Changes not staged for commit:\n", | |||
| "\n", | |||
| " modified: file.txt\n", | |||
| "\n", | |||
| "no changes added to commit\n", | |||
| " (use \"git add\" and/or \"git commit -a\")\n", | |||
| "Dropped refs/stash@{0} (c9071a)\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "git stash pop" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 24, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Hello world!\n", | |||
| "new line\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "cat file.txt" | |||
| ] | |||
| } | |||
| ], | |||
| "metadata": {}, | |||
| "nbformat": 4, | |||
| "nbformat_minor": 2 | |||
| } | |||
| @@ -0,0 +1,359 @@ | |||
| { | |||
| "cells": [ | |||
| { | |||
| "cell_type": "markdown", | |||
| "metadata": {}, | |||
| "source": [ | |||
| "# 2.1. Learning the basics of the Unix shell" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 1, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "~/git/cookbook-2nd/chapter02_best_practices\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "pwd" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 2, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "00_intro.md 03_git.md 07_high_quality.md\n", | |||
| "01_shell.md 04_git_advanced.md 08_test.md\n", | |||
| "02_py3 05_workflows.md 09_debugging.md\n", | |||
| "02_py3.md 06_tips.md images\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "ls" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 3, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "total 100\n", | |||
| "-rw-rw-r-- 1 owner 769 Dec 12 10:23 00_intro.md\n", | |||
| "-rw-rw-r-- 1 owner 2473 Dec 12 14:21 01_shell.md\n", | |||
| "...\n", | |||
| "-rw-rw-r-- 1 owner 9390 Dec 12 11:46 08_test.md\n", | |||
| "-rw-rw-r-- 1 owner 5032 Dec 12 10:23 09_debugging.md\n", | |||
| "drwxrwxr-x 2 owner 4096 Aug 1 16:49 images\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "ls -l" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 4, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "cd images" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 5, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "data": { | |||
| "text/plain": [ | |||
| "~/git/cookbook-2nd/chapter02_best_practices/images" | |||
| ] | |||
| }, | |||
| "execution_count": 5, | |||
| "metadata": {}, | |||
| "output_type": "execute_result" | |||
| } | |||
| ], | |||
| "source": [ | |||
| "pwd" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 6, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "folder.png github_new.png\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "ls" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 7, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "cd .." | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 8, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "data": { | |||
| "text/plain": [ | |||
| "~/git/cookbook-2nd/chapter02_best_practices" | |||
| ] | |||
| }, | |||
| "execution_count": 8, | |||
| "metadata": {}, | |||
| "output_type": "execute_result" | |||
| } | |||
| ], | |||
| "source": [ | |||
| "pwd" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 9, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "total 20\n", | |||
| "drwxr-xr-x 5 cyrille 4096 Nov 14 16:16 .\n", | |||
| "drwxr-xr-x 93 cyrille 4096 Dec 12 10:50 ..\n", | |||
| "drwxr-xr-x 2 cyrille 4096 Nov 14 16:16 extensions\n", | |||
| "drwxr-xr-x 2 cyrille 4096 Nov 14 16:16 nbextensions\n", | |||
| "drwxr-xr-x 7 cyrille 4096 Dec 12 14:18 profile_default\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "ls -la ~/.ipython" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 10, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "00_intro.md 05_workflows.md\n", | |||
| "01_shell.md 06_tips.md\n", | |||
| "02_py3.md 07_high_quality.md\n", | |||
| "03_git.md 08_test.md\n", | |||
| "04_git_advanced.md 09_debugging.md\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "# We create an empty directory:\n", | |||
| "mkdir md_files\n", | |||
| "# We copy all Markdown files into the new directory:\n", | |||
| "cp *.md md_files\n", | |||
| "# We rename the directory:\n", | |||
| "mv md_files markdown_files\n", | |||
| "ls markdown_files" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 11, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "rmdir: failed to remove 'markdown_files':\n", | |||
| " Directory not empty\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "rmdir markdown_files" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 12, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "rm markdown_files/*" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 13, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "rmdir markdown_files" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 14, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "# Learning the basics of the Unix shell\n", | |||
| "\n", | |||
| "Learning how to interact with the operating system (...)\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "# Show the first three lines of a text file:\n", | |||
| "head -n 3 01_shell.md" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 15, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "We will also cover more general topics (...)\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "# Show the last line of a text file:\n", | |||
| "tail -n 1 00_intro.md" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 16, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Hello world!\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "# We display some text:\n", | |||
| "echo \"Hello world!\"" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 17, | |||
| "metadata": {}, | |||
| "outputs": [], | |||
| "source": [ | |||
| "# We redirect the output of a command to\n", | |||
| "# a text file with `>`:\n", | |||
| "echo \"Hello world!\" > myfile.txt" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 18, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Hello world!\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "# We display the entire contents of the file:\n", | |||
| "cat myfile.txt" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 19, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Unix shell\n", | |||
| "Unix shell\n", | |||
| "Unix subsystem\n", | |||
| "Unix shell\n", | |||
| "(...)\n", | |||
| "Unix shell\n", | |||
| "Unix shell\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "grep -Eo \"Unix \\w+\" 01_shell.md" | |||
| ] | |||
| }, | |||
| { | |||
| "cell_type": "code", | |||
| "execution_count": 20, | |||
| "metadata": {}, | |||
| "outputs": [ | |||
| { | |||
| "name": "stdout", | |||
| "output_type": "stream", | |||
| "text": [ | |||
| "Unix shell\n" | |||
| ] | |||
| } | |||
| ], | |||
| "source": [ | |||
| "echo \"This is a Unix shell\" | grep -Eo \"Unix \\w+\"" | |||
| ] | |||
| } | |||
| ], | |||
| "metadata": {}, | |||
| "nbformat": 4, | |||
| "nbformat_minor": 2 | |||
| } | |||