{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "# Reportlab Cheatsheet" ] }, { "cell_type": "code", "execution_count": 110, "metadata": {}, "outputs": [], "source": [ "from reportlab.pdfgen.canvas import Canvas\n", "from reportlab.lib.pagesizes import letter, A4\n", "from reportlab.lib.units import inch, mm" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "# ReportLab PDF Library\n", "\n", "![]()\n", "\n", "What is the ReportLab PDF Library?\n", "\n", "This is a software library that lets you directly create documents in Adobe's Portable Document Format (PDF)using the Python programming language. It also creates charts and data graphics in various bitmap and vectorformats as well as PDF.\n", "\n", "https://www.reportlab.com/docs/reportlab-userguide.pdf" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Canvas" ] }, { "cell_type": "code", "execution_count": 111, "metadata": { "scrolled": true }, "outputs": [ { "data": { "text/plain": [ "\u001b[0;31mInit signature:\u001b[0m\n", "\u001b[0mCanvas\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mfilename\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mpagesize\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mbottomup\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mpageCompression\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0minvariant\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mverbosity\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mencrypt\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mcropMarks\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mpdfVersion\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0menforceColorSpace\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0minitialFontName\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0minitialFontSize\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0minitialLeading\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mcropBox\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0martBox\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mtrimBox\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m \u001b[0mbleedBox\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", "\u001b[0;34m\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n", "\u001b[0;31mDocstring:\u001b[0m \n", "This class is the programmer's interface to the PDF file format. Methods\n", "are (or will be) provided here to do just about everything PDF can do.\n", "\n", "The underlying model to the canvas concept is that of a graphics state machine\n", "that at any given point in time has a current font, fill color (for figure\n", "interiors), stroke color (for figure borders), line width and geometric transform, among\n", "many other characteristics.\n", "\n", "Canvas methods generally either draw something (like canvas.line) using the\n", "current state of the canvas or change some component of the canvas\n", "state (like canvas.setFont). The current state can be saved and restored\n", "using the saveState/restoreState methods.\n", "\n", "Objects are \"painted\" in the order they are drawn so if, for example\n", "two rectangles overlap the last draw will appear \"on top\". PDF form\n", "objects (supported here) are used to draw complex drawings only once,\n", "for possible repeated use.\n", "\n", "There are other features of canvas which are not visible when printed,\n", "such as outlines and bookmarks which are used for navigating a document\n", "in a viewer.\n", "\n", "Here is a very silly example usage which generates a Hello World pdf document.\n", "\n", "Example:: \n", "\n", " from reportlab.pdfgen import canvas\n", " c = canvas.Canvas(\"hello.pdf\")\n", " from reportlab.lib.units import inch\n", " # move the origin up and to the left\n", " c.translate(inch,inch)\n", " # define a large font\n", " c.setFont(\"Helvetica\", 80)\n", " # choose some colors\n", " c.setStrokeColorRGB(0.2,0.5,0.3)\n", " c.setFillColorRGB(1,0,1)\n", " # draw a rectangle\n", " c.rect(inch,inch,6*inch,9*inch, fill=1)\n", " # make text go straight up\n", " c.rotate(90)\n", " # change color\n", " c.setFillColorRGB(0,0,0.77)\n", " # say hello (note after rotate the y coord needs to be negative!)\n", " c.drawString(3*inch, -3*inch, \"Hello World\")\n", " c.showPage()\n", " c.save()\n", "\u001b[0;31mInit docstring:\u001b[0m\n", "Create a canvas of a given size. etc.\n", "\n", "You may pass a file-like object to filename as an alternative to\n", "a string.\n", "For more information about the encrypt parameter refer to the setEncrypt method.\n", "\n", "Most of the attributes are private - we will use set/get methods\n", "as the preferred interface. Default page size is A4.\n", "cropMarks may be True/False or an object with parameters borderWidth, markColor, markWidth\n", "and markLength\n", "\n", "if enforceColorSpace is in ('cmyk', 'rgb', 'sep','sep_black','sep_cmyk') then one of\n", "the standard _PDFColorSetter callables will be used to enforce appropriate color settings.\n", "If it is a callable then that will be used.\n", "\u001b[0;31mFile:\u001b[0m ~/.local/lib/python3.7/site-packages/reportlab/pdfgen/canvas.py\n", "\u001b[0;31mType:\u001b[0m type\n", "\u001b[0;31mSubclasses:\u001b[0m \n" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "Canvas?" ] }, { "cell_type": "code", "execution_count": 112, "metadata": {}, "outputs": [], "source": [ "# Make a Canvas object, bottomup=0 will put the 0,0 at the lop-left (instead of bottom-left)\n", "c = Canvas(\"pdf/reportlab-cheatsheet.pdf\", pagesize=A4, bottomup=0)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Shapes" ] }, { "cell_type": "code", "execution_count": 113, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "\u001b[0;31mSignature:\u001b[0m \u001b[0mc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcircle\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx_cen\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my_cen\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstroke\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfill\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n", "\u001b[0;31mDocstring:\u001b[0m draw a cirle centered at (x_cen,y_cen) with radius r (special case of ellipse)\n", "\u001b[0;31mFile:\u001b[0m ~/.local/lib/python3.7/site-packages/reportlab/pdfgen/canvas.py\n", "\u001b[0;31mType:\u001b[0m method\n" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "c.circle?" ] }, { "cell_type": "code", "execution_count": 114, "metadata": {}, "outputs": [], "source": [ "c.circle(20*mm, 20*mm, 10*mm, stroke=0, fill=1)" ] }, { "cell_type": "code", "execution_count": 115, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "\u001b[0;31mSignature:\u001b[0m \u001b[0mc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrect\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mwidth\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mheight\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstroke\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfill\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n", "\u001b[0;31mDocstring:\u001b[0m draws a rectangle with lower left corner at (x,y) and width and height as given.\n", "\u001b[0;31mFile:\u001b[0m ~/.local/lib/python3.7/site-packages/reportlab/pdfgen/canvas.py\n", "\u001b[0;31mType:\u001b[0m method\n" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "c.rect?" ] }, { "cell_type": "code", "execution_count": 116, "metadata": {}, "outputs": [], "source": [ "c.rect(40*mm, 40*mm, 10*mm, 10*mm, stroke=1, fill=0)" ] }, { "cell_type": "code", "execution_count": 117, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "\u001b[0;31mSignature:\u001b[0m \u001b[0mc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mroundRect\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mwidth\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mheight\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mradius\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstroke\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfill\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n", "\u001b[0;31mDocstring:\u001b[0m\n", "Draws a rectangle with rounded corners. The corners are\n", "approximately quadrants of a circle, with the given radius.\n", "\u001b[0;31mFile:\u001b[0m ~/.local/lib/python3.7/site-packages/reportlab/pdfgen/canvas.py\n", "\u001b[0;31mType:\u001b[0m method\n" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "c.roundRect?" ] }, { "cell_type": "code", "execution_count": 118, "metadata": {}, "outputs": [], "source": [ "c.roundRect(60*mm, 60*mm, 50*mm, 50*mm, 5*mm, stroke=1, fill=0)" ] }, { "cell_type": "code", "execution_count": 119, "metadata": {}, "outputs": [], "source": [ "c.showPage()" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Fonts" ] }, { "cell_type": "code", "execution_count": 120, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "['Courier',\n", " 'Courier-Bold',\n", " 'Courier-BoldOblique',\n", " 'Courier-Oblique',\n", " 'Helvetica',\n", " 'Helvetica-Bold',\n", " 'Helvetica-BoldOblique',\n", " 'Helvetica-Oblique',\n", " 'Symbol',\n", " 'Times-Bold',\n", " 'Times-BoldItalic',\n", " 'Times-Italic',\n", " 'Times-Roman',\n", " 'ZapfDingbats']" ] }, "execution_count": 120, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# Reportlab comes with a set of fonts\n", "c.getAvailableFonts()" ] }, { "cell_type": "code", "execution_count": 131, "metadata": {}, "outputs": [], "source": [ "c.setFont('Courier', 72)" ] }, { "cell_type": "code", "execution_count": 121, "metadata": {}, "outputs": [], "source": [ "# Or you can import fonts\n", "from reportlab.pdfbase.ttfonts import TTFont, pdfmetrics\n", "\n", "fontpath = \"fonts/OSP-DIN.ttf\"\n", "font = TTFont('OSP-DIN', fontpath)\n", "pdfmetrics.registerFont(font)" ] }, { "cell_type": "code", "execution_count": 122, "metadata": {}, "outputs": [], "source": [ "c.setFont('OSP-DIN', 72)" ] }, { "cell_type": "code", "execution_count": 123, "metadata": {}, "outputs": [], "source": [ "c.drawCentredString(105*mm, 50*mm, \"Hello :)!\")" ] }, { "cell_type": "code", "execution_count": 124, "metadata": {}, "outputs": [], "source": [ "c.showPage()" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Colors" ] }, { "cell_type": "code", "execution_count": 126, "metadata": {}, "outputs": [], "source": [ "# Choose a RGB/CMYK color\n", "\n", "# Fill-color\n", "c.setFillColorRGB(255,0,0)\n", "c.setFillColorCMYK(0,1,0,0)\n", "\n", "# Stroke-color\n", "c.setStrokeColorRGB(255,255,0)\n", "c.setStrokeColorCMYK(0,0,1,0)" ] }, { "cell_type": "code", "execution_count": 134, "metadata": {}, "outputs": [], "source": [ "# Or choose one of the embedded colors from Reportlab\n", "from reportlab.lib.colors import pink, magenta, red, blue\n", "\n", "c.setFillColor(magenta)\n", "c.setStrokeColor(red)" ] }, { "cell_type": "code", "execution_count": 128, "metadata": {}, "outputs": [], "source": [ "c.setFont('OSP-DIN', 72)\n", "c.drawCentredString(105*mm, 50*mm, \"Hello :)!\")\n", "\n", "c.rect(105*mm, 150*mm, 50*mm, 50*mm, stroke=1, fill=1)" ] }, { "cell_type": "code", "execution_count": 129, "metadata": {}, "outputs": [], "source": [ "c.showPage()" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Lines" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Text" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Images" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Save PDF" ] }, { "cell_type": "code", "execution_count": 130, "metadata": {}, "outputs": [], "source": [ "c.save()" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] } ], "metadata": { "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.7.3" } }, "nbformat": 4, "nbformat_minor": 4 }