Asciidoctor-pdf生成pdf文件
本文使用asciidoc语法编写。
= Asciidoctor-pdf生成pdf文件
Pinnsvin Pinnsvin@163.com
v1.0 {docdate}
:plantuml-server-url: https://www.plantuml.com/plantuml
:toc:
:doctype: article
:imagesdir: ../images
// enable font awesome
:icons: font
// enable UI
:experimental:
:source-highlighter: rouge
:idprefix: id_
== 简述
asciidoctor-pdf是Asciidoctor一个使用Prawn将asciidoc文档转换成pdf的插件,由Asciidoctor组织开发维护,托管在 link:https://github.com/asciidoctor/asciidoctor-pdf[GitHub] 上,本文将简单介绍下这个插件的使用,部分内容来源于官方。
== 安装
.使用gem安装
....
$ gem install asciidoctor-pdf
....
.语法高亮支持
Rouge (preferred, minimum version: 2.0.0)
....
$ gem install rouge
....
Pygments
....
$ gem install pygments.rb
....
CodeRay
....
$ gem install coderay
....
启用语法高亮,只需要在.adoc文档头部填写如下内容即可:
....
:source-highlighter: rouge
....
== 使用
基本命令,转换asciidoc成为pdf
....
$ asciidoctor-pdf basic-example.adoc
$ # 这两个命令是等效的,只不过上边的命令更加简洁
$ asciidoctor -r asciidoctor-pdf -b pdf basic-example.adoc
....
这里需要说明一下,如果文档中包含中文,初次转换的时候会出现乱码的问题。解决方式请看 link:id_中文乱码问题[中文乱码问题] 章节。
== 我是占位符
后续新增内容区间
== 问题
=== 中文乱码问题
如果文档中包含中文,初次转换的时候会出现乱码的问题。这里简单介绍下asciidoctor-pdf的默认主题。如果查阅了asciidoctor-pdf的帮助文档,就会知道他支持自定义主题的。中文乱码的原因也是由于默认主题中使用了非中文字体导致的,需要添加中文字体。这里有两种解决方式可供选择:
- 创建项目/用户主题
项目和用户的创建方式一样,不同的是二者存储的位置不一样,用户的存储在一个固定文件夹,比如~/.config/adoc, 只要使用命令生成的时候填写了正确的路径即可。
====
- 在adoc所在文件下新建 icon:folder[] fonts文件夹,将中文字体复制到 icon:folder[] fonts文件夹中
- 复制asciidoctor-pdf安装目录中的 icon:file[]
data/themes/default-theme.yml到当前目录,或者新建一个 icon:file[] theme.yml - 编辑修改
default-theme.yml内容,主要节点:
....
font:
catalog:
song: # 宋体,请保证fonts文件中包含如下字体
normal: STSONG.TTF
bold: STSONG.TTF
italic: STSONG.TTF
bold_italic: STSONG.TTF
base:
# 设置字体
font_family: song
literal:
font_family: song
.... 生成pdf
....
$ asciidoctor-pdf -a pdf-style=default-theme.yml -a pdf-fontsdir=fonts test.adoc
....
====默认主题
查看icon:file[]../bin/asciidoctor-pdf源码,看到他实际使用的是 icon:file[] ../../lib/asciidoctor/pdf.rb,我们再查看下这个ruby文件,发现这个又重新定位到 icon:folder[] ../asciidoctor-pdf文件夹,即icon:folder[] ../lib/asciidoctor-pdf,其中包含了 icon:file[] theme_loader.rb,继续查看这个文件,阅读源码之后,发现默认会先加载主题 icon:file[] data\themes\base-theme.yml,如果这个不存在会加载data\themes\default-theme.yml,也就是说base-theme.yml的优先级比default-theme.yml高,我们需要更改base-theme.yml内容。主要修改内容同 ##创建项目/用户主题## 章节是一样的。修改完成之后,此后只需要执行:
....
$ asciidoctor-pdf test.adoc
....
或者我们可以修改default-theme.yml,或者创建自己的主题文件,此后生成需要指明主题文件:
....
$ asciidoctor-pdf -a pdf-style=default-theme.yml test.adoc
....
如果以上两种解决方法不合你心意,那你可以参考下 link:https://github.com/chloerei/asciidoctor-pdf-cjk-kai_gen_gothic[asciidoctor-pdf-cjk-kai_gen_gothic] 这个项目,这是一个asciidoc-pdf的主题项目,主要用于支持CJK footnote:[中日韩统一表意文字(CJK Unified Ideographs)] ,支持中文简体、繁体、韩语、日语等。
Asciidoctor-pdf生成pdf文件的更多相关文章
- 【PDF】java使用Itext生成pdf文档--详解
[API接口] 一.Itext简介 API地址:javadoc/index.html:如 D:/MyJAR/原JAR包/PDF/itext-5.5.3/itextpdf-5.5.3-javadoc/ ...
- Vue 生成PDF并下载
实现原理 该功能原理是将页面转化伟canvas在把canvas转化为base64数据 最后将数据通过pdf.js生成下载,故需要和html2canvas一起使用 友情提醒这个pdf下载不能在app里直 ...
- 实践指南-网页生成PDF
一.背景 开发工作中,需要实现网页生成 PDF 的功能,生成的 PDF 需上传至服务端,将 PDF 地址作为参数请求外部接口,这个转换过程及转换后的 PDF 不需要在前端展示给用户. 二.技术选型 该 ...
- Javascript 将 HTML 页面生成 PDF 并下载
最近碰到个需求,需要把当前页面生成 pdf,并下载.弄了几天,自己整理整理,记录下来,我觉得应该会有人需要 :) html2canvas 简介 我们可以直接在浏览器端使用html2canvas,对整个 ...
- js将 HTML 页面生成 PDF 并下载
最近碰到个需求,需要把当前页面生成 pdf,并下载.弄了几天,自己整理整理,记录下来,我觉得应该会有人需要 :) 先来科普两个插件: html2Canvas 简介 我们可以直接在浏览器端使用html2 ...
- linux下编译bib、tex生成pdf文件
实验: 在linux环境下,编译(英文)*.bib和*.tex文件,生成pdf文件. 环境: fedora 20(uname -a : Linux localhost.localdomain 3.19 ...
- 【Java】使用iText生成PDF文件
iText介绍 iText是著名的开放源码的站点sourceforge一个项目,是用于生成PDF文档的一个java类库.通过iText不仅可以生成PDF或rtf的文档,而且可以将XML.Html文件转 ...
- ThinkPHP3.2.3扩展之生成PDF文件(MPDF)
目前是PHP生成PDF文件最好的插件了,今天介绍下在ThinkPHP3.2.3里如何使用. 先安照路径放好如图. 下面是使用方法 public function pdf(){ //引入类库 Vendo ...
- [轉載]史上最强php生成pdf文件,html转pdf文件方法
之前有个客户需要把一些html页面生成pdf文件,然后我就找一些用php把html页面围成pdf文件的类.方法是可谓是找了很多很多,什么html2pdf,pdflib,FPDF这些都试过了,但是都没有 ...
随机推荐
- 深入SpringMVC注解
原文链接:https://blog.csdn.net/chenpeng19910926/article/details/70837756 @Controller 在SpringMVC 中提供了一个非常 ...
- 3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降. ...
- jdk和dubbo的SPI机制
前言:开闭原则一直是软件开发领域中所追求的,开闭原则中的"开"是指对于组件功能的扩展是开放的,是允许对其进行功能扩展的,“闭”,是指对于原有代码的修改是封闭的,即不应该修改原有的代 ...
- webpack--运行npm run dev自动打开浏览器运行首页的两种方式以及热加载
作为开发人员,我们在修改了代码之后,在vscode终端运行npm run dev指令后,希望它可以自动打开浏览器方便我们调试,有两种方式可以实现: 自动打开浏览器的两种方式: 方式一: 1.webpa ...
- OpenCV3入门1—环境搭建与实验
1.环境搭建 1.1 VS2017开发环境搭建 1).下载软件包 https://opencv.org/ 2).配置环境变量 配置win10系统环境变量,把下面路径添加到path. D:\WORK\5 ...
- 如何提取CSDN博客正文内容
document.getElementById("article_content").outerHTML; 在任意的一片博文运行以上代码都可以获得正文内容,但是对于代码.字体都没有 ...
- Codeforces_731_A
http://codeforces.com/problemset/problem/731/A 每次操作总共4种情况,判断一下就好了. #include<iostream> #include ...
- JDK11和JDK8类加载器的区别
如下代码: public class Test07 { public static void main(String[] args) throws ClassNotFoundException { / ...
- 开源APM系统 HttpReports 在 .Net Core的应用
前言 简单说明下,APM全称Application Performance Management应用性能管理,通过各种收集请求数据,同时搭配Dashboard以实现对应用程序性能管理和故障管理的系统化 ...
- postman之存储测试结果
前言 在Jmeter的随笔中,我跟大家讲过利用Jmeter工具存储测试结果,那么,postman工具要该如何存储测试结果呢?下面一起来学习吧! 一:添加一个登录请求,填入接口参数点击send 二:点击 ...