2017-02-03 97 views
1

此代码的工作的Html敏捷包,的SelectSingleNode

 WebClient client = new WebClient(); 
     client.Encoding = Encoding.UTF8; 
     html = client.DownloadString("http://www.imdb.com/chart/moviemeter?ref_=nv_mv_mpm_8"); 
     HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument(); 
     doc.LoadHtml(html); 
     MessageBox.Show(doc.DocumentNode.SelectSingleNode("//*[@id='main']/div/span/div/div/div[3]/table/tbody/tr[1]/td[2]/a").InnerText); 

的Html代码在这里:

<a href="/title/tt4972582/?pf_rd_m=A2FGELUUNOQJNL&amp;pf_rd_p=2240084082&amp;pf_rd_r=1QW31NGD6JSE46F79CKQ&amp;pf_rd_s=center-1&amp;pf_rd_t=15506&amp;pf_rd_i=moviemeter&amp;ref_=chtmvm_tt_1" title="M. Night Shyamalan (dir.), James McAvoy, Anya Taylor-Joy">Split</a> 

MessageBox中显示,这是 “拆分” 的文字。但是看看这个HTML代码:

<div class="summary_text" itemprop="description"> 
       Three girls are kidnapped by a man with a diagnosed 23 distinct personalities, and must try and escape before the apparent emergence of a frightful new 24th. 
     </div> 

我想MessageBox中显示哪些开头的文字“三个女孩是kidn ......”所以我写了这个代码:

 WebClient client2 = new WebClient(); 
     client2.Encoding = Encoding.UTF8; 
     HtmlAgilityPack.HtmlDocument doc2 = new HtmlAgilityPack.HtmlDocument(); 
     doc2.LoadHtml(client2.DownloadString("http://www.imdb.com/title/tt4972582/?pf_rd_m=A2FGELUUNOQJNL&pf_rd_p=2240084082&pf_rd_r=1QW31NGD6JSE46F79CKQ&pf_rd_s=center-1&pf_rd_t=15506&pf_rd_i=moviemeter&ref_=chtmvm_tt_1")); 
     MessageBox.Show(doc2.DocumentNode.SelectSingleNode("//*[@id='title - overview - widget']/div[3]/div[1]/div[1]").InnerText); 

当我开始这个代码,发生类型为“System.NullReferenceException”的未处理的异常

Xpaths是真的,我已经检查了一百次,所以我该怎么办?

+0

为什么你不使用特定的xpath而不是通过另一个?由于该xpath至少在此刻与您想要的元素不匹配。说明不在该div内。 –

+0

我怎样才能达到这个描述?你可以帮我吗? – Onur

回答

1

你可以试试吗?

 HtmlWeb web = new HtmlWeb(); 
     HtmlDocument doc = web.Load("http://www.imdb.com/title/tt4972582/?pf_rd_m=A2FGELUUNOQJNL&pf_rd_p=2240084082&pf_rd_r=1QW31NGD6JSE46F79CKQ&pf_rd_s=center-1&pf_rd_t=15506&pf_rd_i=moviemeter&ref_=chtmvm_tt_1"); 
     var desNodeText = doc.DocumentNode.Descendants("div").FirstOrDefault(o => o.GetAttributeValue("class", "") == "summary_text").InnerText; 
+0

或xpath:'// div [@ class ='summary_text']' –

+0

Works非常感谢.. – Onur