С#: HtmlAgilityPack извлекает внутренний текст
Я использую HtmlAgilityPack. Есть ли один код строки, который я могу получить во внутреннем тексте html, например, удалить все теги html и скрипты?
Ответы
Ответ 1
Вот так:
document.DocumentNode.InnerText
Обратите внимание, что это вернет текстовое содержимое тегов <script>
.
Чтобы исправить это, вы можете удалить все теги <script>
, например:
foreach(var script in doc.DocumentNode.Descendants("script").ToArray())
script.Remove();
foreach(var style in doc.DocumentNode.Descendants("style").ToArray())
style.Remove();
Ответ 2
Я написал простой метод. Это может вам помочь. Этот метод может извлекать все теги node. Затем вы можете использовать HtmlNodeCollection[i].InnerText
, чтобы получить его текст.
HtmlDocument hDoc;
HtmlNodeCollection nodeCollection;
public void InitInstance(string htmlCode) {
hDoc.LoadHtml(htmlCode);
nodeCollection = new HtmlNodeCollection();
}
private void GetAllNodesInnerTextByTagName(HtmlNode node, string tagName) {
if (null == node.ChildNodes) {
return ;
} else {
HtmlNodeCollection nCollection = node.SelectNodes( tagName );
if( null != nCollection ) {
for( int i=0; i<nCollection.Count; i++) {
nodeCollection.Add( nCollection[i]);
nCollection[i].Remove();
}
}
nCollection=node.ChildNodes;
if(null != nCollection) {
for(int i=0;i<nCollection.Count; i++) {
GetAllNodesInnerTextByTagName( nCollection[i] , tagName );
}
}
}