我有这种将富文本解析为 HTML 的方法。我注意到它在某些地方组成了这样的内联样式:
<DIV STYLE="text-align:Left;font-family:Segoe UI;font-style:normal;font-weight:normal;font-size:12;color:#000000;">
请注意,字体大小最后缺少“pt”,这在我导出为 pdf 时会破坏报告。
这是我处理它的代码:
public static string RtfToHtml(string rtfText)
{
if (String.IsNullOrEmpty(rtfText)) return rtfText;
if (!rtfText.Contains(@"{\rtf1")) return rtfText.Replace("\r\n", "<br>").Replace("\r", "<br>");
Converter converter = new Converter();
StringBuilder sb = new StringBuilder(converter.ConvertRtfToHtml(rtfText));
sb.Replace("font-size:12;", "font-size:12pt;");
try
{
HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(sb.ToString());
RemoveStyleTags(doc, "ol");
RemoveStyleTags(doc, "ul");
RemoveStyleTags(doc, "li");
return doc.DocumentNode.InnerHtml;
}
catch { }
return sb.ToString();
}
我的问题是:有没有更优雅的方式来执行 .Replace() 方法,而不是这样做:
sb.Replace("font-size:12;", "font-size:12pt;");
sb.Replace("font-size:13;", "font-size:13pt;");
sb.Replace("font-size:14;", "font-size:14pt;");
...
sb.Replace("font-size:10000;", "font-size:10000pt;");
显然,我要做的是找到所有输入错误的字体大小声明,附加 pt,同时保持它们已经拥有的整数大小。