\documentclass[10pt,a4paper]{article} % Packages \usepackage{fancyhdr} % For header and footer \usepackage{multicol} % Allows multicols in tables \usepackage{tabularx} % Intelligent column widths \usepackage{tabulary} % Used in header and footer \usepackage{hhline} % Border under tables \usepackage{graphicx} % For images \usepackage{xcolor} % For hex colours %\usepackage[utf8x]{inputenc} % For unicode character support \usepackage[T1]{fontenc} % Without this we get weird character replacements \usepackage{colortbl} % For coloured tables \usepackage{setspace} % For line height \usepackage{lastpage} % Needed for total page number \usepackage{seqsplit} % Splits long words. %\usepackage{opensans} % Can't make this work so far. Shame. Would be lovely. \usepackage[normalem]{ulem} % For underlining links % Most of the following are not required for the majority % of cheat sheets but are needed for some symbol support. \usepackage{amsmath} % Symbols \usepackage{MnSymbol} % Symbols \usepackage{wasysym} % Symbols %\usepackage[english,german,french,spanish,italian]{babel} % Languages % Document Info \author{shakhand} \pdfinfo{ /Title (python-documentation-style.pdf) /Creator (Cheatography) /Author (shakhand) /Subject (python documentation style Cheat Sheet) } % Lengths and widths \addtolength{\textwidth}{6cm} \addtolength{\textheight}{-1cm} \addtolength{\hoffset}{-3cm} \addtolength{\voffset}{-2cm} \setlength{\tabcolsep}{0.2cm} % Space between columns \setlength{\headsep}{-12pt} % Reduce space between header and content \setlength{\headheight}{85pt} % If less, LaTeX automatically increases it \renewcommand{\footrulewidth}{0pt} % Remove footer line \renewcommand{\headrulewidth}{0pt} % Remove header line \renewcommand{\seqinsert}{\ifmmode\allowbreak\else\-\fi} % Hyphens in seqsplit % This two commands together give roughly % the right line height in the tables \renewcommand{\arraystretch}{1.3} \onehalfspacing % Commands \newcommand{\SetRowColor}[1]{\noalign{\gdef\RowColorName{#1}}\rowcolor{\RowColorName}} % Shortcut for row colour \newcommand{\mymulticolumn}[3]{\multicolumn{#1}{>{\columncolor{\RowColorName}}#2}{#3}} % For coloured multi-cols \newcolumntype{x}[1]{>{\raggedright}p{#1}} % New column types for ragged-right paragraph columns \newcommand{\tn}{\tabularnewline} % Required as custom column type in use % Font and Colours \definecolor{HeadBackground}{HTML}{333333} \definecolor{FootBackground}{HTML}{666666} \definecolor{TextColor}{HTML}{333333} \definecolor{DarkBackground}{HTML}{8691A3} \definecolor{LightBackground}{HTML}{F7F8F9} \renewcommand{\familydefault}{\sfdefault} \color{TextColor} % Header and Footer \pagestyle{fancy} \fancyhead{} % Set header to blank \fancyfoot{} % Set footer to blank \fancyhead[L]{ \noindent \begin{multicols}{3} \begin{tabulary}{5.8cm}{C} \SetRowColor{DarkBackground} \vspace{-7pt} {\parbox{\dimexpr\textwidth-2\fboxsep\relax}{\noindent \hspace*{-6pt}\includegraphics[width=5.8cm]{/web/www.cheatography.com/public/images/cheatography_logo.pdf}} } \end{tabulary} \columnbreak \begin{tabulary}{11cm}{L} \vspace{-2pt}\large{\bf{\textcolor{DarkBackground}{\textrm{python documentation style Cheat Sheet}}}} \\ \normalsize{by \textcolor{DarkBackground}{shakhand} via \textcolor{DarkBackground}{\uline{cheatography.com/33748/cs/10529/}}} \end{tabulary} \end{multicols}} \fancyfoot[L]{ \footnotesize \noindent \begin{multicols}{3} \begin{tabulary}{5.8cm}{LL} \SetRowColor{FootBackground} \mymulticolumn{2}{p{5.377cm}}{\bf\textcolor{white}{Cheatographer}} \\ \vspace{-2pt}shakhand \\ \uline{cheatography.com/shakhand} \\ \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Cheat Sheet}} \\ \vspace{-2pt}Published 14th January, 2017.\\ Updated 14th January, 2017.\\ Page {\thepage} of \pageref{LastPage}. \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Sponsor}} \\ \SetRowColor{white} \vspace{-5pt} %\includegraphics[width=48px,height=48px]{dave.jpeg} Measure your website readability!\\ www.readability-score.com \end{tabulary} \end{multicols}} \begin{document} \raggedright \raggedcolumns % Set font size to small. Switch to any value % from this page to resize cheat sheet text: % www.emerson.emory.edu/services/latex/latex_169.html \footnotesize % Small font. \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{Part1}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{\# -{\emph{- coding: utf-8 -}}- \newline """Example Google style docstrings. \newline \newline This module demonstrates documentation as specified by the `Google Python \newline Style Guide`\_. Docstrings may extend over multiple lines. Sections are created \newline with a section header and a colon followed by a block of indented text. \newline \newline Example: \newline Examples can be given using either the ``Example`` or ``Examples`` \newline sections. Sections support any reStructuredText formatting, including \newline literal blocks:: \newline \newline \$ python example\_google.py \newline \newline Section breaks are created by resuming unindented text. Section breaks \newline are also implicitly created anytime a new section starts. \newline \newline Attributes: \newline module\_level\_variable1 (int): Module level variables may be documented in \newline either the ``Attributes`` section of the module docstring, or in an \newline inline docstring immediately following the variable. \newline \newline Either form is acceptable, but the two should not be mixed. Choose \newline one convention to document module level variables and be consistent \newline with it. \newline \newline Todo: \newline {\emph{ For module TODOs \newline }} You have to also use ``sphinx.ext.todo`` extension \newline \newline .. \_Google Python Style Guide: \newline \seqsplit{http://google.github.io/styleguide/pyguide.html} \newline \newline """} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{Part2}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{module\_level\_variable1 = 12345 \newline \newline module\_level\_variable2 = 98765 \newline """int: Module level variable documented inline. \newline \newline The docstring may span multiple lines. The type may optionally be specified \newline on the first line, separated by a colon. \newline """ \newline \newline \newline def \seqsplit{function\_with\_types\_in\_docstring(param1}, param2): \newline """Example function with types documented in the docstring. \newline \newline `PEP 484`\_ type annotations are supported. If attribute, parameter, and \newline return types are annotated according to `PEP 484`\_, they do not need to be \newline included in the docstring: \newline \newline Args: \newline param1 (int): The first parameter. \newline param2 (str): The second parameter. \newline \newline Returns: \newline bool: The return value. True for success, False otherwise. \newline \newline .. \_PEP 484: \newline \seqsplit{https://www.python.org/dev/peps/pep-0484/} \newline \newline """ \newline \newline \newline def \seqsplit{function\_with\_pep484\_type\_annotations(param1:} int, param2: str) -\textgreater{} bool: \newline """Example function with PEP 484 type annotations. \newline \newline Args: \newline param1: The first parameter. \newline param2: The second parameter. \newline \newline Returns: \newline The return value. True for success, False otherwise. \newline \newline """} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \end{document}