この拡張機能は Markdown ファイルを pdf、html、png、jpeg ファイルに変換します。
- PDFのヘッダーとフッターのデフォルトの日付書式変更
- バージョン1.5.0から、ヘッダーとフッターのデフォルトの日付書式がISOベースの書式(YYYY-MM-DD)に変更されました。
- この変更は、以前の書式が環境によって異なる可能性があったため、日付表示の一貫性を向上させることを目的としています。
- 以前の書式を使用したい場合は、markdown-pdf.headerTemplateを参照してください。
以下の機能をサポートしています。
- Syntax highlighting
- emoji
- markdown-it-checkbox
- markdown-it-container
- markdown-it-include
- PlantUML
- mermaid
サンプルファイル
INPUT
::: warning
*here be dragons*
:::
OUTPUT
<div class="warning">
<p><em>here be dragons</em></p>
</div>
INPUT
@startuml
Bob -[#red]> Alice : hello
Alice -[#0000FF]->Bob : ok
@enduml
OUTPUT
Include markdown fragment files: :[alternate-text](relative-path-to-file.md)
.
├── [plugins]
│ └── README.md
├── CHANGELOG.md
└── README.md
INPUT
README Content
:[Plugins](./plugins/README.md)
:[Changelog](CHANGELOG.md)
OUTPUT
Content of README.md
Content of plugins/README.md
Content of CHANGELOG.md
INPUT
```mermaid stateDiagram [*] --> First state First { [*] --> second second --> [*] } ```
OUTPUT
Markdown PDF をインストールして、Visual Studio Code で Markdownファイルを最初に開いた時、Chromium のダウンロードが自動で始まります。
しかしサイズが大きい為 (~170Mb Mac, ~282Mb Linux, ~280Mb Win) 、環境によっては時間がかかります。
ダウンロード中は、ステータスバーに Installing Puppeteer
のメッセージが表示されます。
もしプロキシを使う必要がある場合、settings.json に http.proxy
でプロキシを設定し、Visual Studio Code を再起動してください。
ダウンロードが上手くいかない場合や、Markdown PDF のバージョンアップの度にダウンロードするのを避けたい場合、markdown-pdf.executablePath オプションでインストール済みの Chrome か Chromium を指定してください。
- Markdown ファイルを開きます
F1
キーを押すか、Ctrl+Shift+P
キーを入力しますexport
と入力し以下を選択しますmarkdown-pdf: Export (settings.json)
markdown-pdf: Export (pdf)
markdown-pdf: Export (html)
markdown-pdf: Export (png)
markdown-pdf: Export (jpeg)
markdown-pdf: Export (all: pdf, html, png, jpeg)
- Markdown ファイルを開きます
- 右クリックして以下を選択します
markdown-pdf: Export (settings.json)
markdown-pdf: Export (pdf)
markdown-pdf: Export (html)
markdown-pdf: Export (png)
markdown-pdf: Export (jpeg)
markdown-pdf: Export (all: pdf, html, png, jpeg)
- settings.json に
"markdown-pdf.convertOnSave": true
オプションを追加します - Visual Studio Code を再起動します
- Markdown ファイルを開きます
- 保存すると自動で変換されます
Visual Studio Code User and Workspace Settings
- メニューから ファイル > 基本設定 > ユーザー設定 か ワークスペース設定 を選択します
- 既定の設定 から markdown-pdf の設定を探します
markdown-pdf.*
の設定をコピーします- settings.json に貼り付け、値を変更します
- 出力フォーマット: pdf, html, png, jpeg
- 複数の出力フォーマットをサポート
- Default: pdf
"markdown-pdf.type": [
"pdf",
"html",
"png",
"jpeg"
],
- 保存時の自動変換を有効にします
- boolean. Default: false
- 設定の反映には、Visutal Studio Code の再起動が必要です
- convertOnSave オプションの除外ファイル名を指定します
"markdown-pdf.convertOnSaveExclude": [
"^work",
"work.md$",
"work|test",
"[0-9][0-9][0-9][0-9]-work",
"work\\test" // 全ての \ は \\ と記述する必要があります。(Windows)
],
- 出力ディレクトリを指定します
- 全ての
\
は\\
と記述する必要があります (Windows)
"markdown-pdf.outputDirectory": "C:\\work\\output",
- 相対パス
Markdownファイル
を開いた場合、ファイルからの相対パスとして解釈されますフォルダ
を開いた場合、ルートフォルダからの相対パスとして解釈されますワークスペース
を開いた場合、それぞれのルートフォルダからの相対パスとして解釈されます- マルチルート ワークスペース を参照してください
"markdown-pdf.outputDirectory": "output",
- 相対パス (ホームディレクトリ)
- パスが
^
で始まっている場合、ホームディレクトリからの相対パスとして解釈されます
- パスが
"markdown-pdf.outputDirectory": "~/output",
相対パス
でディレクトリを設定した場合、ディレクトリが存在しなければ作成されます絶対パス
でディレクトリを設定した場合、ディレクトリが存在しなければエラーになります
markdown-pdf.outputDirectoryRelativePathFile
オプションがtrue
に設定されている場合、markdown-pdf.outputDirectory で設定した相対パスは、ファイルからの相対パスとして解釈されます- フォルダやワークスペースからの相対パスを避けたい場合に使うことが出来ます
- boolean. Default: false
- markdown-pdf で使用するスタイルシートのパスを指定します
- ファイルが存在しない場合、スキップされます
- 全ての
\
は\\
と記述する必要があります (Windows)
"markdown-pdf.styles": [
"C:\\Users\\<USERNAME>\\Documents\\markdown-pdf.css",
"/home/<USERNAME>/settings/markdown-pdf.css",
],
- 相対パス
Markdownファイル
を開いた場合、ファイルからの相対パスとして解釈されますフォルダ
を開いた場合、ルートフォルダからの相対パスとして解釈されますワークスペース
を開いた場合、それぞれのルートフォルダからの相対パスとして解釈されます- マルチルート ワークスペース を参照してください
"markdown-pdf.styles": [
"markdown-pdf.css",
],
- 相対パス (ホームディレクトリ)
- パスが
^
で始まっている場合、ホームディレクトリからの相対パスとして解釈されます
- パスが
"markdown-pdf.styles": [
"~/.config/Code/User/markdown-pdf.css"
],
- オンラインCSS (https://xxx/xxx.css) は JPG と PNG では正しく適用されますが、PDF では問題が発生します #67
"markdown-pdf.styles": [
"https://xxx/markdown-pdf.css"
],
markdown-pdf.stylesRelativePathFile
オプションがtrue
に設定されている場合、markdown-pdf.styles で設定した相対パスは、ファイルからの相対パスとして解釈されます- フォルダやワークスペースからの相対パスを避けたい場合に使うことが出来ます
- boolean. Default: false
- デフォルトのスタイルシート(VSCode, markdown-pdf)を有効にします
- boolean. Default: true
- Syntax highlighting を有効にします
- boolean. Default: true
- スタイルシートのファイル名を指定します。例: github.css, monokai.css ...
- ファイル名のリスト
- highlight.js demo
"markdown-pdf.highlightStyle": "github.css",
- 改行を有効にします
- boolean. Default: false
- 絵文字を有効にします EMOJI CHEAT SHEET
- boolean. Default: true
- バンドルされた Chromium の代わりに実行する Chromium または Chrome のパスを指定します
- 全ての
\
は\\
と記述する必要があります (Windows) - 設定の反映には、Visutal Studio Code の再起動が必要です
"markdown-pdf.executablePath": "C:\\Program Files (x86)\\Google\\Chrome\\Application\\chrome.exe"
- ページレンダリングのスケール
- number. default: 1
"markdown-pdf.scale": 1
- pdf only. puppeteer page.pdf options
- ヘッダーとフッター表示を有効にします
- boolean. Default: true
- このオプションを有効にすると、ヘッダーとフッターが両方表示されます
- 片方を表示したくない場合は、もう片方の値を削除します
- ヘッダー非表示
"markdown-pdf.headerTemplate": "",
- フッター非表示
"markdown-pdf.footerTemplate": "",
- ヘッダーを出力する為のHTMLテンプレートを指定します
- このオプションを使用するには、
markdown-pdf.displayHeaderFooter
をtrue
に設定する必要があります。 <span class='date'></span>
: 日付。フォーマットは環境に依存します<span class='title'></span>
: Markdown ファイル名<span class='url'></span>
: Markdown フルパスファイル名<span class='pageNumber'></span>
: 現在のページ番号<span class='totalPages'></span>
: ドキュメントの総ページ数%%ISO-DATETIME%%
: 現在の日付と時刻。ISOベース フォーマット (YYYY-MM-DD hh:mm:ss
)%%ISO-DATE%%
: 現在の日付。ISOベース フォーマット (YYYY-MM-DD
)%%ISO-TIME%%
: 現在の時刻。ISOベース フォーマット (hh:mm:ss
)- Default (version1.5.0以降): Markdown ファイル名 と 日付を
%%ISO-DATE%%
で表示します"markdown-pdf.headerTemplate": "<div style=\"font-size: 9px; margin-left: 1cm;\"> <span class='title'></span></div> <div style=\"font-size: 9px; margin-left: auto; margin-right: 1cm; \">%%ISO-DATE%%</div>",
- Default (version1.4.4以前): Markdown ファイル名 と 日付を
<span class='date'></span>
で表示します"markdown-pdf.headerTemplate": "<div style=\"font-size: 9px; margin-left: 1cm;\"> <span class='title'></span></div> <div style=\"font-size: 9px; margin-left: auto; margin-right: 1cm; \"> <span class='date'></span></div>",
- フッターを出力する為のHTMLテンプレートを指定します
- 詳細は、markdown-pdf.headerTemplate を参照してください
- Default: {現在のページ番号} / {ドキュメントの総ページ数} を表示します
"markdown-pdf.footerTemplate": "<div style=\"font-size: 9px; margin: 0 auto;\"> <span class='pageNumber'></span> / <span class='totalPages'></span></div>",
- 背景のグラフィックを出力
- boolean. Default: true
- ページの向き
- portrait(縦向き) or landscape(横向き)
- Default: portrait
- 出力するページ範囲 例) '1-5, 8, 11-13'
- Default: 全ページ
"markdown-pdf.pageRanges": "1,4-",
- 用紙のフォーマット
- Letter, Legal, Tabloid, Ledger, A0, A1, A2, A3, A4, A5, A6
- Default: A4
"markdown-pdf.format": "A4",
- 用紙の幅/高さ、 単位(mm, cm, in, px)
- このオプションが指定されている場合、markdown-pdf.format オプションより優先されます
"markdown-pdf.width": "10cm",
"markdown-pdf.height": "20cm",
- 用紙の余白、単位(mm, cm, in, px)
"markdown-pdf.margin.top": "1.5cm",
"markdown-pdf.margin.bottom": "1cm",
"markdown-pdf.margin.right": "1cm",
"markdown-pdf.margin.left": "1cm",
- png and jpeg only. puppeteer page.screenshot options
- jpeg only. イメージの品質を 0-100 の範囲で指定します。 png では無効です。
"markdown-pdf.quality": 100,
- ページの切り抜き領域を指定します
- number
// 切り抜き領域のX軸の基点を指定します。ページの左上が原点です。
"markdown-pdf.clip.x": 0,
// 切り抜き領域のY軸の基点を指定します。ページの左上が原点です。
"markdown-pdf.clip.y": 0,
// 切り抜き領域の幅を指定します
"markdown-pdf.clip.width": 1000,
// 切り抜き領域の高さを指定します
"markdown-pdf.clip.height": 1000,
- デフォルトの白い背景ではなく、透過によるスクリーンショットのキャプチャーを有効にします
- boolean. Default: false
- plantuml パーサーの開始区切り文字
- Default: @startuml
- plantuml パーサーの終了区切り文字
- Default: @enduml
- Plantuml server. e.g. http://localhost:8080
- Default: http://www.plantuml.com/plantuml
- 例えば、PlantUMLサーバをローカルで実行するには次のようにします #139 :
plantuml/plantuml-server - Docker Hub
docker run -d -p 8080:8080 plantuml/plantuml-server:jetty
- markdown-it-include を有効にします
- boolean. Default: true
- mermaid server
- Default: https://unpkg.com/mermaid/dist/mermaid.min.js
- 以下の設定を markdown-pdf.styles で指定したスタイルシートに追加します。
.emoji {
height: 2em;
}
Visual Studio Code の files.autoGuessEncoding
オプションを使うと、文字コードが自動判定されるので便利です。
"files.autoGuessEncoding": true,
常に Markdown ファイルからの相対パスのディレクトリに出力したい場合。
例えば、Markdown ファイルと同じディレクトリの "output"ディレクトリに出力する場合、次のように設定してください。
"markdown-pdf.outputDirectory" : "output",
"markdown-pdf.outputDirectoryRelativePathFile": true,
改ページを挿入するには、以下を使用してください。
<div class="page"/>
- オンラインCSS (https://xxx/xxx.css) は JPG と PNG では正しく適用されますが、PDF では問題が発生します #67
- Improve: The default date format for headers and footers has been changed to the ISO-based format (YYYY-MM-DD).
- Support different date formats in templates #197
- Improve: Avoid TimeoutError: Navigation timeout of 30000 ms exceeded and TimeoutError: waiting for Page.printToPDF failed: timeout 30000ms exceeded #266
- Fix: Fix description of outputDirectoryRelativePathFile #238
- README
- Add: Specification Changes
- Fix: Broken link
MIT
- GoogleChrome/puppeteer
- markdown-it/markdown-it
- mcecot/markdown-it-checkbox
- leff/markdown-it-named-headers
- markdown-it/markdown-it-emoji
- HenrikJoreteg/emoji-images
- isagalaev/highlight.js
- cheeriojs/cheerio
- janl/mustache.js
- markdown-it/markdown-it-container
- gmunguia/markdown-it-plantuml
- camelaissani/markdown-it-include
- mermaid-js/mermaid
- jonschlinkert/gray-matter
and