Pandoc,以及扩展名R Markdown,仅保留链接的原始HTML。原始HTML块输出为支持HTML的格式(如epub),但不输出为LaTeX(用于生成PDF)。 Pandoc只会解析链接的内容,这就是如果您的链接文本是URL则它似乎起作用的原因。
最简单的解决方案当然是对链接使用Markdown语法,它与HTML:[Cygwin](https://www.cygwin.com){target="_blank"}一样具有表现力。但是,如果这不是一个选择,那么事情会变得有些棘手。
这里是一种仍然解析那些链接的方法。它使用Lua filter将原始HTML转换为正确的链接。将以下脚本parse-html-links.lua安全地保存到Rmd文件所在的目录中,然后将'--lua-filter=parse-html-links.lua'添加到pandoc_args的列表中。
local elements_in_link = {}
local link_start
local link_end
Inline = function (el)
if el.t == 'RawInline' and el.format:match'html.*' then
if el.text:match'
link_start = el.text
return {}
end
if el.text:match'
link_end = el.text
local link = pandoc.read(link_start .. link_end, 'html').blocks[1].content[1]
link.content = elements_in_link
-- reset
elements_in_link, link_start, link_end = {}, nil, nil
return link
end
end
-- collect link content
if link_start then
table.insert(elements_in_link, el)
return {}
end
-- keep original element
return nil
end