This document describes the md2pptx Markdown preprocessor, which turns Markdown text into a Powerpoint presentation (whether .pptx or .pptm).
In this document we'll refer to it as "md2pptx", pronounced "em dee to pee pee tee ex".
As you can see in the change log, md2pptx is frequently updated - both for bug fixes and enhancements.
- Why md2pptx?
- How Do You Use md2pptx?
- python-pptx license
- Change Log
- Creating Slides
- Slides Without Titles
- Hyperlinks And VBA Macros
- HTML Comments
- Special Text Formatting
- Creating A Glossary Of Terms
- Creating Footnotes
- Controlling The Presentation With Metadata
- Specifying Metadata
- Metadata Keys
- Title And Subtitle Font Sizes And Alignment
- Monospace Font -
monoFont
- Margin size -
marginBase
andtableMargin
- Controlling Adjusting Title Positions And Sizes -
AdjustTitles
- Associating A Class Name with A Background Colour With
style.bgcolor
- Associating A Class Name with A Foreground Colour With
style.fgcolor
- Associating A Class Name With Text Emphasis With
style.emphasis
- Associating A Class Name With Font Size with
style.fontsize
- Template Presentation -
template
- Hiding Slides -
hidden
- Specifying An Abstract Slide With
abstractTitle
- Specifying Text Size With
baseTextSize
AndbaseTextDecrement
- Specifying Bold And Italic Text Colour With
BoldColour
AndItalicColour
- Specifying Bold And Italic Text Effects With
BoldBold
AndItalicItalic
- Controlling Task Slide Production With
taskSlides
andtasksPerSlide
- Controlling Glossary Slide Production With
glossaryTitle
,glossaryTerm
,glossaryMeaning
,glossaryMeaningWidth
, andglossaryTermsPerPage
- Specifying How Many Spaces Represent An Indentation Level With
IndentSpaces
- Specifying Where Temporary Files Are Stored With
tempDir
- Deleting The First (Processing Summary) Slide - with
DeleteFirstSlide
- Specifying Slide Background Images With
backgroundImage
- Table Metadata
- Shrinking Tables With
compactTables
- Adjusting Table Heading Font Size With
tableHeadingSize
- Adding Lines Round Tables And Cells With
addTableLines
- Adding Lines After Table Rows And Columns With
addTableRowLines
AndaddTableColumnLines
- Specifying What The Added Table Lines Look Like With
addTableLineColour
,addTableLineCount
andaddTableLineWidth
- Controlling Whether Empty Table Cells Cause Column Spanning -
SpanCells
- Controlling Whether Tables Have Drop Shadows -
tableShadow
- Shrinking Tables With
- Card Metadata
- Card Background Colour -
CardColour
- Card Border Colour -
CardBorderColour
- Card Border Width -
CardBorderWidth
- Card Title Size -
CardTitleSize
- Card Title Colour -
cardTitleColour
- Card Title Background Colours -
CardTitleBackground
- Card Divider Colour -
cardDividerColour
- Card Shadow -
CardShadow
- Card Size -
CardPercent
- Card Layout Direction -
CardLayout
- Card Title Alignment -
CardTitleAlign
- Card Title Position -
CardTitlePosition
- Card Shape -
CardShape
- Card Horizontal Gap -
CardHorizontalGap
- Card Vertical Gap -
CardVerticalGap
- Card Graphic Position -
CardGraphicPosition
- Card Graphic Size -
CardGraphicSize
- Card Graphic Padding -
CardGraphicPadding
- Card Background Colour -
- Code Metadata
- Funnel Metadata
- Footer And Slide Number Metadata
- Slide Heading Levels -
TopHeadingLevel
- Slides With Multiple Content Blocks
- Graphics Metadata
- Table Of Contents And Section Slide Metadata
- "Chevron Style" Table Of Contents
- "Circle Style" Table Of Contents
- "Plain Style" Table Of Contents
- Table Of Contents Style -
tocStyle
- Table Of Contents Title -
tocTitle
- Table Of Contents Live Links -
tocLinks
- Table Of Contents Item Height -
TOCItemHeight
- Table Of Contents Item Colour -
TOCItemColour
- Table Of Contents Row Gap -
TOCRowGap
- Table Of Contents Font Size -
TOCFontSize
- Section Navigation Buttons -
SectionArrows
- Section Navigation Button Colour -
SectionArrowsColour
- Make Expandable Sections -
SectionsExpand
- Slide Transitions -
Transition
- Dynamic Metadata
- Modifying The Slide Template
- Deviations From Standard Markdown
- Running Inline Python
- An Important Caution
- Coding Inline Python
- Variables You Can Rely On
- Python Helper Routines
- Inline Python Examples
- Building This User Guide
There are advantages in creating presentations using a flat file format. Some of these are:
-
You can use any text editor on any platform to create the file.
-
Other tools can generate the file.
For example, the author uses iThoughtsX on Mac, with its counterpart (iThoughts) on iOS, to generate presentations from outlines.
-
Text editing tools are far quicker and more flexible that the Powerpoint presentation editor.
-
Versioning and collaboration tools - such as git - are much easier to use with a text file than a Powerpoint presentation file.
-
Other flat file formats can be embedded.
With md2pptx you can use a simple Task Management format called Taskpaper to embed tasks. md2pptx will extract such tasks and generated a "Tasks" slide at the end of the presentation.
You can run your own Python code to enhance md2pptx's processing.
The flat file format that md2pptx uses is Markdown. Using Markdown has further advantages:
- The same text could be used to start, or even complete, a document of a different kind. Perhaps a long-form document.
- You can render the material in a web browser. Builds of this very documentation are checked that way.
- Markdown is easy to write.
- Markdown is compact; The files are tiny.
- Markdown is used in popular sites, such as Github.
Every piece of text you use to create a Powerpoint presentation with md2pptx is valid Markdown - with very few exceptions. While it might not render exactly the same way put through another Markdown processor, it is generally equivalent. This is one of the key aims of md2pptx.
One final advantage of the md2pptx approach is you can generate presentations without using PowerPoint itself. Indeed you can create presentations on machines where PowerPoint won't even run. All you need is to be able to run Python 3 and install python-pptx.
The author developed a presentation over 10 years in Powerpoint and OpenOffice and LibreOffice. It became very inconsistent in formatting - fonts, colours, indentations, bullets, etc.. It was a horrible mess.
He took the trouble to convert it to Markdown and regenerated it with a very early version of md2pptx. The presentation looks nice again, with consistent formatting.
It was relatively little trouble to convert to Markdown. In fact it took about an hour to convert the 40 slide presentation. The consistency gain was automatic.
The author also developed mdpre - and actively maintains it.
mdpre is a preprocessor to create Markdown. It has a number of features that might be of use in creating Markdown, with an especial focus on preparing Markdown for md2pptx. These features include:
- Including files.
- Setting (and querying) variables.
- Conditional processing.
- Conversion of CSV files to Markdown tables.
- Creating Table Of Contents slides.
- Generating a slide with annotated "month view" calendars.
The author has made running mdpre and md2pptx together easier by creating a make file. Here is an example (only tested on Mac OS).
Of\ Names\ And\ Numbers.pptx: Of\ Names\ And\ Numbers.md
md2pptx Of\ Names\ And\ Numbers.pptx < Of\ Names\ And\ Numbers.md >> Of\ Names\ And\ Numbers.log
cat Of\ Names\ And\ Numbers.log
Of\ Names\ And\ Numbers.md: Of\ Names\ And\ Numbers.mdp
mdpre -v < Of\ Names\ And\ Numbers.mdp > Of\ Names\ And\ Numbers.md 2> Of\ Names\ And\ Numbers.log
You write Markdown in exactly the same way as normal, with some understanding of how Markdown is converted to slides (using the information in Creating Slides).
To use md2pptx you need to download it and install the prerequisites.
To install md2pptx and its prerequisites
- Have Python 3.8 or higher installed.
- Install python-pptx using the command
pip3 install python-pptx
. (You might have to install pip firsst.) - Optionally install CairoSVG - using the command
pip3 install cairosvg
. (This is for SVG graphics support.) - Install md2pptx by copying a version and unzipping it or using
git clone
. md2pptx can be found here.
The following instructions are for Unix-like systems. (It's developed and used by the developer on Mac OS but should also have identical syntax on Linux.) Windows users will need a slightly different form, but the principle is the same.
Here is a sample invocation:
md2pptx powerpoint-filename < markdown-filename
An alternative is to have the Markdown be in-stream. md2pptx reads from stdin. You can, of course, use stdin in a pipeline. Indeed the developer uses this to pipe from another program. Alternatively, you can specify both an input file and an output file:
md2pptx markdown-filename powerpoint-filename
If the input file doesn't exist md2pptx will terminate with a message. If the input file is empty the same thing will happen.
If you don't specify an input filename and don't redirect stdin md2pptx will await terminal input. This works but is probably only useful when experimenting with syntax with md2pptx.
Messages are written to stderr.
While python-pptx is not included in md2pptx it is used by it.
To quote from the python-pptx license statement:
The MIT License (MIT)
Copyright (c) 2013 Steve Canny, https://github.com/scanny
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
Level | Date | What |
---|---|---|
5.3+ | 12 February 2025 | Added a double-headed arrow to Annotations. Added optional drop shadows for tables with tableShadow . |
5.3 | 11 February 2025 | Added Annotations to run-python . |
5.2.2 | 31 December 2024 | Checklist items can be richer, for example using <span> elements. |
5.2.1 | 23 November 2024 | Checklist items can be optionally coloured red or green, according to status. |
5.2 | 18 November 2024 | Fixed symbol resolution in footers. Tweaked RunPython.ensureTextbox . Added RunPython.removeBullet , RunPython.removeBullets , and RunPython.removeSelectedBullets . Checklist items can be indented. |
5.1 | 26 August 2024 | Fixed failed html import for Numeric Character References.Added Python functions for checklist creation. |
5.0.2 | 26 July 2024 | Added optional columns parameter to RunPython.makeChartData .Added RunPython.filterRows and RunPython.transposeArray support.Specified 'UTF-8' on file read. |
5.0.1 | 14 July 2024 | Added RunPython.alignTableCellText and RunPython.makeDrawnShape support. |
5.0 | 7 July 2024 | Added run-python support. |
4.6.1 | 1 July 2024 | Fixed breakage in hidden . |
4.6 | 30 June 2024 | Use Unicode noncharacters instead of high 8-bit characters for markers. Added hidden metadata and dynamic metadata item. |
4.5 | 16 June 2024 | Support for fontsize in styling. |
4.4 | 6 May 2024 | Support for Python 3.12 and 3.13 (tested with alphas 5 & 6). imghdr package is no longer used to guess graphics file types. |
4.3.3 | 20 January 2024 | Cards can now have audio where a graphic might be. Also media can have a "poster" image for when the media isn't playing. See Card Graphics, Video, & Audio. |
4.3.2 | 17 January 2024 | Cards can now have a video where a graphic might be. See Card Graphics, Video, & Audio. |
4.3.1 | 13 January 2024 | Card graphics are now clickable and can have tooltips. They can also use data: URL's. |
4.3 | 3 January 2024 | Added card graphics support and CardGraphicPosition , CardGraphicSize , and CardGraphicPadding . |
4.2.1 | 28 December 2023 | Made backgroundImage create real slide backgrounds. |
4.2 | 27 December 2023 | Added background image support using backgroundImage . |
4.1.2 | 11 July 2023 | Fixed two bugs: Using <sub> & <sup> causes a crash. Also Card Slides cause a crash. |
4.1.1 | 10 July 2023 | Added numbersFontSize and footerFontSize . |
4.1 | 28 April 2023 | Added funnelLabelsPosition and funnelWidest . Added cardTitleBackground . Added quotation mark related HTML entity references. |
4.0 | 7 April 2023 | Added Funnel support. CardColour can now be pluralised: CardColors or CardColours . |
3.7 | 26 March 2023 | Added cardDividerColour . Most colours now RGB or Theme Colour (documented in Specifying Colours). |
3.6 | 18 March 2023 | Added cardTitleColour & line for cardshape . Allow multiple colours for cardColour . |
3.5.2 | 14 March 2023 | Added pageTitleAlign - for content page title alignment. |
3.5.1 | 3 March 2023 | pageSubtitleSize supports same meaning "same font size as first line". |
3.5.1 | 25 February 2023 | Added support for separately scaling second and subsequent slide title lines - with pageSubtitleSize . |
3.5 | 18 February 2023 | Added support for GraphViz .dot file rendering within triple backticks |
3.4.1 | 23 October 2022 | Added support for a few more slide transitions: wipe , vortex , fracture , split , and push . |
3.4 | 16 October 2022 | Added support for a small number of slide transitions. |
3.3.3 | 8 October 2022 | Fixed bug where coding a MultiMarkdown style heading ID deleted the text to the right. Noted outbound links from headings are a deviation from standard Markdown. |
3.3.2 | 6 September 2022 | Fixed bug where expanding sections crashed md2pptx. Clarified supported section name characters. See sectionsExpand. |
3.3.1 | 3 September 2022 | Processing Summary slide can have up to 5 column pairs. <span class=> matching lower cased. |
3.3 | 9 August 2022 | Added sectionsExpand to enable sections to expand and contract. |
3.2.2 | 10 June 2022 | Enhanced custom footer text with presentation title and subtitle. Added specifying individual lines from these and section titles. Handle <br/> . |
3.2.1 | 8 June 2022 | Added presTitleSize and presSubtitleSize. |
3.2 | 22 May 2022 | Clearing the Processing Summary slide no longer removes Action Button objects. Pseudo-footers can be created. |
3.1 | 27 April 2022 | Added support for VBA macro invocation via ppaction://macro?name= syntax |
3.0.1 | 15 April 2022 | Improved error handling for embedding graphics, video, and audio from the web. Documented here. |
3.0 | 11 April 2022 | Added <video> and <audio> element support, described here. Added some links to the Change Log. |
2.6.1 | 19 March 2022 | Added tableHeadingSize and fixed bug with cell spanning more than 2 columns. |
2.6 | 18 March 2022 | Support multi-column table cells - complying with the MultiMarkdown spec. Added deleteFirstSlide . |
2.5.5 | 5 March 2022 | Make tableMargin , marginBase , and numbersHeight dynamically settable. |
2.5.4 | 3 March 2022 | Where possible use Content-Type HTTP header to determine graphics file type when fetched from the web. |
2.5.3 | 1 March 2022 | Added exception handling when creating temporary file. Also when retrieving files from a URL. |
2.5.2 | 27 February 2022 | Added tempDir to specify where temporary files are stored. |
2.5.1 | 12 February 2022 | Fixed bug 110 - crash on bad metadata line |
2.5 | 14 November 2021 | Added support for . exportGraphics: yes exports PNG for SVG & EPS files. Added support for EPS graphics. |
2.4.3 | 24 October 2021 | Added support for indirect links, complementing reference links. |
2.4.2 | 18 October 2021 | Added hideMetadata: style - to suppress style. items in the Processing Summary slide. Also flag overridden values in same. |
2.4.1 | 2 October 2021 | Fixed bug where code appeared in a slide's Notes slide |
2.4 | 19 September 2021 | Some simple style information added to span support. fgcolor & bgcolor hex RGB metadata values are checked for validity. |
2.3.4 | 7 September 2021 | Added SectionArrows which enables navigation buttons between Section slides. SectionArrowsColour sets the buttons' background colour. |
2.3.3 | 27 August 2021 | Added TOCStyle: plain Table Of Contents layout. Also can enable internal links in TOC and Section slides. Fixed addTableLines bug. |
2.3.2 | 23 August 2021 | Added TOCStyle: circle Table Of Contents layout. Also metadata to control Table Of Contents layout. |
2.3.1 | 21 August 2021 | Forgot to mention prev / pop in documentation for 2.3. |
2.3 | 21 August 2021 | Fixed "slide title as heading reference bug". Added Python release to runtime output. Refactored metadata handling. |
2.2.5 | 5 August 2021 | You can turn on lines after table rows and columns with addTableRowLines and addTableColumnLines . You can also do addTableLines on a slide-by-slide basis. Also addTableLineColour , addTableLineWidth , and addTableLineCount . |
2.2.4 | 30 July 2021 | You can turn on a border round a table or all cells with addTableLines . Fixed bug where slide notes appeared containing code fragments and subtitles. |
2.2.3 | 25 July 2021 | Code etc blocks can include numeric character and entity references |
2.2.2 | 22 July 2021 | Fixed bug where code blocks not initialised to none on starting a new slide |
2.2.1 | 19 July 2021 | Added AdjustTitles - to control whether md2pptx adjusts slide title positions and sizes. Made slide notes work again. |
2.2 | 20 June 2021 | Added IndentSpaces - to control, including dynamically, how many spaces represent a single level of list indentation. |
2.1 | 21 May 2021 | Added λ , μ , ν , &pi , &rho . Allow more than one table or code block on a slide. |
2.0.2 | 3 May 2021 | A single code block can share a slide with a list block or a table / graphics block |
2.0.1 | 1 May 2021 | Added × , % , ÷ , ∀ , ∃ . Fixed 'three up graphic' layout bug. |
2.0 | 11 April 2021 | Two slide content elements on a slide, involving a major restructuring of the slide layout engine. |
1.9.5 | 28 March 2021 | Added … . Allow specification of gaps between cards. Allow specification of heading level for title slide. |
1.9.4 | 21 March 2021 | Added controls code slide foreground and background colour RGB values. |
1.9.3 | 21 March 2021 | Added controls on how many columns wide code is and fixed pitch height to width ratio. |
1.9.2 | 16 March 2021 | Added <pre> , <code> , triple backtick - with <span> colouring for <pre> . Added ways to make a no-title slide. |
1.9.1 | 6 March 2021 | Added ✓ entity reference. Reworked internals with more consistent layout and getContentRec and title formatting improvements. Prereq Python 3.8. |
1.9 | 17 February 2021 | Add support to specify which slide in master. Also numbersMargin |
1.8.1 | 10 February 2021 | Card options: Rounded versus square corners. Titles above or in cards |
1.8 | 31 January 2021 | SVG support for file and web graphics |
1.7.2 | 24 January 2021 | Make vertical bars optional around image references |
1.7.1 | 11 January 2021 | Fixed bug where hyperlinks in slide titles didn't work |
1.7 | 9 January 2021 | Added support for numbered list items |
1.6.3 | 2 January 2021 | Added support for vertical cards. Also new CardTitleAlign and CardLayout metadata, plus basetextsize and basetextdecrement Dynamic Metadata items. |
1.6.2 | 1 January 2021 | Added 3 slide-level Dynamic Metadata capabilities and cardpercent metadata value. |
1.6.1 | 29 December 2020 | Added <a id= as an alternative hyperlink anchor. |
1.6 | 22 December 2020 | Added Card Slide support. Metadata keys are now case-insensitive. |
1.5 | 7 December 2020 | Pictures now can have a tooltip. You can define inter-slide links on both pictures and runs of text. You can omit the final ` |
1.4 | 23 November 2020 | Task slides' slide numbers are hyperlinked to the relevant slide |
1.3 | 20 November 2020 | Glossary terms now have tooltips and hyperlinks to the relevant Glossary slide. Footnotes have hyperlinks to the relevant Footnotes slide. |
1.2 | 3 November 2020 | Support URLs for graphics. Reworked Processing Summary slide to use a flowed table. |
1.1 | 25 October 2020 | Introduce Template as a better replacement for Master - which still works. Add German characters. Better template file searching. Escape underscore. Better handling of continuation onto second and subsequent lines. |
1.0 | 13 October 2020 | Python 3, Support input filename as first command line parameter. |
0.9 | 4 September 2020 | Footnote slide support |
0.8 | 14 June 2020 | bgcolor is now style.bgcolor . Added style.fgcolor and style.emphasis . |
0.7.3 | 24 May 2020 | Allow background colouring via span elements |
0.7.2 | 14 April 2020 | Support three graphics on a slide. Added = entity reference. Added tableMargin . |
0.7.1 | 14 November 2019 | Make slide titles longer. Fixed formatting issue with one-graphic-above-another table slide. |
0.7 | 3 November 2019 | Support abbr element as a glossary item. Each distinct term leads to a glossary slide entry at the back of the presentation. |
0.6 | 8 October 2019 | Support vertical pair of graphics in a table Fixed some issues with Markdown-syntax hyperlinks Support escaped square brackets \[ and \] ,[ and ] being newly-supported alternatives |
0.5 | 12 May 2019 | CriticMarkup support |
0.4.5 | 5 May 2019 | Some numeric character references |
0.4.4 | 6 March 2019 | Processing summary slide shows build date and time |
0.4.3 | 20 January 2019 | Support a few HTML entity references - punctuation and arrows. Support split task slide sets - completed and incomplete. Task tags are sorted. |
0.4.2 | 13 January 2019 | Tasks slide set controllable with metadata taskSlides and tasksPerSlide |
0.4.1 | 9 January 2019 | Enhanced Taskpaper support with @due , @tags , and @done , and reworked as a series of table slides. |
0.4 | 7 January 2019 | Support shrinking of table cell font and margins. Added two-to-by-two grid of graphics on a slide. |
0.3.2 | 3 January 2019 | Support \# as a literal octothorpe/hash/pound.Tidied up reporting. Added superscript, subscript, strikethrough, and underline text effects. |
0.3.1 | 3 November 2018 | Fixed support for <br/> so it won't create a bullet on the new line. |
0.3 | 22 October 2018 | Added customisation for bold and italic text |
0.2 | 3 September 2018 | Added ways of controlling bullet sizes |
0.1 | 1 April 2018 | Initial Prototype |
Let's start with a simple example. Consider the following text.
template: Martin Template.pptx
pageTitleSize: 24
sectionTitleSize: 30
# This Is the Presentation Title Page
## This Is A Section
### This Is A Bullet Slide
* Bullet One
* Sub-bullet A
* Sub-bullet B
* Bullet Two
* Bullet Three
You can try it if you like. Just cut it and paste it into a file. Call it something like Example.markdown.
It will render something like this:
The first slide is special, and an almost inevitable feature of using the python-pptx library. You will probably want to remove it before publishing.
If there is at least one slide in the presentation template md2pptx uses the first one to create a processing summary. The processing summary slide shows processing options, the time and date the presentation was created by md2pptx, and metadata.
Metadata is specified in the first three lines of this sample. In general metadata is the set of lines before the first blank line. It consists of key/value pairs, with the key separated from the value by a colon.
In this case the metadata specifies a number of things:
- The Powerpoint file the presentation is based on is "hipodz.pptx".
- Each slide with a title has a title font 22 points high.
- Each presentation section slide has a title font 30 points high.
- A number of other styling-related specifications.
All of the above are optional but you will almost certainly want to specify a template. Feel free to copy Martin Template.pptx - which is included with md2pptx - and make stylistic changes.
For more on metadata see Controlling The Presentation With Metadata.
As you can see the format of each slide is fairly straightforward. How to code slides is described in the following sections.
You code a presentation title slide with a Markdown Heading Level 1:
# This Is the Presentation Title Slide
If you type anything in subsequent lines - before a blank line - the text will appear as extra lines in the presentation title. You might use this, for example, to add the presentation authors' details.
(You can adjust the Markdown heading level for this type of slide with TopHeadingLevel
.)
You code a presentation section slide with a Markdown Heading Level 2:
## This Is A Section
You can code multiple lines, as with Presentation Title slides.
Notes:
- You can adjust the Markdown heading level for this type of slide with
TopHeadingLevel
- You can make the section slides be the start of expandable and contractable sections with
sectionsExpand
.
Bullet slides use Markdown bulleted lists, which can be nested. This example shows two levels of nesting.
### This Is A Bullet Slide
* Bullet One
* Sub-bullet A
* Sub-bullet B
* Bullet Two
* Bullet Three
The title of the slide is defined by coding a Markdown Heading Level 3 (###
).
Note: You can allow the title to spill onto a second line but it is better to break titles up using <br/>
. Doing so enables md2pptx to layout slide contents below the title better. It also allows you to specify a different (probably) smaller font size for the second and subsequent lines of the title.
Bulleted list items are introduced by an asterisk.
Note: Some dialects of Markdown allow other bullet markers but md2pptx doesn't. You can be sure by coding *
you have valid Markdown that md2pptx can also process correctly. For an explanation of why you have to stick to *
see here.
To nest bullets use a tab character or 2 spaces to indent the sub-bullets. md2pptx doesn't have a limit on the level of nesting but Powerpoint probably does.
Terminate the bulleted list slide with a blank line.
Note: You can alter the number of spaces that represent each level of indenting. See Specifying How Many Spaces Represent An Indentation Level With IndentSpaces
. If you use tabs they will be converted to the the appropriate number of spaces internally.
Within a bullet slide you can have numbered items. Here is an example of a slide with mixed numbers and bullets:
### This Is A Mixed Numbers And Bullets Slide
* Bullet One
1. Numbered sub-bullet A
1. Numbered sub-bullet B
* Bullet Two
* Bullet Three
Numbered list items are introduced with an integer, followed by a full stop.
Markdown takes care of the numbering. In the above example there are two numbered items. While the first will indeed be numbered "1" the second will be numbered "2", despite the 1.
coding.
Numbering with 1.
is actually a useful practice - as it makes it easier to reorder a numbered list (by moving the lines around).
Note: You can mix numbered and bulleted items in a list.
You can embed three kinds of media in slides:
These media items can be from your file system, or over the web.
If a local file is found a simple "missing" file message is printed.
In the case of over the web, two kinds of errors can be detected and reported:
- The domain is unreachable, reported as a socket error.
- The domain is reachable, but an error occurred in retrieving the file. In this case the HTTP code is reported, helping you debug whether the filename is wrong (404) or some other issue.
As with bullet slides, code the slide title as a Markdown Heading Level 3. Specify the graphic to embed with the standard Markdown image reference:
### A Graphic Slide
![](graphics/my-graphic.png)
The graphic will be scaled to sensibly fill the slide area.
If you code a string inside the square brackets it will be used as a tooltip (or screentip, in Powerpoint parlance). In Presentation Mode, when you hover over the graphic the tooltip will be displayed. Here is an example:
![Here is a tooltip](graphics/my-graphic.png)
HINT: If you want two graphics side by side use a single-row table, described here. If you want two graphics one above the other use a two-row, single-column table, described here.
You can make a picture clickable, with an optional tooltip. This means you can click on a picture in slideshow mode to go to another slide. The tooltip is shown in slideshow mode when your mouse hovers over the picture.
Here's an example, showing both a tooltip and a clickable link.
[![Foo Fighters Sonic Highways](https://upload.wikimedia.org/wikipedia/en/6/67/Foo_Fighters_8LP_Sonic_Highways.jpg)](#sonic-highways)
Here the image reference is embedded in the clickable link:
- The tooltip text is
Foo Fighters Sonic Highways
. - The picture's source is
https://upload.wikimedia.org/wikipedia/en/6/67/Foo_Fighters_8LP_Sonic_Highways.jpg
- The target slide has the heading reference
sonic-highways
.
To create a hyperlink to a slide with heading reference code something like this as the title of that slide:
### My Slide’s Title [sonic-highways]
See Hyperlinks for more on creating hyperlinks.
md2pptx supports graphics references in three different formats:
- A local file reference -
![](~/Documents/Customers/XYZCO/sysplexes.png)
- A HTTP(S) reference -
![](http://www.anyfirm.co/banner.jpeg)
- A
data:
URI reference -![]()
The data:
URI example actually works! Try it.
For cases other than the local file, the reference - when displayed by md2pptx - is shortened to show the beginning and the end of the reference. This is to make it easy to recognise if you've accidentally repeated the reference. Here is an example:
Slides:
=======
1 Test Title --> .../Nka02WcDC6hCtKgQhCAP/9k=
For image graphics only PNG and JPEG have been tested. While the code doesn't explicitly prohibit other image file types they aren't currently supported.
Scalable Vector Graphics (SVG) format is only supported if you have installed the CairoSVG Python package - as PowerPoint doesn't support it (and nor does python-pptx). SVG files - whether from the web or a local file - are converted to a temporary PNG file first, before copying into the PowerPoint slide deck.
SVG support uses the CairoSVG library - which requires Python to be at least at the 3.6 level. md2pptx's SVG support is limited by that available in CairoSVG and so not all SVG files are supported.
If CairoSVG is not installed and md2pptx encounters an SVG graphic reference it will write a message reminding you of the need for CairoSVG. md2pptx will then immediately terminate.
Encapsulated Postscript (EPS) format is only supported if you have installed the Pillow Python package and Ghostscript - as PowerPoint doesn't support it (and nor does python-pptx). EPS files - whether from the web or a local file - are converted to a temporary PNG file first, before copying into the PowerPoint slide deck. Pillow requires Python to be at least at the 3.7 level.
You can optionally have md2pptx export the temporary PNG files. See Exporting Converted SVG And PNG Files - exportGraphics
. The file name is the same as the SVG or EPS file's name, except the extension is PNG.
Notes:
-
You can specify which directory temporary files, such as temporary graphics, are stored in - using
tempDir
. -
For graphics - whether image or vector - retrieved from the Internet md2pptx will attempt to acquire the MIME type (
Content-Type
HTTP header) to determine what type the graphic is:- PNG -
image/png
- JPEG -
image/jpeg
orimage/jpg
(though the latter is unofficial) - SVG -
image/svg+xml
orimage/svg
(though the latter is unofficial) - EPS -
application/postscript
- PNG -
-
For graphics from files on disk the file extension is used to guess the type.
Videos and audio files are supported in a similar way to graphics slides. However, there is no Markdown support for embedding videos or audio files. Fortunately, Markdown processors support HTML.
You should be aware that, though you can legitimately embed a video or audio, Powerpoint might not be able to play it on all platforms.
md2pptx supports embedding videos using the HTML <video>
element.
Here is an example:
<video height=300 width=400 src="waterdrop.mp4"></video>
md2pptx uses the values of the height
and width
elements to compute the aspect ratio of the video. In this example the ratio of the width to height is 4 to 3.
Optionally, you can code a poster
attribute. This defines a static graphic to be displayed when the video isn't playing. Here's an example:
<video width="400" height="300" src="waterdrop.mp4" poster="Battery W3M.png">
Notes:
- Unlike with graphics specified according to Graphics Slides, the poster graphic's dimensions are not used to scale the poster graphic or the video.
- md2pptx supports only the simplest form of the
<video>
element.
md2pptx supports embedding audio files using the HTML <audio>
element.
Here is an example:
<audio src="audiotest.mp4"></audio>
Optionally, you can code a poster
attribute. This defines a static graphic to be displayed when the audio file isn't playing. Here's an example:
<audio src="audiotest.mp4" poster="my-album-cover.png"></audio>
Notes:
- The HTML
<audio>
element does not supportwidth
orheight
attributes. md2pptx scales the audio file on the slide to be square. - Unlike with graphics specified according to Graphics Slides, the poster graphic's dimensions are not used to scale the poster graphic or the audio file.
- md2pptx supports only the simplest form of the
<audio>
element.
You can create a table slide using Markdown's table format.
Code a title with a Markdown Heading Level 3. Then code a table. Here is a simple example of a table:
|Left Heading|Centre Heading|Right Heading|
|:----|:-:|--:|
|Alpha|Bravo|1|
|Charlie|Delta|2|
In this example there are three columns and three rows. The first row is the heading row. The third and fourth rows are data rows.
The second row controls the alignment of each column and their width:
- In the first column the leading colon denotes the text is to be left-justified.
- In the second column the colons either end denotes the text is to be centred.
- In the third column the trailing colon denotes the text is to be right-justified.
- According to the number of dashes the columns have widths in the ratio of 4 to 1 to 2.
In other Markdown processors the widths of the columns can't be specified in this way; The relative width specifications will be ignored.
Each cell can consist of text, which will wrap as necessary. You can't embed images in a table slide. But see here and here.
As a convenience, you can omit the final |
on a line. While this isn't strictly Markdown compliant this might be helpful.
The best Markdown fit for two graphics side by side is a single row table with two cells. md2pptx will "special case" such a table.
If you code something like this the two graphics will be placed next to each other:
|![](left-graphic.png)|![](right-graphic.png)|
A table won't be created in this case.
Don't code any headings or more than one row.
For the types of graphics supported see Graphics File References.
For how to make such graphics clickable or have a tooltip see Clickable Pictures.
Note: Regular Markdown processors don't support pictures in tables; They render the |
characters literally. For this reason the vertical bars are optional.
The best Markdown fit for four graphics on a slide is a two row table with two pairs of cells. md2pptx will "special case" such a table.
If you code something like this the four graphics will be placed in two rows of two:
|![](top-left-graphic.png)|![](top-right-graphic.png)|
|![](bottom-left-graphic.png)|![](bottom-right-graphic.png)|
A table won't be created in this case.
Don't code any headings or more than two rows.
To achieve the best result some margins around the graphics are reduced.
For the types of graphics supported see Graphics File References.
For how to make such graphics clickable or have a tooltip see Clickable Pictures.
Note: Regular Markdown processors don't support pictures in tables; They render the |
characters literally. For this reason the vertical bars are optional.
The best Markdown fit for three graphics on a slide is a two row table:
- The first row has two graphics.
- The second row has one graphic, centred in the row.
md2pptx will "special case" such a table.
If you code something like this the three graphics will be placed appropriately:
|![](top-left-graphic.png)|![](top-right-graphic.png)|
|![](bottom-graphic.png)|
Here the layout will be a "T".
A table won't be created in this case.
Don't code any headings or more than two rows.
To achieve the best result some margins around the graphics are reduced.
There are some variants on the above scheme. For example, if you code:
|![](top-graphic.png)|
|![](bottom-left-graphic.png)|![](bottom-right-graphic.png)|
Here the layout will be an inverted "T".
You can also force left alignment or right alignment of the sole graphic in a row. For example:
|![](top-leftgraphic.png)||
|![](bottom-left-graphic.png)|![](bottom-right-graphic.png)|
will align the sole top-row graphic to the left.
For the types of graphics supported see Graphics File References.
For how to make such graphics clickable or have a tooltip see Clickable Pictures.
Note: Regular Markdown processors don't support pictures in tables; They render the |
characters literally. For this reason the vertical bars are optional.
The best Markdown fit for two graphics, on above the other, on a slide is a two row table with a single cell in each row. md2pptx will "special case" such a table.
If you code something like this the two graphics will be placed in two rows of one:
|![](top-graphic.png)|
|![](bottom-graphic.png)|
A table won't be created in this case.
Don't code any headings or more than two rows.
For the types of graphics supported see Graphics File References.
For how to make such graphics clickable or have a tooltip see Clickable Pictures.
Note: Regular Markdown processors don't support pictures in tables; They render the |
characters literally. For this reason the vertical bars are optional.
Markdown supports cells that span more than one contiguous column. Here's an example:
|A||C|
|:-:|:-:|:-|
|Two cells?||One?|
|1|2|3|
||A|B|
In this example
- The empty cell in the heading line causes the "A" cell to occupy the first two columns.
- The empty cell after "Two Cells?" causes "Two Cells?" to occupy the first two columns.
- The empty cell at the beginning of the final row leads to an empty first cell. "A" is in the second column.
A card slide contains multiple panels - or cards. They come in two flavours:
- Horizontal - where the cards are next to each other
- Vertical - where the cards are one above the other
For the rest of this section the assumption is that cards are horizontally arranged. (Vertically-arranged cards are very similar.)
Each card has a title and, below that, the contents are defined using the same syntax as in Bullet Slides. In fact this slide type is derivative of the Bullet Slide type.
A horizontally-arranged card slide can look something like this:
The key features of this slide are:
- A title, coded with Markdown Heading Level 3 syntax (
###
). - An optional panel above the cards, coded using Bullet Slides syntax.
- A sequence of cards, coded one after the other but displayed side by side:
- The title is coded using Markdown Heading Level 4 syntax (
####
). - The body of the card is coded using Bullet Slides syntax.
- The title is coded using Markdown Heading Level 4 syntax (
The width of each card is calculated depending on the number of cards. In this example the horizontal space is divided equally between the 4 cards.
In the above example there has been a small amount of tweaking of the format, using metadata. You can control the exact format using many tweaks:
- Card Background Colours
- Card Border Colour
- Card Border Width
- Card Title Font Size
- Card Title Colour
- Card Title Background Colours.
- Card Divider Colour
- Card Shadow
- Card Size
- Card Layout Direction
- Card Title Alignment
- Card Title Position
- Card Shape
- Card Horizontal Gap
- Card Vertical Gap
- Card Graphic Position
- Card Graphic Size
- Card Graphic Padding
One example of using a different style is this:
Here the card background is invisible but the cards are separated by lines. You achieve this by coding:
CardShape: line
(See Card Shape for more information.)
In the above examples the card titles are above the cards. You can specify that the card titles are inside the cards, at the top. To do this code:
CardTitlePosition: inside
(See Card Title Position for more information.)
You can suppress a title by coding its text value to
. If you do this for all the titles on a card slide the space reserved for card titles will be zero. If there are some titles not treated this way the
-titled cards will have a gap where the title would have been.
You can add a single graphic, video, or audio file to each card. They can be placed in reserved areas before or after the card bulleted list contents.
Place any graphic, video, or audio declaration between the card's title and the card's contents. For example:
#### Card One
![](block.png)
* Some content for Card One
* And some more content
As you can see, the image reference is just a standard Markdown one. A video reference might be of the form:
<video height=300 width=400 src="waterdrop.mp4"></video>
An audio reference might be of the form:
<audio src="audiotest.mp3" poster="Battery W2M.png"></audio>
In this case the poster
attribute is coded. This enables a graphic to be shown when the audio player isn't activated. You can also code the poster
attribute for a video.
Notes:
- You must code a non-zero value for
CardGraphicSize
for graphics or videos to be shown. The default is 0. - If a card doesn't have a graphic or a video the bulleted list contents can fill the whole of the card (except for any title inside the card).
- Card graphics can have tooltips and can be clickable. See Graphics Slides for how to code this. (audio and video can't.)
- Media (audio or video) might not be playable on a specific platform, even though it has been legitimately embedded in a presentation.
You can create a slide where the body is in a monospace font, without bullets, in a number of different ways:
- Where what you type appears exactly as you typed it - using
<code>
, triple backticks, or by indentation. - Where what you type can be coloured, using
<pre>
and<span>
elements, together withstyle.fgcolor
etc specifications.
When we say "code", what you're displaying could be something like a terminal screen shot, of course. What's important is that it will be rendered in a fixed-pitch font.
In each case, the heading for the slide is generally introduced with heading level 3 - ###
. However you can start a slide without a heading. See Slides Without Titles for how to do this.
You can include HTML entity references and numeric character references. For example you might code ❶
to place ❶ next to a line of code. You could then code the same thing in a table below the code fragment, where each row explains a line of code.
Notes:
- Do not code numeric character references in the range FFD0 to FFEF. These are - in Unicode terms - noncharacters. md2pptx uses them internally when parsing text.
- You can more precisely control how code slides are laid out and their colours with Code Metadata.
The HTML <code>
element is supported. Surround the block of text by <code>
and </code
:
### This Is A Code Slide
<code>
for(i = 0; i < 10; i++){
alert(i)
}
</code>
Note: It, as in HTML, does not support <span>
elements.
Triple backticks are supported. Surround the block of text by them:
### This Is A Code Slide
```
for(i = 0; i < 10; i++){
alert(i)
}
```
Note: It does not support <span>
elements.
If you have GraphViz installed you can render GraphViz diagrams as graphics.
On startup md2pptx will check whether the graphviz Python package is installed. It cannot check if the GraphViz application is installed - but you need that as well to process GraphViz .dot data.
If both the graphviz package and the GraphViz application are installed you can render .dot file format lines. Here is an example:
```dot
digraph G{
edge [dir=forward]
node [shape=plaintext]
0 [label="0 (None)"]
0 -> 5 [label="root" color = blue]
1 [label="1 (Hello)"]
2 [label="2 (how)"]
2 -> 1 [label="advmod"]
3 [label="3 (are)" fontcolor = green]
4 [label="4 (you)"]
5 [label="5 (doing)"]
5 -> 3 [label="aux"]
5 -> 2 [label="advanced mod"]
5 -> 4 [label="nsubj"]
}
```
This will be rendered as a graphic and inserted in the current slide. The graphic will be scaled as appropriate.
This is how the above code is rendered
Each line of the code fragment - to be displayed in a monospace font - is indented with 4 spaces:
### This Is A Code Slide
for i in range(10):
print(i)
Note: It does not support <span>
elements.
The HTML <pre>
element is supported. Surround the block of text by <pre>
and </pre
:
### This Is A Code Slide
<pre>
for(i = 0; i < 10; i++){
alert(i)
}
</pre>
Note: It, as in HTML, does support <span>
elements. This is the best way to provide syntax colouring. You can use style.fgcolor
, style.bgcolor
, and style.emphasis
to style the text. To do this you use the class
attribute:
<span class="keyword">for</span> (i = 0; i < 10; i ++)
Funnels depict a funnel, with the wide part to the left. Each successive stage in the funnel narrows the funnel. In a sense this is like a pipeline, with stages. Here each stage but the last narrows the pipe. md2pptx can create such slides from CSV data. A typical result looks like this:
In this example the funnel is rendered below some bullets. You can render funnels on the same slide as other items, which can be of any type.
The code to create this slide is:
### This Is A Funnel Slide
<!-- md2pptx: contentSplit: 1 3 -->
<!-- md2pptx: funnelColours: ACCENT 3, ACCENT 4, ACCENT 5 , ACCENT 6 -->
* Here is some text above the funnel diagram
* The funnel parts are described by two-column CSV rows
* Columns after the first two are ignored
``` funnel
1000 / Week<br/>(Roughly),Website<br/>Hits
100 / Week,Enquiries
80 / Week,Qualified
70 / Week,Signed
65 / Week,Delivered
```
Each row leads to a funnel stage. The first column is the text for the label above each stage body. The second column is the text for the stage body.
Notes:
- You can force line breaks in both the funnel stage titles and the funnel stage bodies.
- You can specify aspects of funnels' appearance with metadata.
- Any CSV columns after the first two are ignored.
You can create tasks in a subset of the Taskpaper format by coding a line that starts with a -
:
- MARTIN: Complete The User Guide
If md2pptx detects any such tasks it removes them from the body of the presentation and adds them to a special set of "Tasks" slides at the end of the presentation. If no tasks are detected these slides are not created.
Taskpaper is a very flexible and simple text-based task management system. md2pptx parses anything after the -
simplistically but doesn't invalidate the Taskpaper format:
- Anything after the
-
leading character and before the first@
symbol, if any, is the task title. - Anything bracketed by
@due(
and)
is treated as a due date - but the date isn't actively parsed. - Anything bracketed by
@tags(
and)
is treated as a set of tags. Tags are separated by a space or a comma and they are sorted. - Anything bracketed by
@done(
and)
is treated as a completion date - but it isn't actively parsed. (An uncompleted task need not have anything in inside the bracket - or the@done
could be missing.)
The task title, any due date, any tags, and any completion information, are added as a table row to the set of tasks.
Because of Taskpaper support you can't start a bullet with a -
. So always start bulleted list items with a *
.
Tasks on the Tasks slides are shown with the slide number they were coded on. If you click on the slide number you are taken to the corresponding slide.
Here's a more comprehensive example. Coding
- Complete abstract @due(2019-01-11) @tags(Anna,Martin)
will cause a task to appear with title "Complete abstract", a due date of "2019-01-11", and tags "Anna,Martin". In this case the task has implicitly not been completed. (It would be possible to achieve the same effect by coding @done()
.)
Task slides are paginated: Multiple task slides are created, each with the task slide number appended to the title, if there are more than a certain number of tasks.
You can control task slide production by specifying taskSlides
and tasksPerSlide
. See Controlling Task Slide Production With taskSlides
and tasksPerSlide
.
md2pptx started with a very simple layout scheme: A single content block on a slide (in addition to the title). Those content blocks are:
- A numbered or bulleted list, perhaps with cards
- A table or else some graphics
- A block of code
Beginning with md2pptx 2.0, this restriction has been gradually relieved.
You can code, for example, two blocks. Write them as you would for regular Markdown. Here is an example:
### Here Is A title
* Here is a bullet
* Here is a sub-bullet
![](my-graphic.png)
The order in which, in this example, the bulleted list and the graphics blocks appear matters:
- For horizontal layout the bulleted list would appear to the left of the graphic.
- For vertical layout the bulleted list would appear above the graphic.
You can still only code one list block, with its optional set of cards. You can code multiple code blocks, and multiple tables.
You can code up to 10 content blocks, though in practice such a slide would probably be overcrowded.
In a text editor it's simple to reverse the order of these two blocks of content.
You can specify two aspects of splitting a slide between the various blocks of content:
- Whether the split is horizontal or vertical, the default being vertical.
- What proportion of the content space is the first block, and what proportion is the second.
These controls are described in Slides With Multiple Content Blocks.
Notes:
- You can't specify two list / card blocks on a single slide.
- For graphics, if you specify more than one graphic this will count as a single block. For example, two graphics side by side is a single block.
You can add notes to slides. In Powerpoint these appear below the main slide (and aren't shown when projecting a slide presentation).
To add a slide note leave a blank line after the slide's contents. Then add paragraphs of text. Plain text paragraphs are separated by blank lines, as is standard in Markdown.
You can use entity references, such as %
.
You can also use some other kinds of markup, such as hyperlinks and <abbr>
elements.
Using hyperlinks when viewing slide notes in the Powerpoint application is cumbersome - as there is no equivalent for slide notes of Slide Show Mode. To follow a hyperlink in slide notes:
- Right click on the hyperlink.
- Select the Hyperlink menu item.
- Select Open Hyperlink.
It should then open in your browser.
Notes:
- It would be confusing (to the parser) to support structured items such as bulleted lists in slide notes. For this reason they are not supported.
- You can intersperse notes with slide contents. For example, you can follow a code block with slide note paragraphs that describe that code block. Then have another code block on the same slide, followed by its explanatory notes. All the notes will be gathered into the notes slide, which is not how other markdown processors would handle it. They would intersperse the paragraphs and the code blocks - in the order you coded them.
Most slides have a title - and it's easy to see where such slides start. However, sometimes you want a slide without a title. For those cases you can start a slide in a two basic ways:
- Use a horizontal rule
- Use a level 3 heading with a non-breaking space:
The most likely use case is for code slides, though you might continue a bulleted-list slide this way.
Note: If you continue a numbered list onto a new slide its number will reset to 1.
You can code a horizontal rule in a number of ways - which all Markdown processors should be able to handle:
- Code an HTML
<hr/>
element. - Code a line starting with
***
,---
or___
. You can continue these as far to the right as you like.
Most of the time this is the technique you'll want to use but note other Markdown processors are likely to actually produce a horizontal rule.
Code the following on its own line:
###
This has the perhaps-useful side effect of not drawing a horizontal rule in most other Markdown processors.
md2pptx allows you to create links and invoke VBA macros. You can code
- URL References, perhaps to an external web site.
- Hyperlink references to other slides in the same presentation.
- Links that invoke VBA macros in the same presentation.
You can code such references in the body of a slide or its heading (though, as documented in Deviations From Standard Markdown, the latter is not standard Markdown). )
To code a hyperlink to an external URL in a slide code something like:
[IBM Website](https://www.ibm.com)
It will be rendered with the text "IBM Website" displayed: IBM Website. This above works for external references. To create an internal slide reference you need to do two things:
- Tag the heading of the target slide with a heading reference (href).
- Code a reference to the target slide using the href.
The above syntax is in a form called Reference Hyperlinking. You can use an alternative form - called Indirect Hyperlinking. To code an external URL using an indirect hyperlink use the form
[IBM Website][IBM]
[IBM]: https://www.ibm.com
You might prefer the indirect form to the (inline) reference form for a couple of reasons:
- You can reuse the same link, coding it in one place.
- You can code such a link anywhere, potentially collecting links at the end of your Markdown file.
Multimarkdown and md2pptx support the following way of identifying a heading reference (href):
### z15 Processor Architecture [z15-arch]
* 12 Cores Per PU Chip
* Most of which are enabled
* 4 PU Chips per drawer
* 1-5 drawers per machine
The above is a slide with a title ("z15 Processor Architecture"). You can link to this slide using the href ("z15-arch").
An alternative method of specifying a target is like this:
### z15 Processor Architecture
<a id="z15-arch"></a>
* 12 Cores Per PU Chip
* Most of which are enabled
* 4 PU Chips per drawer
* 1-5 drawers per machine
This method is provided because it is the only reliable within-a-document hyperlink target syntax that both GitHub and other Markdown processors support.
You can refer to the slide in a hyperlink using the href. Here's an example:
### Attributes Of A High Performance System
* For how a high performance system is built see [here](#z15-arch)
- The bullet links to the slide with href
z15-arch
. - You click on the word
here
in a presentation to move to the referred-to slide.
If the source presentation contains macros you can invoke them using a special Powerpoint URI of the form:
ppaction://macro?name=myMacro
You can use this form of URL in a text run:
[Run The Macro](ppaction://macro?name=myMacro)
And you can use this form from a graphic:
[![](button-picture1.png))](ppaction://macro?name=myMacro)
When you run the slide show these links become "live"; Clicking on them runs the macro. You might get a security warning - but there is some control over to what degree Powerpoint's macro security is managed.
As documented in Deviations From Standard Markdown, the "ppaction://" URI won't work in HTML.
Notes:
- The template presentation must have the extension ".pptm" for "Powerpoint With Macros".
- The generated presentation will also have the extension ".pptm".
- You can only invoke macros already in the template presentation.
- The generated presentation can be converted to ".pptx" in Powerpoint itself.
You might want to remove the first slide - for Production. Here's a macro that will do that:
Sub x()
ActivePresentation.Slides(1).Delete
End Sub
You could invoke it from a slide with:
[Remove First Slide](ppaction://macro?name=removeFirstSlide)
or you could place an Action Button to run the removeFirstSlide
macro on the Processing Summary slide itself. To do that edit the template presentation and place a custom button on the first slide.
Here is a sample set of macros that further prepare the presentation for Production:
Sub removeFirstSlide()
ActivePresentation.Slides(1).Delete
End Sub
Sub savePresentationAsPPTX()
Dim pptmName As String
pptmName = ActivePresentation.FullName
Dim pptxName As String
pptxName = Left(pptmName, InStr(pptmName, ".")) & "pptx"
ActivePresentation.SaveAs pptxName, ppSaveAsOpenXMLPresentation
End Sub
Sub removeFirstSlideAndSaveAsPPTX()
Call removeFirstSlide
Call savePresentationAsPPTX
End Sub
Again, you might place an Action Button to run removeFirstSlideAndSaveAsPPTX
on the Processing Summary slide.
You can use HTML-style comments, ranging over multiple lines.
Start the first line with <!--
.
End the last line with -->
.
md2pptx will throw away HTML comments, rather than adding them to the output file.
The one exception is the use of Dynamic Metadata. md2pptx will honour these.
Note: Other Markdown processors will copy the comment into the output file. Put nothing in the comments that is sensitive.
Markdown and md2pptx allow additional ways of formatting text. The syntax md2pptx supports is a subset of what many Markdown processors allow.
To specify bold surround the text with pairs of asterisks - **bold**
.
To specify italics surround the text with single asterisks - *italics*
.
If you actually want an asterisk code either \*
or the asterisk surrounded by spaces. (An asterisk at the end of a line need only have a preceding space.) Alternatively you can code an HTML entity reference - ∗
.
If you actually want an octothorpe/hash/pound symbol (rendered "#") code \#
.
You can use bold and italics syntax to change the colour of highlighted text. See here for more.
To specify a monospace font
use the back tick character - `
- at the start and end of the text run.
To force a line break code <br/>
. This, being HTML, is legitimate in Markdown and will be treated as a line break. I don't want one here so I won't code one here.
Some other HTML-originated text effects work - as Markdown allows you to embed HTML (elements and attributes):
Effect | HTML Element | Example | Produces |
---|---|---|---|
Superscript | sup |
x<sup>2</sup> |
x2 |
Subscript | sub |
C<sub>6</sub>H<sub>12</sub>O<sub>6</sub> |
C6H12O6 |
Underline | ins |
this is <ins>important</ins> |
this is important |
Strikethrough | del |
this is <del>obsolete>/del> |
this is |
Note: Superscript works by raising the text baseline. Subscript works by lowering it. This is how Powerpoint itself does it.
You can set a number of attributes for a piece of text:
- Foreground colour
- Background colour
- Font effects such as bold
- Font size
To do this use the <span>
HTML element:
- You can use
<span class= "..." >
- which is probably more compact but less direct. - You can use
<span style= "..." >
- which is more direct but less compact.
Where the same styling needs to be applied to multiple pieces of text the class
attribute is probably the most appropriate. Here is an example:
I would like to highlight <span class="yellow">this bit</span> but not **this** bit.
In this example the span
element specifies a class
attribute. The class name must match one specified in the metadata using one of
style.bgcolor.
- described in Associating A Class Name With A Background Colour Withstyle.bgcolor
.style.fgcolor
- described in Associating A Class Name With A Foreground Colour Withstyle.fgcolor
.style.emphasis
- described in Associating A Class Name With Text Emphasis Withstyle.emphasis
.style.fontsize
- described in Associating A Class Name With Font Size Withstyle.fontsize
.
If you coded metadata
style.fgcolor.yellow: FFFF00
the result would be something like this:
I would like to highlight this bit but not this bit.
Notes:
- A fragment of text in a span can't use any other text effect, such as bolding or italics.
- The class name can be specified with double quotes, single quotes, or no quotes at all.
- Class name matching is done in a case-insensitive way.
If you want to be able to process the text using a normal Markdown processor you can code Cascading Style Sheet (CSS) using the HTML <style>
element. md2pptx will ignore any HTML after the metadata and before the first real Markdown text. For example:
<style>
.mytest{
text-decoration: underline;
color: #FF0000;
background-color: #FFFF00;
font-weight: bold;
font-style: italic;
font-size: 24px;
}
</style>
The above uses only the style elements that md2pptx supports with style.
metadata. It relies on you coding
<span class="mytest">Here is some text</span>
for example - as it uses the class mytest
.
You can specify a limited number of types of styling:
- Foreground colour with
color
- Background colour with
color
- Underlining with
text-decoration: underline
- Bold with
font-weight: bold
- Italic with
font-style: italic
- Font size with
font-size
Here is an example:
Here's <span style="font-weight: bold;font-style: italic;color: #0000FF;font-size: 16.5px;">blue bold italic</span> text.
Notice the color
specification is in Hexadecimal RGB (Red Green Blue) format. CSS colour names are not supported.
md2pptx supports a few HTML entity references:
Entity Reference | Character | Entity Reference | Character | Entity Reference | Character | Entity Reference | Character |
---|---|---|---|---|---|---|---|
< |
< | ← |
← | ä |
ä | grave; |
` |
> |
> | → |
→ | Ä |
Ä | ' |
' |
≥ |
≥ | ↑ |
↑ | ü |
ü | ‘ |
‘ |
≤ |
≤ | ↓ |
↓ | Ü |
Ü | ’ |
’ |
≈ |
≈ | ↔ |
↔ | ö |
ö | " |
" |
Δ |
Δ | ↕ |
↕ | Ö |
Ö | “ |
“ |
δ |
δ | ↗ |
↗ | ß |
ß | ” |
” |
∼ |
∼ | ↖ |
↖ | € |
€ | Ø |
Ø |
∗ |
∗ | ↘ |
↘ | … |
… | ø |
ø |
; |
; | ↙ |
↙ | % |
% | ||
: |
: | [ |
[ | ÷ |
÷ | ||
& |
& | ] |
] | ∀ |
∀ | ||
, |
, | ∞ |
∞ | ∃ |
∃ | ||
✓ |
✓ | × |
× | λ |
λ | ||
μ |
μ | ν |
ν | π |
π | ||
ρ |
ρ | |
non-breaking space | ‐ |
‐ |
md2pptx supports a few HTML numeric character references:
- Some like
ß
- with 3 or 4 numeric digits. (This produces the character 'ß'). - Some like
Σ
- with 4 hexadecimal digits. (This produces the character 'Σ').
(Some emoji work. For example you can paste 🦖 in to the source.)
md2pptx supports a few escaped characters:
\[
\]
\`
\_
md2pptx supports CriticMarkup for text. To quote from their home page:
CriticMarkup is a way for authors and editors to track changes to documents in plain text. As with Markdown, small groups of distinctive characters allow you to highlight insertions, deletions, substitutions and comments, all without the overhead of heavy, proprietary office suites.
md2pptx supports all five markup elements. In common with other CriticMarkup processors, md2pptx shows the markup and merely colours the markup and marked up text appropriately:
-
Insertion -
{++
and++}
- rendered in green.For example
{++ This text was inserted ++}
-
Deletion -
{--
and--}
- rendered in red.For example
{-- This text was deleted --}
-
Comment -
{>>
and<<}
- rendered in blue.For example
{>> This text is a comment <<}
-
Replacement -
{~~
,~>
~~}
- rendered in orange.For example
{~~old text~>replacement text~~}
-
Highlight -
{==
and==}
- rendered in purple.For example
{== This is a highlight ==}
In the above examples the deletions, insertions, replacements etc don't actually happen; They are just marked. Editing tools are needed to actually perform these actions, once the reviewer's comments have been accepted.
You can use the HTML abbr
element to generate a glossary entry. For example,
<abbr title='British Broadcasting Corporation'>BBC</abbr>
In this example the glossary term is "BBC" and its definition is "British Broadcasting Corporation".
One or more Glossary Table slides will appear at the end of the presentation if any such terms are defined. When you create a glossary entry three things will happen:
- Both the term and its definition will appear in the glossary.
- The term will appear in the slide with the
abbr
element - with the appearance of a hyperlink element, which you can click on to get to the relevant Glossary slide. - If you hover over the term for a second or two the definition of the term will appear as a tooltip.
If you define the term more than once only the first use will be included in the glossary. All uses of the term will appear in the normal slides.
Each Glossary Table slide comprises two columns: A narrow column with the terms (or acronyms), and a wider column with their definitions (or meanings).
In Glossary Table slides the definitions are sorted alphabetically, upper case before lower case.
If you use the abbr
HTML element most markdown processors will treat it as HTML and hovering over the term will reveal the definition.
However, while md2pptx can cope with e.g. <br/>
elements in a glossary definition most markdown processors can't.
You can control various aspects of the glossary's appearance using metadata. How to is described here.
Because md2pptx's support uses hyperlinks you might want to adjust your template so that taken hyperlinks are the same colour as not-yet-taken ones. This is something md2pptx can't do for you. You can change these colours under "Themes" in the Slide Master editor.
You can create and reference footnotes.
To define a footnote code [^name]:
on a new line. The remainder of the line will be the footnote text.
If you have defined footnotes one or more Footnotes slides will be added to the end of the presentation.
Footnotes are automatically numbered, starting with 1.
To refer to a footnote code [^name]
. The footnote's number (automatically generated) will appear like so:
This is a footnote reference4.
If the name doesn't match a footnote a question mark will be printed instead of the footnote number.
If you click on a footnote number you will be taken to the appropriate Footnotes slide.
You can control some aspects of md2pptx's processing using metadata.
You specify "whole presentation" metadata in the lines before the first blank line. It consists of key / value pairs, with the key separated from the value by a colon.
Keys are case insensitive. In this User Guide they are capitalised to aid comprehension. For example, baseTextDecrement
is treated the same as basetextdecrement
.
While some Markdown processors handle metadata, most ignore it. Conversely, while md2pptx will generally print all the metadata it encounters on the first slide (if the template presentation contains at least 1 slide), it will practically ignore metadata it doesn't understand.
Also any line containing invalid metadata (that is not in the form key : value
) will be flagged as an error but otherwise ignored.
"Whole presentation" refers to metadata that applies to every slide in the presentation - unless overridden. Whole presentation metadata items are described in Metadata Keys.
Some metadata items can be overridden dynamically - in the middle of the presentation. md2pptx will only support these where it makes sense to. These keys are described in Dynamic Metadata.
As described in Creating Slides, md2pptx will populate the first slide in the template file with metadata information (if such a slide exists). This slide will contain a table with all the "whole presentation" metadata keys and their values. Its format will adjust to fit all the metadata items.
Notes
- If you override a "whole presentation" metadata item by a dynamic metadata specification the key and value in this table will be coloured blue. An asterisk will be appended to the metadata value.
- You can suppress
style.
metadata items by specifying the metadata itemhideMetadata: style
. In the md2pptx developer's experiencestyle.
metadata items can become numerous and could obscure more important items in the Processing Summary slide. The default is not to hide such items. - Before the metadata table is created md2pptx will remove all but the title item in this slide. The one type of item that won't be removed is any Action Buttons. See Sample Macro To Remove The First Slide for an example of where these might be useful.
In most places where you specify colours they can be of one of two forms:
- A theme colour
- An RGB value
Powerpoint themes have named theme colours. The names you can use with md2pptx are:
- NONE
- ACCENT 1
- ACCENT 2
- ACCENT 3
- ACCENT 4
- ACCENT 5
- ACCENT 6
- BACKGROUND 1
- BACKGROUND 2
- DARK 1
- DARK 2
- FOLLOWED HYPERLINK
- HYPERLINK
- LIGHT 1
- LIGHT 2
- TEXT 1
- TEXT 2
- MIXED
As you can probably guess, these are standard values for python-pptx and, ultimately, PowerPoint.
Here is an example:
BoldColour: ACCENT 1
This will give you more consistent colouring than RGB Colours.
Note: For the values you can use any capitalisation you like (or none). e.g. ItalicColor: dark 1
.
RGB stands for "Red, Green, and Blue". You specify RGB values as 6 hexadecimal digits. For example:
ItalicColour: #FF0000
Each pair of hexadecimal digits represents Red, Green, and Blue, respectively. Each is a hexadecimal encoding of 0-255, with 0 being "none of this colour" and 255 being "saturated in this colour".
This will give you more precise colouring than Theme Colours.
Note: You must include the octothorpe (#
) before the hexadecimal value.
The following sections describe each of the metadata keys.
You can change the font sizes for titles and subtitles throughout the presentation.
You can change the alignment for titles of content slides.
You can specify the point size of the first title line of each slide that isn't a section divider or title slide. The size is specified in points.
Example:
pageTitleSize: 24
The default is 30 points.
You can override this value on a slide-by-slide basis with Dynamic PageTitleSize.
Notes:
- The first title line is terminated by
<br/>
. There might be only one line in the title. - When a title spills onto a second line that is not treated as a new title line.
- Lines after the first line can have a different font size. (See
pageSubtitleSize
.)
You can specify the point size of the second and subsequent title lines of each slide that isn't a section divider or title slide. The size is specified in points.
Example:
pageSubtitleSize: 22
The default is 30 points (the same as pageTitleSize
.)
You can override this value on a slide-by-slide basis with Dynamic PageSubtitleSize.
Notes:
- The title lines are terminated by
<br/>
. - When a title spills onto another line that is not treated as a new title line.
- You can specify
same
and it will match thepageTitleSize
value.
You can specify the point size of the title text for each slide that's a section divider slide. The size is specified in points.
Example:
sectionTitleSize: 42
The default is 40 points.
You can specify the point size of the subtitle text for each slide that's a section divider slide. The size is specified in points.
The subtitle text is the second and subsequent lines of the title - generally a separate text shape on the slide.
Example:
sectionSubtitleSize: 24
The default is 28 points.
You can specify the point size of the title text for each slide that's a presentation title slide. The size is specified in points.
Example:
presTitleSize: 42
The default is 40 points.
You can specify the point size of the subtitle text for each slide that's a presentation title slide. The size is specified in points.
The subtitle text is the second and subsequent lines of the title - generally a separate text shape on the slide.
Example:
presSubtitleSize: 24
The default is 28 points.
You can change the horizontal alignment of content pages using pageTitleAlign
. Alignment can be:
- Left - with
left
orl
- Right - with
right
orr
- Center - with
center
,centre
orc
The default is left
.
Example:
pageTitleAlign: center
centres content page titles.
You can specify which font to use for monospaced text - such as on code slides.
Example:
monoFont: Arial
The default is Courier.
You can increase or decrease the margin around things - in decimal fractions of an inch.
For a table you can specify the left and right margins using tableMargin
.
For everything else use marginBase
.
Example:
marginBase: 0.5
The default is 0.2
(inches).
You can do this dynamically (on a slide-by-slide basis with marginBase
or tableMargin
.
By default md2pptx will adjust the positions and sizes of slide elements - to create a uniform, tidy experience. Sometimes, though, you might not want this adjustment to happen. For elements other than titles this is unlikely to be the case - as that would interfere with multi-element layouts.
You can disable adjusting the positions and sizes of slide titles:
AdjustTitles: no
The default is yes
.
You can use HTML <span>
elements to set the background colour, as described in Using HTML <style> Elements To Specify Text Effects.
Here is an example:
style.bgcolor.yellow: FFFF00
In this example the class "yellow" is associated with a background colour, defined in RGB terms as hexadecimal FFFF00, which is:
- 255 of red
- 255 of green
- 0 of blue
which is in fact yellow.
You can use HTML <span>
elements to set the foreground colour, as described in Using HTML <style> Elements To Specify Text Effects.
Here is an example:
style.fgcolor.red: FF0000
In this example the class "red" is associated with a foreground colour, defined in RGB terms as hexadecimal FF0000, which is:
- 255 of red
- 0 of green
- 0 of blue
which is in fact red.
You can use HTML <span>
elements to bold text, make it italic, or underline it - as described in Using HTML <style> Elements To Specify Text Effects.
Here is an example:
style.emphasis.important: bold underline
In this example the class "important" is associated with bolding the text and underlining it.
You can also use italic
.
As the example shows, separate the emphasis attributes with a space.
You can use HTML <span>
elements to specify the font size for a piece of text - as described in Using HTML <style> Elements To Specify Text Effects.
Here is an example:
style.fontsize.christopher: 40px
In this example the class "christopher" is associated with setting the text's font size to 40 pixels.
Note: You must specify font size in pixels, with "px" directly after the numeric part - which can be integer or floating point.
You can specify a different template file to create the presentation from than the one supplied with python-pptx. The one supplied with md2pptx is a very good one to work from:
template: Martin Template.pptx
If you want to create your own template you probably want to take Martin Template.pptx and modify it. See Modifying The Slide Template for more information on how to do so.
(For compatibility purposes, you can continue to use master
instead of template
. It's probably better practice, though, to use template
.)
Templates are searched for in the following sequence:
- Using the name as given. For example
hipodz.pptx
will search the current directory. - In the md2pptx installation directory.
Hiding Slides - hidden
You can mark slides to be hidden in a slideshow. This presentation-level metadata item is designed to be overridden at the individual slide level.
To set the initial value for all slides to be hidden code
hidden : yes
To set the initial value for all slides to be shown code
hidden : no
See hidden
for how to override this default at an individual slide level.
The default value for hidden
is no
.
You can arrange for a single-level bulleted list slide to be formatted specially - as an abstract.
Instead of each list item having a bullet, it is treated as a paragraph. This is more appropriate for an abstract slide. (An extra blank paragraph is added between each paragraph - to space it out.)
To indicate an abstract slide code
abstractTitle: Abstract
Any slide with the title matching the value of abstractTitle will be rendered as an abstract slide.
You can control the size of text - in table slides, code slides, and bulleted list slides - with two metadata tags: baseTextSize
And baseTextDecrement
.
If you don't specify baseTextSize
the base presentation's font sizes are used.
If you specify a baseTextSize
value code, tables, and the top-level bullet use this size, which is specified in points.
Further, if you specify baseTextDecrement
each successive level of bullets' font size is decremented by this number of points.
The default for baseTextDecrement
is 2 points.
For example, if you code
baseTextSize: 20
baseTextDecrement: 1
the top-level bullet uses a 20 point font, the next level down a 19 point font, and so on.
If you just coded
baseTextSize: 20
the top-level bullet uses a 20 point font, the next level down a 18 point font, and so on.
You can specify these dynamically. See here and here. You might want to do this to fine tune a particularly sparse or crowded page.
You can modify how md2pptx formats bold and italic colours:
- To specify the colour of bold text use
BoldColour
(orBoldColor
). - To specify the colour of italic text use
ItalicColour
(orItalicColor
).
For example:
BoldColour: ACCENT 1
Will cause text marked like so **I am bold**
to be rendered in the presentation's smartmaster's "Accent 1" colour.
You can modify how md2pptx formats bold and italic text.
If you don't want bold text to actually be bold code
BoldBold: no
If you don't want italic text to actually be italic code
ItalicItalic: no
The default for both of these is, of course, yes
so that bold text is bold and italic text is italic.
These options were added so that BoldColour
and ItalicColour
could just become colour effects. See here.
Before unleashing your presentation on the world you probably want to remove the Task List slides from it. You can control what tasks are shown, if any, with taskSlides
. It can take four different values:
all
(the default) which shows both complete and incomplete tasks.none
which hides the task list slides altogether.done
which shows completed tasks only.remaining
which shows only tasks that haven't been completed.separate
which separates the tasks into slides with completed tasks and slides with incomplete tasks.
A completed task is one where the @done
attribute has been coded with something inside the brackets. An incomplete task is one where either the @done
attribute wasn't coded or there is nothing inside the brackets.
For example, to suppress all task slides code
taskSlides: none
Though you wouldn't normally need to do this, you can control how many tasks appear on a slide with tasksPerSlide
. For example, coding
tasksPerSlide: 10
will limit the numberof tasks on a slide to 10. The default is 20 tasks per slide.
Controlling Glossary Slide Production With glossaryTitle
, glossaryTerm
, glossaryMeaning
,glossaryMeaningWidth
, and glossaryTermsPerPage
Creating A Glossary Of Terms describes how you can use the abbr
element to generate a glossary of terms.
You can control various aspects of the appearance of the Glossary Slide(s) using the following metadata items.
For example, coding
glossaryTitle: Definitions
will cause the Glossary Slide title to be "Definitions". The default is "Glossary".
Coding
glossaryTerm: Acronym
will cause the first heading of the table in the Glossary Slide to be "Acronym". The default is "Term".
Coding
glossaryMeaning: Definition
will cause the second heading of the table in the Glossary Slide to be "Definition". The default is "Meaning".
Coding
glossaryMeaningWidth: 3
will cause the width of the second column in the table to be three times that of the first column.
Coding
glossaryTermsPerPage: 10
will cause the maximum number of glossary items on a Glossary slide to be 10. If there are more terms, a second slide will be created. And so on. The default is 20.
While the default for signifying each level of indentation for bullets is two spaces, you can change it by coding IndentSpaces
for metadata. For example:
IndentSpaces: 4
You can change the value of IndentSpaces
on a slide-by-slide basis, perhaps because you are including material from elsewhere that uses a different value. See Dynamic IndentSpaces.
You can specify which directory temporary files are stored in. For example:
tempDir: ~/Temp
The above stores temporary files in the Temp subdirectory of the user's home directory. As you can see from this example directory names are expanded.
Sometimes you will want to review the Processing Summary slide - which is the first slide in the presentation. Sometimes you won't.
To remove it specify:
removeFirstSlide: yes
The default is no
.
Note: If you don't have a Processing Summary slide - perhaps because the slide master you used doesn't have a slide - the first slide would still be removed if you specified removeFirstSlide: yes
. This is probably not what you want to have happen.
You can specify a background image for slides with backgroundImage
. For example:
backgroundImage: myFavouriteBackground.png
The default is no background image (other than from the slide master), represented by an empty string.
You can override this value with Dynamic Metadata.
Notes:
- python-pptx doesn't know how to manipulate a slide background image. md2pptx generates additional XML to insert the background image.
- A background covers the slide area entirely, with the image scaled to fit. It's a good idea to make your background image be the same size, or have the same aspect ratio, as the slide.
You can reduce the size of a table on the slide with compactTables
. If you specify a value larger than 0 two things will happen:
- The font will use whatever point size you specify.
- The margins around the text in a cell will be reduced to 0.
For example, to remove the margins and reduce the font size to 16pt code
compactTables: 16
You can override this value with Dynamic Metadata.
You can adjust the size of a table heading on the slide with tableHeadingSize
. If you specify a value larger than 0 the table heading line font will use whatever point size you specify.
For example, to increase the table heading font size to 24pt code
tableHeadingSize: 24
You can override this value with Dynamic Metadata.
You can add lines to tables in two ways:
addTableLines: box
will add a black border round the entire table.
addTableLines: both
will add a black border round all the cells, and effectively the table.
The default is addTableLines: no
which doesn't add any table lines.
You can override this metadata item with Dynamic Metadata.
Note: This capability never removes lines - for example if they are present in the template presentation.
You can add lines to the right of specific columns and below specific rows with addTableColumnLines
and addTableRowLines
, respectively.
For example
addTableColumnLines: 1 3
specifies tables will have vertical lines to the right of the first and third columns. (Column numbers start at 1.)
Similarly
addTableRowLines: 1
specifies tables will have horizontal lines below the first row (often a header).
You can override both these metadata items with Dynamic Metadata.
Note: This capability never removes lines - for example if they are present in the template presentation.
Specifying What The Added Table Lines Look Like With addTableLineColour
, addTableLineCount
and addTableLineWidth
By default added table lines are black, narrow, and consist of a single line. You can change all three of these.
To change the colour specify the RGB value like this:
addTableLineColour: FF00FF
which will make the added lines purple. (This example is full-on red and full-on blue mixed to make purple.)
To double the width of the added lines specify a width multiplier (in this case 2
) like this:
addTableLineWidth: 2
To make the added lines pairs specify:
addTableLineCount: 2
In this case the only valid values are 1
and 2
x.
You can specify all three of these on a table-by-table basis. See Dynamic Metadata.
For some use cases you don't want an empty table cell to cause the cell to the left to expand into it. To prevent this code:
spanCells: no
The default is yes
.
You can override this value at the slide level with Dynamic SpanCells.
You can control whether tables have drop shadows:
tableShadow: yes
The default is no
.
You can specify which colours to use for the background of each card in a Card Slide - using CardColour
(or CardColor
or CardColours
or CardColors
). For example:
CardColour: BACKGROUND 2
If you don't specify this the default text box background colour - from the template - will be used.
You can specify a series of card background colours, separated by commas. For example:
CardColour: ACCENT 1, ACCENT 2, ACCENT 3
If you specify more than one value each successive card will use the next colour in rotation. For example, with the above, a five-card slide would have backgrounds:
- ACCENT 1
- ACCENT 2
- ACCENT 3
- ACCENT 1
- ACCENT 2
You can override this value on a slide-by-slide basis with Dynamic CardColour.
You can specify which of the theme colours to use for the border of each card in a Card Slide - using CardBorderColour
(or CardBorderColor
).For example:
CardBorderColour: TEXT 1
If you don't specify this the cards won't have a border.
You can specify the thickness of the border (in points) of each card in a Card Slide - using CardBorderWidth
. For example:
CardBorderWidth: 1
If you don't specify this the cards will use the default text box border width - from the template.
Specifying 0
will prevent a border from being drawn.
You can specify the size of the font (in points) for the cards' title - using CardTitleSize
. For example:
CardTitleSize: 15
If you don't specify this the card titles will be 2/3 the size of the slide's title.
You can specify the colour of cards' titles with cardTitleColour
. For example:
CardTitleColour: DARK 1
would set the cards' titles to the theme's "DARK 1" colour.
You can specify which colours to use for the background of each card's title in a Card Slide - using cardTitleBackground
(or CardTitleBackgrounds
). For example:
CardTitleBackground: BACKGROUND 2
If you don't specify this the default text box background colour - from the template - will be used.
You can specify a series of card title background colours, separated by commas. For example:
CardTitleBackground: ACCENT 4, ACCENT 5
If you specify more than one value each successive card will use the next colour in rotation.
If the card titles are inside the cards (parhaps because a CardTitlePosition
value of inside
was specified)cardTitleBackground
will be ignored.
You can override this value on a slide-by-slide basis with Dynamic CardTitleBackground.
You can specify the colour of lines between cards - if the line
style is chosen. For example:
CardLineColour: ACCENT 1
would set the lines between cards to the theme's "ACCENT 1" colour.
You can specify whether a card has a shadow - using CardShadow
. For example:
CardShadow: yes
If you don't specify this the cards won't have a shadow - unless the default text box style is to have a shadow.
You can control the vertical space used by cards - as a percentage of the content area. The default is 80%.
Here is an example:
CardPercent: 70
You can override this value on a slide-by-slide basis with Dynamic CardPercent.
By default md2pptx lays out cards across the slide. This is called "horizontal layout" - and is generally a good use of slide space. But it's not what many Markdown processors do with Heading Level 4 (####
). They tend to lay out vertically, even though this is generally a poorer use of slide "real estate".
To specify horizontal card layout code:
CardLayout: horizontal
To specify vertical card layout code:
CardLayout: vertical
You can override this value on a slide-by-slide basis with Dynamic CardLayout.
By default md2pptx centres card titles above the corresponding card. Generally this looks best for the horizontal card layout.You can override this - perhaps to make titles on a vertical card layout slide left aligned.
To specify left card title alignment code:
CardTitleAlign: left
You can specify left
, right
, or center
or centre
. You can abbreviate these to l
, r
, or c
.
You can override this value on a slide-by-slide basis with Dynamic CardTitleAlign.
By default md2pptx places each card's title above the card body. You can override this.
To specify the cards' titles will be inside the card body, at the top, code:
CardTitlePosition: inside
The default value is above
.
You can override this value on a slide-by-slide basis with Dynamic CardTitlePosition.
By default md2pptx renders each card with a rounded card body. You can override this.
To specify the cards' bodies will be squared off, at the top, code:
CardShape: squared
You can explicitly code rounded
for the default "playing card" shape.
To specify the cards won't have backgrounds but will be separated by lines, code:
CardShape: line
If the card layout direction is vertical the lines will be horizontal. Conversely, if the card layout direction is horizontal the lines will be vertical.
You can override the cardShape
value on a slide-by-slide basis with Dynamic CardShape.
You can adjust the horizontal space between cards that are laid out side by side using CardHorizontalGap
. For example:
CardHorizontalGap: 0.2
The default is 0.25 inches.
You can override this on a slide-by-slide basis with Dynamic Horizontal Gap.
You can adjust the vertical space between cards that are laid out one above the other using CardVerticalGap
. For example:
CardVerticalGap: 0.05
The default is 0.1 inches.
You can override this on a slide-by-slide basis with Dynamic Vertical Gap.
You can specify whether any graphic appears before or after the bulleted list contents of the card:
cardGraphicPosition: after
causes the graphic to appear after the bulleted list.
before
(which is the default) causes the graphic to appear before the bulleted list.
Notes:
- The values
before
andafter
are used because they work in both horizontal and vertical layouts. - If
before
is specified, in horizontal layout, the graphics appear below any titles. - You can cause graphics to replace text titles by specifying
for all the titles - and specifying graphics instead.
If you want graphics or videos to appear in cards you must specify a non-zero value of CardGraphicSize
. For example:
cardGraphicSize: 0.75
would cause the graphics and videos to be scaled to fit into a 0.75 inch square.
The default is 0
, that is no graphics.
You can specify space around the graphic or video on a card. For example:
cardGraphicPadding: 0.5
will leave a space of 0.5 inches around the graphics and videos. The default is 0.1
, leaving a 0.1 inch pad around them.
You can adjust how code slides display their content.
You can adjust how wide the text box the code is displayed in using CodeColumns
. For example:
CodeColumns: 70
The default value is 80.
You can override this on a slide-by-slide basis with Dynamic CodeColumns.
md2pptx assumes the height of a column is 1.2 times its width. You can adjust this ratio with FPRatio
:
FPRatio: 1.1
You can override this on a slide-by-slide basis with Dynamic FPRatio.
The default foreground colour for code slides is black (#000000 in RGB terms). You can override this by specifying an RGB colour, such as white:
CodeForeground: FFFFFF
You can override this on a slide-by-slide basis with Dynamic CodeForeground.
The default background colour for code slides is white (#FFFFFF in RGB terms). You can override this by specifying an RGB colour, such as black:
codeBackground: 000000
You can override this on a slide-by-slide basis with Dynamic codeBackground.
You can specify a number of things about how funnels are rendered:
- You can specify colours for text, shape outlines and shape interiors.
- You can specify the percentage of the vertical space to be set aside for labels.
By default the interior of each stage is coloured ACCENT 1, ACCENT 2, ... , ACCENT 6, and back round to ACCENT 1 again. You can override this by specifying your own list of colours. How to specify colours is described in Specifying Colours.
For example, coding
funnelColours: ACCENT 2, ACCENT 1
rotates the colours between ACCENT 1 and ACCENT 2 in the presentation's theme.
Using RGB colours, you could create the almost unusable rotation of
funnelColours: #FF0000, #00FF00, #0000FF
(which is red, then green, then blue, then back to red ...)
You can use the alternate spelling FunnelColors
.
You can do this dynamically (on a slide-by-slide basis) with funnelColours
.
You can specify which colour to use for the border of each stage in a funnel - using FunnelBorderColour
(or FunnelBorderColor
).For example:
FunnelBorderColour: #000000
which yields a black border round each stage.
If you don't specify this the stages won't have a border.
You can do this dynamically (on a slide-by-slide basis) with funnelBorderColour
.
You can specify which colour to use for the label of each stage in a funnel - using FunnelTitleColour
(or FunnelTitleColor
).For example:
FunnelTitleColour: #000000
which yields black text for each stage.
You can do this dynamically (on a slide-by-slide basis) with funnelTitleColour
.
You can specify which colour to use for the text in the body of each stage in a funnel - using FunnelTextColour
(or FunnelTextColor
). For example:
FunnelTextColour: #FF0000
which yields red text in the body of each stage.
You can do this dynamically (on a slide-by-slide basis) with funnelTextColour
.
When a funnel is constructed vertical space is set aside for the labels above each stage body. Generally the default (10%) of the vertical space for labels plus funnel body is enough. However, particularly if some of the labels occupy more than one line, you might need to adjust this percentage.
You can alter the space proportion using FunnelLabelsPercent
. For example:
funnelLabelsPercent: 15
In this example 15% of the vertical space is set aside for labels. In testing this appeared to be enough for two-line labels and not too much for the labels that were single line.
You can do this dynamically (on a slide-by-slide basis) with funnelLabelsPercent
.
Note: Multiple lines in a label are separated by <br/>
.
You can specify whether the labels are before or after the stages in a funnel - using FunnelLabelsPosition
. For example:
funnelLabelsPosition: after
will ensure funnel labels come after the funnel stages.
For horizontal funnels before
means "above" and after
means "below".
You can do this dynamically (on a slide-by-slide basis) with funnelLabelsPosition
.
By default a funnel's stages get progressively narrower towards the right. You might, however, want to reverse this so that the funnel gets wider towards the right. You can do this by specifying funnelWidest
. For example,
funnelWidest: right
reverses the usual funnel direction and acts as a "fan out" of sorts - with the funnel becoming progressively wider towards the right.
You can also have the funnel vertical instead of horizontal, or have constant width (or height) stages.
The supported values are:
left
(which is the default)right
top
bottom
pipe
where the stages have constant heighthpipe
- short for "horizontal pipe" - which is the same aspipe
vpipe
- short for "vertical pipe" - where the stages have constant width
You can do this dynamically (on a slide-by-slide basis) with funnelWidest
.
You can specify a number of things about the bottom of each slide:
- You can specify whether slide numbers are to be generated by md2pptx - with
numbers
. - You can specify how much space to reserve at the bottom of the slide for things like slide numbers - with
NumbersHeight
. - You can add "pseudo-footer" information in three places at the bottom of the slide. These are not genuine footer elements but are more flexible. See Specifying Footer Text.
- You can specify the font sizes for slide numbers and footers - with numbersFontSize and footerFontSize, respectively.
Note: This user guide will use the term "footer" rather than "pseudo footer", and "slide number" instead of "pseudo slide number".
md2pptx can add slide numbers. These are generated by md2pptx itself (or hardcoded) and are not the same as ones you can turn on in a footer.
The default value is no
. You can turn them on for all slides with yes
or non-title slides with content
.
Example:
numbers: yes
You can specify the size of the slide number font with numbersFontSize
. For example
numbersFontSize: 16.5
will cause slide numbers to be displayed with a 16.5 point font. The default value is 12 points.
You can override the default space left at the bottom of the slides - for slide numbers or maybe a custom footer:
NumbersHeight: 1.0
This specifies to reserve 1.0 inches of vertical space. The default is 0.4 inches.
You can do this dynamically (on a slide-by-slide basis) with numbersHeight
.
You can specify text for three areas at the bottom of the slide:
- Left of centre - with
leftFooterText
. - In the middle - with
middleFooterText
. - Right of centre - with
rightFooterText
.
The syntax for each of these is the same. Here's an example for the centre footer:
middleFooterText: My presentation
If you code this the text "My presentation" will appear at the bottom of each slide - in the middle.
You can control whether Title and Section slides have footers. To turn them on code:
sectionFooters: yes
The default is no
.
Unlike real footers, md2pptx's footer support can be flexible: You can specify a number of things that can be included in a footer. For example:
leftFooterText: Section <section>
will lead to a left-side footer with the text "Section ", followed by the first line of the current section title.
You can turn any footer that references a section title into a live link by specifying:
liveFooters: yes
The default is no
.
You can specify the following special values:
<section>
for the first line of the current section slide's title.<section1>
,<section2>
, or<section3>
for, respectively, the first, second, and third lines of the current section slide's title.<presTitle>
for the first line of the presentation title slide's title.<presTitle1>
,<presTitle2>
, or<presTitle3>
for, respectively, the first, second, and third lines of the presentation title slide's title.<presSubtitle>
for the first line of the presentation title slide's subtitle.<presSubtitle1>
,<presSubtitle2>
, or<presSubtitle3>
for, respectively, the first, second, and third lines of the presentation title slide's subtitle.
You can trigger a line break in a footer using <br/>
. For example:
rightFooterText: <presTitle1><br/><presSubtitle1>
will place the first line of the presentation title and the first line of the presentation subtitle in the right footer - on two lines.
Notes
- Lines are separated by
<br/>
. - For slides before the first Section Slide the title will be empty.
- There will be no symbol substitution - beyond what was in the section title.
- The case of the terms must be as shown. For example,
<presTitle1>
must be coded exactly as shown.
You can specify the size of the footer text font with footerFontSize
. For example
footerFontSize: 14.0
will cause footers to be displayed with a 14 point font. The default value is 8 points.
The usual heading levels for different types of slides are as follows:
Level | Slide type |
---|---|
1 | Presentation title |
2 | Section title |
3 | Content |
4 | Card |
However, you might need to "demote" all these slide types to, say:
Level | Slide type |
---|---|
2 | Presentation title |
3 | Section title |
4 | Content |
5 | Card |
This might be, for example, because the same Markdown is destined for a formal publication, where the top level heading is reserved for the publication's title. To achieve this demotion you only need to specify the top level in the slide hierarchy:
TopHeadingLevel: 2
The other heading levels will be adjusted accordingly.
Note: You obviously need to code the Title Slide at Heading Level 2, for example.
This section describes how you can control the layout of slides with multiple blocks of content.
See Slides With More Than One Content Block for how to specify multiple blocks of content on a slide
You can specify whether the blocks of content are to be vertically or horizontally arranged with
ContentSplitDirection: vertical
or
ContentSplitDirection: horizontal
You can use h
or v
for short. You can also use ContentSplitDirn
.
You can override this on a slide-by-slide basis with Dynamic ContentSplitDirection.
The default value is vertical
.
Here is an example where the content split direction is vertical
You specify the split between the blocks as proportions. For example:
ContentSplit: 1 4
will make the first block a quarter the height (or width) of the second. Specify proportions using integers.
You can override this on a slide-by-slide basis with Dynamic ContentSplit.
The default value is such as to make each block have equal space.
Here is an example where the content split direction is horizontal and the 2 areas are in the ratio of 2 to 1.
Note: 0
is a perfectly valid value.
It is used to ensure Python code takes up no slide space when running Python. See Running Inline Python.
By default md2pptx does not export SVG and EPS files converted to PNG. (md2pptx handles SVG and EPS graphics by converting them to PNG format.) You can save the converted graphics to PNG by specifying:
exportGraphics: yes
If you have a slide in a certain format you can convert it to a Table Of Contents slide. This slide can be "Chevron Style", "Circle Style", or "Plain Style".
In addition to building the Table Of Contents slide, for Chevron and Circle styles, each Section Slide replicates the Table Of Contents slide but with the current section's title highlighted. The examples below will make this clearer.
The format required is a bulleted list slide with each section title listed as a top level bullet. For example:
### Topics
* [A Section](#a-section)
* [Another Section](#another-section)
* [Yet Another Section](#yet-another-section)
* [A Much Longer Section Title](#a-much-longer-section-title)
* [An Even Longer Giant Section Title](#an-even-longer-giant-section-title)
* [Let's Do It Again](#lets-do-it-again)
* [And One More Time](#and-one-more-time)
You will recognise each entry as an internal link. Perhaps the easiest way to create such a piece of Markdown is with mdpre with its =toc
capability. It will automate gathering the links and Section slide titles.
When processing this slide md2pptx will recognise it as a Table Of Contents slide because of the slide title "Topics". It will build a list of headings from the bullets. With Chevron and Circle styles, when md2pptx sees a Section slide whose title matches one of the titles in the Table Of Contents slide's bullets it creates a similar slide to the Table Of Contents slide, but with this section highlighted.
Notes:
- Ensure only one slide has the same title as the Table Of Contents slide. Otherwise md2pptx will attempt to render the other slides as if they were a Table Of Contents slide.
- Ensure the Section slides' titles are unique. Otherwise more than one chevron will be highlighted on the relevant section slide.
- The style of the Table Of Contents and Section slides is controlled with
tocStyle
. - You don't have to use "Topics" as the title of the Table Of Contents slide. You can control this with
tocTitle
.
To create a "Chevron Style" Table Of Contents slide and Section slides code:
tocStyle: chevron
If you create a "Chevron Style" Table Of Contents slide, it will look something like this:
If you specify tocStyle: chevron
the Section slides will be rendered something like this:
Here the section is highlighted by removing the background.
In the above pictures live links are disabled and default rendering options have been taken.
To create a "Circle Style" Table Of Contents slide and Section slides code:
tocStyle: circle
If you create a "Circle Style" Table Of Contents slide, it will look something like this:
If you specify tocStyle: circle
the Section slides will be rendered something like this:
Here the section is highlighted by removing the background and emphasising the circle itself.
In the above pictures live links are disabled and default rendering options have been taken.
The purpose of Plain Style is to create a Table Of Contents slide with each presentation section listed as a live link. Unlike with Chevron and Circle styles, Plain Style does not affect Section slides.
To create a "Plain Style" Table Of Contents slide and Section slides code:
tocStyle: plain
If you create a "Plain Style" Table Of Contents slide, it will look something like this:
Note: With Plain Style, Section slides are unaffected; They are rendered as if no Table Of Contents functions were used.
There are three styles of Table Of Contents and Section slide you can specify:
tocStyle: chevron
tocStyle: circle
TOCStyle: plain
If your Table Of Contents slide's title is something other than "Topics" you need to tell md2pptx what title to match, additionally coding something like
tocTitle: Agenda
md2pptx will look for this title on a slide instead of "Topics" and use the matching slide to create a Table Of Contents slide.
You can enable live links in Table Of Contents and Section slides for Chevron and Circle styles. (Links are always live in Plain style.) In a Powerpoint slide show clicking on an item in the Table Of Contents slide or a Section slide takes you to the Section slide that is the link's target.
By default live links are not enabled - for compatibility with existing presentations.
Enable live links by coding
tocLinks: yes
Note: You cannot control the colour of links in Powerpoint. For that reason you might need to change the background colour of items using TOCItemColour.
You can control the height of the items with TOCItemHeight
. Coding
tocItemHeight: 1.5
leads to each item being 1.5 inches high.
For Chevron the default is 1 inch high. For Circle the default is 1.25 inches.
Chevron items are 2.5 times as wide as they are high. Circle items are the same width as they are high.
For Chevron and Circle Table Of Contents styles you can control the background colour of the items with TOCItemColour
(or TOCItemColor
). Coding
tocItemColour: E0E0FF
leads to each item's background colour being pale blue. This is a hexadecimal RGB (Red, Green, Blue) value.
If you don't specify this the default Powerpoint background colour for shapes is used.
This option was introduced because when live links are used in Table Of Contents and Section slides the link text might be nearly invisible.
Note: This option doesn't affect the background colour of the highlighted item on a Section slide; That remains unfilled.
You can control the vertical spacing between rows of items with TOCRowGap
. Coding
tocRowGap: 0.5
leads to the vertical gap between rows being 0.5 inches.
The default is 0.75 inches.
You can adjust the font size for the Table Of Contents entries with TOCFontSize
. Coding
tocFontSize: 10
leads to the font size being 10 points.
For Chevron the default is 14pt. For Circle the default is 12pt.
You can enable navigation buttons for Section slides - if you have Table Of Contents enabled. If you do the result is something like this:
The three buttons are:
- To previous section slide
- To the table of contents slide
- To the next section slide
Buttons which make no sense - such as the last Section slide having a forward button - are suppressed.
Coding
sectionArrows: yes
enables this feature.
The default value is no
.
You can specify the background colour for the buttons with SectionArrowsColour
.
You can set the background colour of the buttons specified with SectionArrows
.
You probably want to match any colour specified with TOCItemColour
.
To do this use SectionArrowsColour
(or SectionArrowsColor
).
Coding
sectionArrowsColour: E0E0FF
leads to each item's background colour being pale blue. This is a hexadecimal RGB (Red, Green, Blue) value.
If you don't specify this the default Powerpoint background colour for shapes is used.
You can make expandable and collapsable sections. In this context a section begins with a section slide and continues until the next section slide.
When collapsed the PowerPoint side bar shows the section name and the number of slides in that section. When expanded the side bar shows the section name above the first slide in the section.
To make expandable and contractable sections code:
sectionsExpand: yes
The default is no
.
Notes:
- The section name is derived from the section slide's title. The following characters are passed through to the section name:
- Alphanumerics
&-+!/
- Spaces
- Asterisks (coded as
∗
)
- In testing only PowerPoint has demonstrated the ability to display collapsible sections. Neither LibreOffice nor Keynote showed any understanding of collapsible sections, though both otherwise loaded the test presentation fine.
With md2pptx you can create transitions between slides.
To do so code, for example:
transition: ripple
A limited number have been successfully tested:
ripple
reveal
honeycomb
shred
wipe
vortex
fracture
split
push
The default is no
- which prevents slide transition effects being generated.
You can override this value with Dynamic Metadata.
md2pptx can alter some in-effect settings, starting at a particular slide. Straight after the heading code a special form of (HTML) comment like so:
### Origins Of Mainframe, Performance, Topics Podcast
<!-- md2pptx: compacttables: 14 -->
The use of md2pptx:
in the comment tells md2pptx there is a Dynamic Metadata statement embedded in the comment.
Here are the values you can specify for the metadata:
pres
- revert to the presentations's value (if specified). If, at the beginning of the presentation, you didn't specify a value for this metadata item it will be the md2pptx default that will be in effect.default
- revert to the md2pptx default.prev
orpop
- use the previous value, popping the stack as you do.- Any other value - used literally.
If you dynamically change a metadata value the new value will remain in effect for the remainder of the presentation, unless changed again.
Note: After tweaking a slide you might well want to revert to your presentation's overall value (or even the md2pptx default). Instead of this you might use prev
orpop
, though these are destructive.
hidden
You can override the system value of hidden
.
For example, you might want to hide just the fifth slide:
- Code, or allow to default,
hidden
tono
in the metadata at the top of the presentation. - Code
<!-- md2pptx: hidden: yes -->
below the title of the fifth slide. - Code
<!-- md2pptx: hidden: no -->
below the title of the sixth slide.
Each coding of this dynamic metadata item applies until any subsequent coding of it.
You can override the presentation CompactTables metadata value - perhaps to decrease the font size for a particularly crowded table slide:
<!-- md2pptx: compacttables: 12 -->
You can override the presentation TableHeadingSize metadata value - perhaps to increase the font size for a particular table slide:
<!-- md2pptx: tableheadingsize: 36 -->
You can override the presentation AddTableLines specification on a table-by-table basis:
<!-- md2pptx: addtablelines: box -->
You can override the presentation AddTableRowLines and AddTableColumnLines specifications on a table-by-table basis:
Here is an example of adding horizontal lines below rows 1 and 4:
<!-- md2pptx: addtablerowlines: 1 4 -->
Here is an example of adding vertical liness to the right of column 2:
<!-- md2pptx: addtablecolumnlines: 2 -->
You can override the presentation Added Table Line Attributes on a table-by-table basis. Here are some examples:
<!-- md2pptx: addtablelinecolour: 00FF00 -->
turns the added lines green.
<!-- md2pptx: addtablelinewidth: 4 -->
makes the added lines 4 times wider than normal.
<!-- md2pptx: addtablelinecount: 2 -->
makes the added lines each appear as a pair of lines.
You can override the presentation SpanCells
value:
<!-- md2pptx: spancells: yes -->
You might do this if the presentation generally tolerates multi-column table cells but this table doesn't.
You can override the presentation CardPercent metadata value - perhaps to allow room for more card content:
<!-- md2pptx: cardpercent: 90 -->
You can override the presentation CardLayout metadata value - perhaps to make an individual card slide vertical when most are horizontal:
Either vertical
or horizontal
can be specified.
<!-- md2pptx: cardlayout: vertical -->
You can override the presentation CardColour metadata value:
For example:
<!-- md2pptx: cardcolour: ACCENT 2, ACCENT 4 -->
You can override the presentation CardTitleAlign metadata value - perhaps to make an individual card slide's titles left-aligned when most are centred:
<!-- md2pptx: cardtitlealign: l -->
You can override the presentation CardTitlePosition metadata value - perhaps to make an individual card slide's titles inside the cards when most are above:
<!-- md2pptx: cardtitleposition: insde -->
You can override the presentation CardTitleBackground metadata value:
For example:
<!-- md2pptx: cardtitlebackground: ACCENT 3 -->
You can override the presentation CardShape metadata value - perhaps to make an individual card slide's cards have square corners when most are rounded:
<!-- md2pptx: cardshape: squared -->
You can override the presentation CardHorizontalGap metadata value - perhaps to squeeze the gaps between cards:
<!-- md2pptx: cardhorizontalgap: 0.05 -->
You can override the presentation CardVerticalGap metadata value - perhaps to squeeze the gaps between cards:
<!-- md2pptx: cardverticalgap: 0.05 -->
You can override the presentation CodeColumns metadata value. For example:
<!-- md2pptx: codecolumns: 60 -->
The above changes the CodeColumns
value for this and subsequent slides to 60.
You can override the presentation FPRatio (fixed pitch font character height to width ratio) metadata value. For example:
<!-- md2pptx: fpratio: 1.3 -->
The above changes the FPRatio
value for this and subsequent slides to 1.3.
You can override the presentation CodeForeground code slide foreground colour on a slide-by-slide basis:
<!-- md2pptx: codeforeground: 000000 -->
You can override the presentation CodeBackground code slide background colour on a slide-by-slide basis:
<!-- md2pptx: codebackground: FFFFFF -->
You can override the presentation FunnelColours metadata value:
<!-- md2pptx: funnelcolours: ACCENT 3, ACCENT 4 -->
You can override the presentation FunnelBorderColour metadata value:
<!-- md2pptx: funnelbordercolour: ACCENT 5 -->
You can override the presentation FunnelTitleColour metadata value:
<!-- md2pptx: funneltitlecolour: ACCENT 5 -->
You can override the presentation FunnelTextColour metadata value:
<!-- md2pptx: funneltextcolour: #000000 -->
You can override the presentation FunnelLabelsPercent metadata value:
<!-- md2pptx: funnellabelspercent: 20 -->
You can override the presentation FunnelLabelsPosition metadata value:
<!-- md2pptx: funnellabelsposition: after -->
You can override the presentation FunnelWidest metadata value:
<!-- md2pptx: funnelwidest: pipe -->
You can override the presentation PageTitleSize metadata value - perhaps to allow room for more text in the title of a slide:
<!-- md2pptx: pagetitlesize: 16 -->
You can override the presentation PageSubtitleSize metadata value - perhaps to allow room for more text in the title of a slide:
<!-- md2pptx: pagesubtitlesize: 14 -->
You can specify same
and it will match the pageTitleSize
value.
You can override the presentation BaseTextSize metadata value. For example:
<!-- md2pptx: basetextsize: 16 -->
The above makes the top-level bullets smaller than you would normally see - perhaps to cram in more bullets.
You can override the presentation BaseTextDecrement metadata value. For example:
<!-- md2pptx: basetextdecrement: 0 -->
The above stops each level of bullets having progressively smaller text.
You can override the presentation ContentSplitDirection value on a slide-by-slide basis:
<!-- md2pptx: contentsplitdirection: v -->
You can override the presentation ContentSplit specification on a slide-by-slide basis:
<!-- md2pptx: contentsplit: 1 1 3 -->
You can override the presentation IndentSpaces specification on a slide-by-slide basis:
<!-- md2pptx: indentspaces: 4 -->
You can override the presentation MarginBase specification on a slide-by-slide-basis. For example:
<!-- md2pptx: marginbase: 0 -->
You might do this along with a Dynamic NumbersHeight value of 0 to allow something to occupy the whole slide.
You can override the presentation NumbersHeight specification on a slide-by-slide-basis. For example:
<!-- md2pptx: numbersheight: 0 -->
You might do this along with a Dynamic MarginBase value of 0 to allow something to occupy the whole slide.
You can override the presentation TableMargin specification on a slide-by-slide-basis:
<!-- md2pptx: tablemargin: 0.25 -->
You can override the presentation Transition specification on a slide-by-slide basis:
<!-- md2pptx: transition: reveal -->
It's important to note that doing this will affect the transition into this slide. Likewise all subsequent slides - until overridden again or reverted.
You can override the presentation BackgroundImage specification on a slide-by-slide basis:
<!-- md2pptx: backgroundImage: myNewBackground.png -->
The included template presentation - Martin Template.pptx - is what the author tested with and gives good results. However, you probably want to develop your own template from it.
This section is a basic introduction to the rules of the game for doing so.
It's best not to change the order of the slides in the slide master view and not to delete any elements. If you have a slide template presentation where the necessary slides are in the wrong order you can override where md2pptx picks its slides from. See the table below for metadata items to specify different template slides i.e override what md2pptx expects. Here's an example:
BlankLayout: 14
In this example, the slide in the template presentation to use for blank slides is number 14, with 0 being the first.
It's probably also not useful to add elements. Take care with moving and resizing elements; It's probably best to experiment to see what effects you get.
The following table shows how each slide type is created.
Slide Type | Origin | Metadata Override |
Non-Title Content |
---|---|---|---|
Processing Summary | Original slide from Template | Metadata: Second Shape | |
Presentation Title | Slide Layout 0 | TitleSlideLayout | Subtitle: Second Shape |
Section | Slide Layout 1 | SectionSlideLayout | Subtitle: Second Shape |
Graphic With Title | Slide Layout 5 | TitleOnlyLayout | Graphic: New Shape |
Graphic Without Title | Slide Layout 6 | BlankLayout | Graphic: New Shape |
Code | Slide Layout 5 | TitleOnlyLayout | Code: New Shape |
Content | Slide Layout 2 | ContentSlideLayout | Bulleted List: Second Shape |
Table | Slide Layout 5 | TitleOnlyLayout | Table: New Shape |
Tasks | Slide Layout 2 | ContentSlideLayout | Bulleted List: Second Shape |
Notes:
- When looking for a title md2pptx looks first for a title shape and, failing that, uses the first shape. It's the Template Designer's responsibility to size and position it sensibly.
- "New Shape" means md2pptx will create a new shape with, hopefully, sensible position and size.
- With "Second Shape" it's the Template Designer's responsibility to size and position it sensibly.
The following sections give a brief description of each slide type md2pptx builds a presentation from. Your template presentation should have a slide of each type.
The title of each section includes the metadata override for that type of template slide.
This is for the presentation's overall title. It probably has a title text line half way down the slide - though other designs are possible.
Generally you would use a Heading Level 1 (#
) to create such a slide.
This is for a section within the presentation - and is generally simpler than the presentation title slide. It probably has a title text line half way down the slide - though other designs are possible.
Generally you would use a Heading Level 2 (##
) to create such a slide.
This is used where there will be some content below a title - and md2pptx doesn't use any content that might already be on the slide.
This is where md2pptx wants to create a slide without using any content from the template slide.
This is where md2pptx wants to reuse e.g. a text area. It is expected the template slide will have a title shape.
While a key aim of the md2pptx project is to keep as closely as possible to standard Markdown (or at any rate Multimarkdown) there are some known incompatibilities. Apart from the fact md2pptx doesn't support all Markdown (or HTML) syntax, the deviations are intended to be useful and optional. (The ability to generate presentations with a simple text format is the paramount consideration.)
This section lists the known ones so you can make judgments about which deviations to tolerate.
Known deviations are:
-
md2pptx can reference Encapsulated Postscript (EPS) graphics - by converting them to .PNG files. Markdown and HTML can't. See Graphics File References for details of how you specify to md2pptx including graphics of various types.
-
In tables the number of dashes in a column's header is used to denote its relative width. This is not standard Markdown behaviour. See Table Slides for details of md2pptx's Tables support.
-
In tables trailing pipe (
|
) characters are optional in md2pptx. -
md2pptx supports inline Taskpaper format. Markdown doesn't. (The use of the Taskpaper
-
delimiter currently prevents md2pptx from supporting it as a list bullet marker.) See Task List Slides for details of md2pptx's Taskpaper support. -
Using md2pptx's "ppaction://" URI support to run a VBA macro won't work in HTML.
-
Using outbound hyperlinks in a heading is not standard Markdown - whether within the document or to the web.
-
GraphViz .dot files aren't rendered by most Markdown processors.
-
Funnels aren't rendered by any other Markdown processor.
-
run-python functionality isn't supported by any other Markdown processor.
md2pptx is a python program that uses the python-pptx library. There are many python-pptx capabilities that md2pptx doesn't use - because they can't be expressed directly in Markdown or HTML.
One good example is graphing. Another is highlighting cells in a table.
Running inline python, perhaps with helper routines, enables these.
The deal remains the same: A flat text file you author turning into a PowerPoint presentation.
Notes:
It is probably not a good idea to create additional slides in your python code - unless they are in a separate presentation. If you do md2pptx might very well get confused.
This support reserves space for your Python code to draw in. For some applications you will want this space to be zero. If that's the case consider the following dynamic metadata:
<!-- md2pptx: contentSplit: 1 0 -->
This ensures the second shape (in this case your Python drawing space) is zero in both dimensions. You can, of course, extend this technique to multiple shapes on a slide. For more information see ContentSplit.
The support described in Running Inline Python allows you to run arbitary python code. It would be unwise to embed python code of unknown provenance.
Use only code you directly write (or, of known provenance, embedded with mdpre's =include
capability).
In general, though, this function is worth exploring - if it enables you turn flat files into presentations that you otherwise couldn't make that way.
To code python inline start with this line:
``` run-python
then code your python logic.
Finish with the line:
```
This is like an ordinary code block but with the addition of run-python
on the opening line.
You could code your python in a separate file and embed it with mdpre's's =include
capability. That would be especially useful if you embed the same code in multiple slides or presentations.
While there is no absolute guarantee that variables won't get refactored the following variables are unlikely to be renamed.
slide
- the current slide you can manipulate. See Slides for the python-pptx documentation.renderingRectangle
- the dimensions and position of an area you can render into.
md2pptx provides a number of helper routines - to simplify common things such as chart creation and table manipulation.
Note: Most of the helper routines can be intermixed with standard python-pptx coding.
These general helper routines are meant equally to help with graphing and table manipulation. They can be combined. So, for example you could combine runPython.readCSV, runPython.filterRows, and runPython.transposeArray:
chart_csv = RunPython.transposeArray(RunPython.filterRows(RunPython.readCSV("chartdata.csv"), myFilter))
This function reads a CSV file into variables.
- file name.
- A list of rows, each row containing a list of cell values (e.g.
[["A","B"],[1,2],[3,4]]
)
The flavour of CSV reader is:
chart_reader = csv.reader(csvfile, quoting = csv.QUOTE_NONNUMERIC)
This function filters your array of data using a function you supply, returning another array.
- Data in the form created by RunPython.readCSV.
- A function you supply, returning
True
for "keep the row, otherwiseFalse
. The function should expect two parameters:- The row number, zero-indexed
- The row as a Python list
- Data in the form created by RunPython.readCSV.
This function transposes your array of data, returning another array.
- Data in the form created by RunPython.readCSV.
- Data in the form created by RunPython.readCSV.
This function ensures your program has a textbox to insert content into.
- The
slide
to add any needed textbox to. Generally this is theslide
object provided by md2pptx when your python code gets control. - The rectangle to render any new textbox in. Most likely this is the
renderingRectangle
object provided by md2pptx when your python code gets control. - The index of the shape to try to use as a textbox. This is optional.
- The textbox shape that is found or created.
There are two use cases:
-
If a shape index is passed in this routine will check if it is a textbox. If so it will be returned. If not, or if the index is invalid, a new textbox will be returned.
-
If no shape index is passed in this routine will search for the last textbox shape on the slide. If it is at index
0
that is presumed to be a slide title and a new textbox is created. If no textbox is found a new one is created.
This function is used in RunPython.checklistFromCSV
.
This function makes a CategoryChartData object, potentially for use with RunPython.makeChart
.
- The chart data in the form created by
RunPython.readCSV
. True
for series being columns,False
otherwise.True
is the default.True
causes the output array to be transposed.- Optional list of column numbers to filter on. This is zero-indexed and uses Python list syntax. Filtering occurs before any transposition.
Note: You can use this function to reorder (e.g. [3 1 2]
) and even duplicate rows (e.g. [4 1 1]
).
- A CategoryChartData object.
This function takes a CategoryChartData object, possibly made by RunPython.makeChartData
, and creates a
Chart shape from it.
This shape is added to the slide identified by the variable slide
.
- The
slide
to add the chart to. Generally this is theslide
object provided by md2pptx when your python code gets control. - The chart type. This is one of the values documented in XL_CHART_TYPE.
- The rectangle to render the new chart in. Most likely this is the
renderingRectangle
object provided by md2pptx when your python code gets control. - The chart data in CategoryChartData format. Most likely this was created by
RunPython.makeChartData
. - The title of the chart. This string defaults to
None
- which prevents a title being created. - The legend position for the chart. This is one of the values documented in XL_LEGEND_POSITION. This defaults to
None
which prevents a legend being created.
- A
Chart
object - which you can further manipulate.
This function creates a table from input data and makes a Table
shape from it.
This shape is added to the slide identified by the variable slide
.
- The
slide
to add the table to. Generally this is theslide
object provided by md2pptx when your python code gets control. - The rectangle to render the new table in. Most likely this is the
renderingRectangle
object provided by md2pptx when your python code gets control. - The table data in the form created by
RunPython.readCSV
.
- A
Table
object - which you can further manipulate.
This function sets the background colour of a cell in an existing Table
object.
- The
Table
object. - The row number. Zero-indexed and not bounds checked.
- The column number. Zero-indexed and not bounds checked.
- The red value - between 0 and 255.
- The green value - between 0 and 255.
- The blue value - between 0 and 255.
- Nothing is returned.
This function sets the background colour of a list of cells in an existing Table
object.
- The
Table
object. - The list of cells. Each item in the list is of the form
- The row number. Zero-indexed and not bounds checked.
- The column number. Zero-indexed and not bounds checked.
- The red value - between 0 and 255.
- The green value - between 0 and 255.
- The blue value - between 0 and 255.
- Nothing is returned.
This function aligns all the text paragraphs in a table cell. Generally there will be only one paragraph in a cell - but this function iterates over them all.
- The
Table
object. - The row number. Zero-indexed and not bounds checked.
- The column number. Zero-indexed and not bounds checked.
- Alignment. See PP_PARAGRAPH_ALIGNMENT.
- (Optional) paragraph number. If not specified all paragraphs in the cell will be aligned. If specified just the (zero-indexed) paragraph will be aligned.
- Nothing is returned.
This function draws a shape from a set of vertices, optionally filling it and adding text.
- The
slide
to add the shape to. Generally this is theslide
object provided by md2pptx when your python code gets control. - An array of points. Each point is of the form:
- x coordinate - in EMU units
- y coordinate - in EMU units
- Whether the shape is to be filled. Defaults to
False
. - Text to add to the shape. Defaults to
None
. - The text colour. Defaults to
None
- which leads to black text. See Specifying Colours. - The fill colour. Defaults to
None
- which, in the case of the shape being filled, leads to the presentation's default colour. See Specifying Colours. - Whether the shape is to be filled. Defaults to
True
.
- The created shape
There are a number of functions that can help you make checklists, including pulling in a CSV file with status in. These checklists can have ticked, crossed, or empty boxes - depending on the input data.
This function massages the output from RunPython.readCSV
to prepare it for input to RunPython.makeChecklist.
By default it operates on the second column and
- sets cells with text value
"Yes"
toTrue
. - sets cells with text value
"No"
toFalse
. - sets cells with text value
""
toNone
.
The column number and text string values can be changed from the defaults.
- Data in the form created by RunPython.readCSV.
- Column number to massage, zero-indexed. Defaults to "1".
- String to be set to
True
. Defaults to"Yes"
. - String to be set to
False
. Defaults to"No"
. - String to be set to
None
. Defaults to""
.
- Data in the form created by RunPython.readCSV.
The idea behind this function is to allow people to create CSV files with string values for state.
Once massaged the resulting array of arrays can be fed into RunPython.makeChecklist
.
This function creates a checklist in a textbox from a CSV file. The checklist items can be indented and can, optionally, be coloured to reflect their state.
- The
slide
to create the checklist on. Generally this is theslide
object provided by md2pptx when your python code gets control. - The rectangle to render any new textbox in. Most likely this is the
renderingRectangle
object provided by md2pptx when your python code gets control. - The name of the CSV file containing the list of items and their statuses.
- The index of the shape to try to use as a textbox. This is optional.
- Whether to colour the checklist items according to their state. This is optional and can be enabled by coding
colourChecks=True
as a parameter. The default is not to colour the checklist items.
- The textbox shape containing the rendered checklist.
This function uses the following lower level routines
RunPython.readCSV
to read in a CSV file.RunPython.makeTruthy
to massage the contents of the CSV file.RunPython.ensureTextbox
to find a textbox. The shape index you optionally pass in is passed on toRunPython.ensureTextbox
.RunPython.makeChecklist
to create the checklist content.RunPython.doChecklistChecks
- called byRunPython.makeChecklist
.
See Slide WIth A Checklist Examples for examples with the format of the CSV file.
This function creates a checklist in a textbox from an array. The checklist items can be indented and can, optionally, be coloured to reflect their state.
- The textbox shape to build the checklist in.
- The checklist.
- The index for the text of each item within each row. Defaults to
0
. - The index for the checked status of each item within each row. Defaults to
1
. - The index for the indentation level of each item within each row. Defaults to
2
. - Whether to colour the checklist items according to their state. This is optional and can be enabled by coding
colourChecks=True
as a parameter. The default is not to colour the checklist items.
- The textbox shape containing the rendered checklist.
This function is called by RunPython.checklistFromCSV
.
In turn it calls RunPython.doChecklistChecks
to do the actually placement of checkmarks.
Here is an example of a checklist array:
[
['Retrieved data', True, 1],
['Built databases', False, 1],
['Analysis', None, 1],
['Architectural Introduction', None, 2],
['CPU', None, 2],
['Memory and I/O', None, 2],
['WLM', None, 2],
['Parallel Sysplex', None, 2],
['DDF', None, 2],
['Batch', None, 2],
['Workshop', None, 1],
['Executive Summary', None]
]
In this example the checklist items are plain text.
They can be more complex than that, perhaps with some words bolded or wrapped in a <span>
element.
To do this simply ensure the first element of each item has the appropriate markup.
For example:
[
['Retrieved data', True, 1],
['Built databases', False, 1],
['Analysis', None, 1],
['Architectural Introduction', None, 2],
['CPU', None, 2],
['Memory and I/O', None, 2],
['WLM', None, 2],
['Parallel Sysplex', None, 2],
['<span class="optional">DDF</span>', None, 2],
['Batch', None, 2],
['Workshop', None, 1],
['<span class="Important">Executive Summary</span>', None]
]
This function adds check marks to the checklist items and, optionally, colours them to reflect their state.
- The textbox shape to set the checkmarks for.
- A list - one per paragraph - of checkmark indicators.
- Whether to colour the checklist items according to their state. This is optional and can be enabled by coding
colourChecks=True
as a parameter. The default is not to colour the checklist items.
- The textbox shape containing the rendered checklist.
The checkmark indicators are:
None
- leave the paragraph unchecked.True
- give the paragraph a tick.False
- give the paragraph a cross.
There are a number of routines to enable you to manipulate paragraphs in text boxes. Recall each text box has a set of paragraphs, which might or might not have bullets.
This function removes a single bullet from a shape.
- The text box shape to remove the bullet from.
- The index of the paragraph to remove the bullet from. The first paragraph has an index of 0.
- The text box shape
This function removes all the bullets from a text box shape.
- The text box shape to remove all the bullets from.
- The text box shape.
This function removes selected bullets from a text box shape.
- The text box shape to remove selected bullets from.
- A list of paragraph numbers to remove the bullets for. Each entry is a zero-indexed paragraph number.
- The text box shape.
You can annotate a slide using these helper routines.
A number of annotation types are supported:
- Lines, with or without line ending arrow heads
- Rectangles, with or without rounded corners, with or without text
- Images
The foreground colour can be set for each annotation. For an annotation with a closed shape the background colour can also be set.
All dimensions are in inches and can be negative. Positions are relative to the top left of the slide.
How to specify colours is described in Specifying Colours. This information will be handy with most of the annotations described below.
An annotation consists of a number of values. For RunPython.doAnnotations this is a list of values. For RunPython.annotationsFromCSV this is a line in a CSV file.
Each annotation starts with four floating point values:
- The starting x value, relative to the left edge of the slide.
- The starting y value, relative to the top edge of the slide.
- The width of the annotation. (Or the end x value relative to the beginning.)
- The height of the annotation. (Or the end y value relative to the end.)
The fifth item is either a code for the type of annotation or the text of the annotation.
The remainder of the list / line depends on the type of the annotation:
-
For a line the fifth item is one of
-
,<-
,->
, or<->
:-
denotes a line with no arrow heads.<-
denotes a line with an arrow head at the beginning.->
denotes a line with an arrow head at the end.<->
denotes a line with arrow heads at both ends.
An optional line colour can be specified as the sixth item. For example
#FF0000
orACCENT 1
. -
For a rectangle the fifth item is one of
[]
, or()
:[]
denotes a rectangle without rounded corners.()
denotes a rectangle with rounded corners.
If there is a non-empty sixth item it is text to be centred in the rectangle. If there is a non-empty seventh item it is the foreground colour. If there is a non-empty eighth item it is the background colour.
-
For a graphic the fifth item begins with a
!
and the remaining characters are the filename. The graphic is scaled to fit the rectangle defined by the first four items. -
Any other string is literally a text annotation, without a box. If there is a non-empty sixth item it is the foreground colour.
This function adds annotations to a slide from a list of lists. Each top-level list item describes a single annotation.
- The slide to annotate. Generally this is the
slide
object provided by md2pptx when your python code gets control. - Data in the form created by RunPython.readCSV.
- Nothing is returned.
This function adds annotations to a slide from a CSV file. Each line describes a single annotation.
- The slide to annotate. Generally this is the
slide
object provided by md2pptx when your python code gets control. - The name of the file to read annotations from.
- Nothing is returned.
This function uses RunPython.readCSV
to read in a CSV file.
It calls RunPython.doAnnotations
to perform the annotations.
Here are a few examples that use the Python helper routines.
- Graphing Example
- Table Manipulation Example
- Slide With A Shape Example
- Slide With A Checklist Examples
- Slide With Some Bullets Removed Example
- Annotations Example
Here is sample code to add a graph to a slide. The complete code snippet includes creating the new slide with a title, as well as graph creation from an external CSV file.
### Here Is A Slide With A Graph
``` run-python
# Read chart data from CSV file
chart_csv = RunPython.readCSV("chartdata.csv")
# Make chart data from the array. Second parameter defaults to True for "Series Is Column"
chart_data = RunPython.makeChartData(chart_csv, True)
chart1 = RunPython.makeChart(slide,
XL_CHART_TYPE.COLUMN_CLUSTERED,
renderingRectangle,
chart_data,
"My Important Chart",
XL_LEGEND_POSITION.BOTTOM)
```
This example uses helper routines provided by md2pptx:
RunPython.readCSV
reads in a CSV file.RunPython.makeChartData
turns this CSV data into chart data that can be directly used to make a chart.RunPython.makeChart
turns this chart data into a chart. You can use thechart1
object in further python-pptx calls.
The CSV file that readCSV
processes might look like this:
" ","East","West","Midwest"
"Series 1",19.2,21.4,16.7
"Series 2",17.8,13.1,22.9
"Series 3",19.2,21.4,16.7
"Series 4",17.8,13.1,22.9
You will notice two chart control items:
XL_CHART_TYPE.COLUMN_CLUSTERED
- the chart typeXL_LEGEND_POSITION.BOTTOM
- the chart legend position.
These are both from python-pptx. Rather than copy all the possible values into this user guide, see XL_CHART_TYPE and XL_LEGEND_POSITION. Other chart modifiers are available in python-pptx.
The result of this code looks something like this:
Here is sample code to add a table to a slide. The complete code snippet includes creating the new slide with a title, as well as table creation from an external CSV file.
### Here Is A Table
``` run-python
# Read chart data from CSV file
chart_csv = RunPython.readCSV("chartdata.csv")
# Make the table with the data
table1 = RunPython.makeTable(slide,renderingRectangle, chart_csv)
# Set a cell background to yellow
RunPython.applyCellFillRGB(table1, 2, 3, 255, 255, 0)
# Set list of cells to green
greenList = [(0, 0), (2,1), (3,2)]
RunPython.applyCellListFillRGB(table1, greenList, 0, 255, 0)
```
This example uses helper routines provided by md2pptx:
RunPython.readCSV
reads in a CSV file.RunPython.makeTable
makes a table from the CSV data.RunPython.applyCellFillRGB
turns the background of one cell yellow.RunPython.applyCellListFillRGB
turns the background of three cells green.
In this example makeTable
computes the new table's row and column counts from the read in CSV file.
The CSV file might look like the one in Graphing Example.
The result of this code looks something like this:
Here is sample code to add a shape to a slide. The complete code snippet includes creating the new slide with a title, as well as shape creation.
In this example the shape occupies the whole of the offered rendering rectangle.
The shape is created with RunPython.makeDrawnShape
with the following parameters:
- The current slide - given by the variable
slide
. - An array of points.
True
to fill the shape.- Some text to add to the shape - "My Text".
- A text colour that is red -
#FF0000
. - A background colour that is turquoise -
#00FFFF
. True
for joining up the shape (defaulted here).
### Here Is A Slide - With Smart Colouring
``` run-python
vertices = [
(renderingRectangle.left, renderingRectangle.top),
(renderingRectangle.left + renderingRectangle.width, renderingRectangle.top),
(renderingRectangle.left + renderingRectangle.width, renderingRectangle.top + renderingRectangle.height),
(renderingRectangle.left, renderingRectangle.top + renderingRectangle.height),
]
s = RunPython.makeDrawnShape(slide, vertices, True, "My Text","#FF0000","#80FFFF")
```
The result of this code looks something like this:
Here is sample code to add a checklist to a slide. Let's start with a CSV file with three lines in it. Each represents a task. The first has an empty completion cell, the second has a positive completion cell, and the third has a negative one.
Let's call this "tasks.csv":
"One task",""
"Another task","Yes"
"A task that won't get done","No"
This is the kind of file you could create and maintain by hand, or with a tool.
If you run the following through md2pptx you get a slide with a title and a three-item checklist.
template: Martin Template.pptx
### Here Is A Slide With A Checklist
``` run-python
RunPython.checklistFromCSV(slide, renderingRectangle, "tasks.csv")
```
The resulting slide would look something like this:
Obviously you could create a presentation with multiple such slides, each from a different CSV file.
Checklists can be more sophisticated than this simple example shows. If you add a third column you can specify an indentation level for each checklist item. Here is such a CSV file:
"Retrieved data","Yes",1
"Built databases","",1
"Analysis","",1
"Architectural Introduction","",2
"CPU","",2
"Memory and I/O","",2
"WLM","",2
"Parallel Sysplex","",2
"DDF","",2
"Batch","",2
"Workshop","",1
"Executive Summary",""
You'll notice the "Executive Summary" row doesn't have a third cell. This leads to the item not being indented. All the other items have a third cell. Those with "1" in that cell are not indented. Those with "2" are indented by 1.
The result looks something like this:
You can optionally colour the checklist, based on each item's status.
You do this by adding colourChecks = True
to the RunPython.checklistFromCSV
function call.
The result might look something like this:
Here is sample code to remove some bullets from a text box on a slide.
### Here Is A Slide With Some bullets To Fix Up
* One
* Two
* Three
``` run-python
myTextbox = RunPython.ensureTextbox(slide, renderingRectangle)
RunPython.removeSelectedBullets(myTextbox, [0, 2])
```
In this case - because the array of paragraphs to remove bullets from is zero-indexed - the first and third bullets are removed.
The resulting slide would look something like this:
This example shows how to annotate a slide using a CSV file to handle the annotations. This is probably the most common and simplest case.
The Python code is very simple:
### Here Is A Slide
* **Here** is some text
``` run-python
RunPython.annotationsFromCSV(slide, "annotations.csv")
```
In this example the slide has a title and a list with a single bullet.
The Python code follows.
It calls RunPython.annotationsFromCSV
with two parameters:
- The current slide.
- The annotations CSV file.
In this example you probably want to add the dynamic metadata line below the title line:
<!-- md2pptx: contentsplit: 1 0 -->
This will ensure no space is reserved on the slide for the Python code, just for the bulleted list.
Here is a sample Annotations CSV file:
"1.0","2.0","2.0","2.0","Hello from Annotations","#FF0000"
"1.0","6.0","2.0","2.0","Hello again from Annotations","ACCENT 3"
"3.0","4.0","5.0","6.0","->"
"6.0","4.0","1.0","1.0","!block.png"
"4.0","3.0","5.0","6.0","<-","#FF0000"
"5.0","2.0","5.0","6.0","-","ACCENT 4"
"7.0","2.0","2.0","0.75","[]","Fred","","ACCENT 4"
"8.0","3.0","2.0","0.5","()","Jim","#00FF00","#FF0000"
You can see the first four cells are dimensions and the fifth an "annotation code":
- The first two lines are character strings, one with an RGB colour and the other with a theme colour.
- The third is a line with an arrow head on the end. It uses default colouring.
- The fourth is a graphic.
- The fifth is a line with an arrow head at the start. It uses RGB colouring.
- The sixth is a line with no arrow heads. It uses theme colouring.
- The seventh is a rectangle with text in it. Its foreground colour is defaulted and its background is set to a theme colour.
- The eighth is a rectangle with rounded corners, with text in it. Both the foreground and background are set to RGB colours.
This user guide is written in Markdown - but with a few extensions. To build it correctly you need to use mdpre.
The command to convert to standard Markdown is:
mdpre -v < user-guide.mdp > user-guide.md 2>user-guide.log
Then convert user-guide.md from Markdown to HTML using your converter of choice. (The prime author of this package uses Sublime Text.)
If committing include all the user-guide.*
files.
Obviously, it's user-guide.mdp you edit to make your changes.
Notes:
- For extensive blocks of text you might like to use mdpre's
=include
capability - to embed a file with your text. - If you are creating tables mdpre's
=csv
capability is what this user guide has used.