我正在使用 wkhtmltopdf 将 html 转换为 pdf。问题是带有 č、š、ž、đ 等字符的字体(这些是塞尔维亚语、克罗地亚语、斯洛文尼亚语使用的字符)。它们不会以 pdf 格式显示。Html 正确呈现。
这就是我的 html 的构造方式:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<title>Export</title>
</head>
<body>
<h3>č,š,ž,đ</h3>
</body>
</html>
在我使用 wkhtmptopdf 的 C# 代码中,我这样做了
Process p;
ProcessStartInfo psi = new ProcessStartInfo();
psi.FileName = HtmlToPdfExePath;
psi.WorkingDirectory = Path.GetDirectoryName(psi.FileName);
// run the conversion utility
psi.UseShellExecute = false;
psi.CreateNoWindow = true;
psi.RedirectStandardInput = true;
psi.RedirectStandardOutput = true;
psi.RedirectStandardError = true;
// note: that we tell wkhtmltopdf to be quiet and not run scripts
string args = "-q -n ";
args += "--disable-smart-shrinking ";
args += "--orientation Portrait ";
args += "--outline-depth 0 ";
args += "--page-size A4 ";
args += "--encoding utf-8";
args += " - -";
psi.Arguments = args;
p = Process.Start(psi);
如您所见,我在 html 和 wkhtmltopdf 上使用 utf-8 编码作为参数,但字符不能正确呈现。我错过了什么?以下是我在 pdf 中得到的内容。英文字符呈现正常。