Markdown转pdf
最近由于项目需要,要用到把markdown转换成pdf文件下载下来,最开始的时候想到的是先把markdown转成html,用到的是Parsedown;然后再将html转成pdf,用到了html2pdf,这是两个php的类库,安装起来十分简单,只需要用composer安装即可。
"require": {
"spipu/html2pdf": "^4.6",
"erusev/parsedown": "^1.6"
},
将这两句加入到composer.json中,运行composer install。这样在vendor中会多处三个文件夹:erusev,spipu,tecnickcom。
下面是php的部分代码:
- $result = Parsedown::instance()->parse($comtent);//$content是从数据库取出的markdown的东西
- $html2pdf = new HTML2PDF('P', 'A4', 'fr', true, 'UTF-8', 3);
- $html2pdf->SetDefaultFont('droidsansfallback');//设置字体,这个字体需要自己去添加,因为html2pdf本身是不支持中文的,会出现乱码,你需要把droidsansfallback.php、droidsansfallback.z以及droidsansfallback.ctg.z(可以百度到的)这三个文件复制到 TCPDF\fonts 下面即可。
//html2pdf中文支持底层是TCPDF实现的,在执行composer install的时候会自动安装上tcpdf.- $html2pdf->writeHTML($result);
- $html2pdf->Output('a.pdf');输出a.pdf文件,直接下载了。
这样试一试真的可以下载pdf文件了。。。但是,你会发现中文都没有换行。这是一个大坑,我在网上找了好多资料都没有好的解决办法;
暂时不提这个,接着我们还有个需求就是需要批量下载,这是我遇到的第二个坑,html2pdf没有生成pdf文件,而是直接通过header()函数发送到浏览器(这个你可以查看$html2pdf->Output()这个函数源码),所以批量下载也会有很多麻烦。
其次当你的md中有代码的时候,也就是转化的html有这样的标签,<pre><code>测试</code></pre>,中文就会出现乱码,这个即便你已经设置了中文字体也会出现。
经历了这些,我果断放弃了这种方法。但是,总会有其他的办法的,于是我找到了pandoc。
我简单介绍一下这个东西,它被称作是一款神器
它可以把markdown、 reStructuredText、 textile、 HTML、或者LaTeX转换成:
HTML格式: XHTML, HTML5, 以及HTML幻灯片Slidy, S5,或者DZSlides.
文字处理软件格式: Microsoft Word docx, OpenOffice/LibreOffice ODT, OpenDocument XML
电子书: EPUB
文档格式: DocBook, GNU TexInfo, Groff man pages
TeX格式: LaTeX, ConTeXt, LaTeX Beamer slides
PDF via LaTeX
轻量级标记语言格式: Markdown, reStructuredText, AsciiDoc, MediaWiki markup, Emacs Org-Mode, Textile。
我的是mac环境,所以安装pandoc:
- brew install pandoc
pandoc 在生成pdf时需要借助laTex排版引擎,不建议安装精简版的,因为这样还需要安装各种依赖包;我直接安装了mactex(挺大的大概两个多GB),这时候我们就可以借助命令行生成生成pdf了,是不是有点小激动呢~
- pandoc --latex-engine=xelatex -V mainfont='STSong' --template=pandoc/pm-template a.md -o a.pdf //STSong是mac中的一种中文字体,这个字体一定要保证你的电脑上有才行
- $stream = fopen(a.md, "w+");//生成a.md文件
- fwrite($stream,$content);//将md内容写到该文件中
- exec('pandoc --latex-engine=xelatex -V mainfont=\'STSong\' --template=my a.md -o a.pdf',$output,$return_val);//执行转化命令,--latex-engine=xelatex 指定排版引擎为 xelatex ,为什么?因为默认的排版引擎不支持中文.
以下是我提供的my.latex模版
- \documentclass[$if(fontsize)$$fontsize$,$endif$$if(lang)$$lang$,$endif$$if(papersize)$$papersize$,$endif$]{$documentclass$}
- \usepackage{geometry} % 設定邊界
- \geometry{
- top=1in,
- inner=1in,
- outer=1in,
- bottom=1in,
- headheight=3ex,
- headsep=2ex
- }
- \usepackage[T1]{fontenc}
- \usepackage{lmodern}
- \usepackage{amssymb,amsmath}
- \usepackage{ifxetex,ifluatex}
- \usepackage{fixltx2e} % provides \textsubscript
- % use upquote if available, for straight quotes in verbatim environments
- \IfFileExists{upquote.sty}{\usepackage{upquote}}{}
- \ifnum 0\ifxetex 1\fi\ifluatex 1\fi=0 % if pdftex
- \usepackage[utf8]{inputenc}
- $if(euro)$
- \usepackage{eurosym}
- $endif$
- \else % if luatex or xelatex
- \usepackage{fontspec} % 允許設定字體
- \usepackage{xeCJK} % 分開設置中英文字型
- \setCJKmainfont{STSong} % 設定中文字型
- \setmainfont{Georgia} % 設定英文字型
- \setromanfont{Georgia} % 字型
- \setmonofont{Courier New}
- \linespread{1.2}\selectfont % 行距
- \XeTeXlinebreaklocale "zh" % 針對中文自動換行
- \XeTeXlinebreakskip = 0pt plus 1pt % 字與字之間加入0pt至1pt的間距,確保左右對整齊
- \parindent 0em % 段落縮進
- \setlength{\parskip}{20pt} % 段落之間的距離
- \ifxetex
- \usepackage{xltxtra,xunicode}
- \fi
- \defaultfontfeatures{Mapping=tex-text,Scale=MatchLowercase}
- \newcommand{\euro}{€}
- $if(mainfont)$
- \setmainfont{$mainfont$}
- $endif$
- $if(sansfont)$
- \setsansfont{$sansfont$}
- $endif$
- $if(monofont)$
- \setmonofont{$monofont$}
- $endif$
- $if(mathfont)$
- \setmathfont{$mathfont$}
- $endif$
- \fi
- % use microtype if available
- \IfFileExists{microtype.sty}{\usepackage{microtype}}{}
- $if(geometry)$
- \usepackage[$for(geometry)$$geometry$$sep$,$endfor$]{geometry}
- $endif$
- $if(natbib)$
- \usepackage{natbib}
- \bibliographystyle{plainnat}
- $endif$
- $if(biblatex)$
- \usepackage{biblatex}
- $if(biblio-files)$
- \bibliography{$biblio-files$}
- $endif$
- $endif$
- $if(listings)$
- \usepackage{listings}ƒ
- $endif$
- $if(lhs)$
- \lstnewenvironment{code}{\lstset{language=Haskell,basicstyle=\small\ttfamily}}{}
- $endif$
- $if(highlighting-macros)$
- $highlighting-macros$
- $endif$
- $if(verbatim-in-note)$
- \usepackage{fancyvrb}
- $endif$
- $if(tables)$
- \usepackage{longtable}
- $endif$
- $if(graphics)$
- \usepackage{graphicx}
- % We will generate all images so they have a width \maxwidth. This means
- % that they will get their normal width if they fit onto the page, but
- % are scaled down if they would overflow the margins.
- \makeatletter
- \def\maxwidth{\ifdim\Gin@nat@width>\linewidth\linewidth
- \else\Gin@nat@width\fi}
- \makeatother
- \let\Oldincludegraphics\includegraphics
- \renewcommand{\includegraphics}[1]{\Oldincludegraphics[width=\maxwidth]{#1}}
- $endif$
- \ifxetex
- \usepackage[setpagesize=false, % page size defined by xetex
- unicode=false, % unicode breaks when used with xetex
- xetex]{hyperref}
- \else
- \usepackage[unicode=true]{hyperref}
- \fi
- \hypersetup{breaklinks=true,
- bookmarks=true,
- pdfauthor={$author-meta$},
- pdftitle={$title-meta$},
- colorlinks=true,
- urlcolor=$if(urlcolor)$$urlcolor$$else$blue$endif$,
- linkcolor=$if(linkcolor)$$linkcolor$$else$magenta$endif$,
- pdfborder={0 0 0}}
- \urlstyle{same} % don't use monospace font for urls
- $if(links-as-notes)$
- % Make links footnotes instead of hotlinks:
- \renewcommand{\href}[2]{#2\footnote{\url{#1}}}
- $endif$
- $if(strikeout)$
- \usepackage[normalem]{ulem}
- % avoid problems with \sout in headers with hyperref:
- \pdfstringdefDisableCommands{\renewcommand{\sout}{}}
- $endif$
- \setlength{\parindent}{0pt}
- %\setlength{\parskip}{6pt plus 2pt minus 1pt}
- \setlength{\emergencystretch}{3em} % prevent overfull lines
- \title{\huge 在OSX平台上的XeLaTeX中文測試} % 設置標題,使用巨大字體
- \author{FoolEgg.com} % 設置作者
- \date{February 2013} % 設置日期
- \usepackage{titling}
- \setlength{\droptitle}{-8em} % 將標題移動至頁面的上面
- \usepackage{fancyhdr}
- \usepackage{lastpage}
- \pagestyle{fancyplain}
- $if(numbersections)$
- \setcounter{secnumdepth}{5}
- $else$
- \setcounter{secnumdepth}{0}
- $endif$
- $if(verbatim-in-note)$
- \VerbatimFootnotes % allows verbatim text in footnotes
- $endif$
- $if(lang)$
- \ifxetex
- \usepackage{polyglossia}
- \setmainlanguage{$mainlang$}
- \else
- \usepackage[$lang$]{babel}
- \fi
- $endif$
- $for(header-includes)$
- $header-includes$
- $endfor$
- $if(title)$
- \title{$title$}
- $endif$
- \author{$for(author)$$author$$sep$ \and $endfor$}
- \date{$date$}
- \begin{document}
- $if(title)$
- \maketitle
- $endif$
- $for(include-before)$
- $include-before$
- $endfor$
- $if(toc)$
- {
- \hypersetup{linkcolor=black}
- \setcounter{tocdepth}{$toc-depth$}
- \tableofcontents
- }
- $endif$
- $body$
- $if(natbib)$
- $if(biblio-files)$
- $if(biblio-title)$
- $if(book-class)$
- \renewcommand\bibname{$biblio-title$}
- $else$
- \renewcommand\refname{$biblio-title$}
- $endif$
- $endif$
- \bibliography{$biblio-files$}
- $endif$
- $endif$
- $if(biblatex)$
- \printbibliography$if(biblio-title)$[title=$biblio-title$]$endif$
- $endif$
- $for(include-after)$
- $include-after$
- $endfor$
- \end{document}
Markdown转pdf的更多相关文章
- Markdown: 编译pdf
在网上发布博文的时候希望能顺便在本地保存一份记录,这样总结的东西很多的时候就可以写成一本给自己看的小书了.在linux下面有两个选择latex和markdown,虽然latex非常强大,但是很少有博客 ...
- MarkDown to PDF
前面随便说说 之前在 windows 上一直习惯用 cmdmarkdown 把要写的东西写下来,再通过 typora 转成 pdf:现在很多时候在用 Ubuntu,需要把写完的作业转成 pdf 交上去 ...
- atom markdown转换PDF 解决AssertionError: html-pdf: Failed to load PhantomJS module
atom编辑器markdown转换PDF 解决AssertionError: html-pdf: Failed to load PhantomJS module. You have to set th ...
- markdown 转 pdf 方法
(1)Mou: (macosx 系统下的markdown编辑器,转pdf完美,推荐) http://25.io/mou/ (2)Chrome 打印 (打印得很好看,缺点是转好的pdf上的文字有时候不能 ...
- markdown转为pdf文件
要求: 把.md格式转为.pdf格式,并批量处理,最后将多个pdf文件合并为一个pdf并以文件名作为书签名 解决思路: 1.md格式的markdown文件转为html 为了将 md 格式转换成 htm ...
- 使用 VS Code + Markdown 编写 PDF 文档
背景介绍 作为一个技术人员,基本都需要编写技术相关文档,而且大部分技术人员都应该掌握 markdown 这个技能,使用 markdown 来编写并生成 PDF 文档将会是一个不错的体验,以下就介绍下如 ...
- windows使用Pandoc将Markdown转换为PDF文件
pandoc下载:https://github.com/jgm/pandoc/releases/tag/1.19.2.1 //windows下载msi文件 miktex下载:https://mikte ...
- [原创]使用Pandoc实现Markdown文件转PDF文件
Markdown写法简单明快,我十分喜欢,以至于我最近都想使用Markdown快速的进行测试说明书的写作,但是考虑到这文档是要进行交接的,一个.md的文件在内部传输还是有不便,于是就想到了能不能把Ma ...
- 关于Markdown格式转PDF格式
Markdown转PDF格式 个人使用的Markdown编辑平台:有道云笔记网页版 当我们编辑好自己的随笔以后,在网页的[客户端下载]下面有一个[更多]的圆形图标选项,点击后在菜单中有一处[打印]选项 ...
随机推荐
- minSdkVersion与targetSdkVersion
targetSdkVersion是Android提供向前兼容的主要依据,在应用的targetSdkVersion没有更新之前,系统不会应用最新的行为变化 比如设置了app的targetSdkVersi ...
- createElement、createTextNode、setAttribute使用方法
createElement() 方法可创建元素节点. 示例:var placeholder = document.createElement("img"); createTextN ...
- 初步使用nodejs(一)
初步使用nodejs(一) 首先打开 https://nodejs.org/,点击INSTALL下载安装 安装完成后 打开CMD 输入node –v 验证是否正常 至此,NODEJS安装完成. 下载W ...
- visual studio 中将选中代码相同的代码的颜色设置,修改高亮颜色
这是一个很实用的功能,默认的设置里不是很明显,设置完之后效果图如下: 具体设置方法是: 1. 菜单:工具 -> 选项 ->环境 ->字体和颜色 2. 在右边的 "显示 ...
- Java 不使用科学计数法表示数据设置
java.text.NumberFormat nf = java.text.NumberFormat.getInstance(); nf.setGroupingUsed(false); nf.form ...
- linux xfce4普通用户 mount usb提示: Not authorized to perform operation
问题:xfce4下,USB 硬盘能自动挂载并显示,但是普通用户操作时,提示:Not authorized to perform operation. 时间:20160928 os:gentoo + x ...
- Java泛型的定义以及对于<? extends T>和<? super T>
Java 中对于泛型方法的定义: public <T> T getT(){ .....相关代码; } 其中我对<T>的理解就是申明只是一个泛型方法的标记,T是返回的类型. 对于 ...
- USACO 3.2 Contact
ContactIOI'98 The cows have developed a new interest in scanning the universe outside their farm wit ...
- 解决IE兼容总汇【转】
转载声明: 藏羚羊 2014年04月16日 于 前端开拓者 发表 本文固定链接: http://www.frontopen.com/2552.html 1. <meta http-equiv=“ ...
- cocos2d安装配置及打包成Android
vs+python+cocos2d python下载:点这里 这里需要下载Python 2.X版本.曾经以为要下载3.x版本 后来装上发现cocos2d-x提供的python运行报错,所以卸载以后重新 ...