我在使用正则表达式准备字符串时遇到问题。我写了这个函数:
private String parseAnswer(String res)
{
String[] pattern = new String[16] { "<head[^>]*?>.*?</head>", "<style[^>]*?>.*?</style>", "<script[^>]*?.*?</script>", "<object[^>]*?.*?</object>", "<embed[^>]*?.*?</embed>", "<applet[^>]*?.*?</applet>", "<noframes[^>]*?.*?</noframes>", "<noscript[^>]*?.*?</noscript>", "<noembed[^>]*?.*?</noembed>", "</?((address)|(blockquote)|(center)|(del))", "</?((div)|(h[1-9])|(ins)|(isindex)|(p)|(pre))", "</?((dir)|(dl)|(dt)|(dd)|(li)|(menu)|(ol)|(ul))", "</?((table)|(th)|(td)|(caption))", "</?((form)|(button)|(fieldset)|(legend)|(input))", "</?((label)|(select)|(optgroup)|(option)|(textarea))", "</?((frameset)|(frame)|(iframe))" };
String[] replacement = new String[16] { " ", " ", " ", " ", " ", " ", " ", " ", " ", "\n$0", "\n$0", "\n$0", "\n$0", "\n$0", "\n$0", "\n$0" };
for (int i = 0; i < pattern.Length; i++)
{
res = Regex.Replace(res, pattern[i], replacement[i]);
}
return res;
}
此函数获取 HTML 代码作为输入。我想清除一些 HTML 标签。为此,我准备了一系列模式。但似乎我的函数没有清除 HTML 代码。我的模式是我要删除的 HTML 标记列表。一些我没有删除但只添加\n的标签。
你能帮我解决这个正则表达式吗?或者给我任何图书馆来完成它的任务?我的目标是删除 HTML 标签以仅接收要解析的网站文本。
编辑:好的,我可以使用 HTMLAgilityPack,但我有几个问题: htmlDoc.LoadHtml(URL); - 我需要将结果转换为 UTF8 -> HTMLAgilityPack 有任何转换功能吗?其次,通常我想将 InnerText 的结果放入 Json 并将其发送到 Javascript。如何删除 Javascript 中禁止的字符?