Загрузка файла HtmlAgilityPack

c# html-agility-pack

Вопрос

У меня проблема, когда я пытаюсь загрузить файл из файловой системы. Проблема в том, что в значении некоторого управления HTML у меня меньше знака «<» внутри значения span

HtmlDocument doc = new HtmlDocument();
doc.OptionReadEncoding = true;

//StreamReader str = new StreamReader(fileName, Encoding.UTF8);
StreamReader str = new StreamReader(@"E:\HTMLS\OEL\1030,1.html",Encoding.UTF8,true);

doc.Load(str.BaseStream, Encoding.ASCII);
//string streamString = str.ReadToEnd().
str.Close();
//all nodes

doc.DocumentNode.Descendants().Where(x => x.Name == "#text" && (x.InnerText == "\r\n\t" || x.InnerText == "\r\n" || x.InnerText == "\r\n\t\t")).ToList().ForEach(x => x.Remove());
List<HtmlNode> listHtmlNode = doc.DocumentNode.Descendants("table").ToList();

Популярные ответы

У вас не должно быть таких символов, как < как содержимое в вашем HTML. Наличие их в html делает html недействительным и приведет к неправильной работе пакета HTMLAgility.

Если они вам нужны в html, вам нужно их закодировать. < становится %lt; см. здесь http://www.w3schools.com/html/html_entities.asp



Related

Лицензировано согласно: CC-BY-SA with attribution
Не связан с Stack Overflow
Лицензировано согласно: CC-BY-SA with attribution
Не связан с Stack Overflow