Selectnode del pacchetto agilità HTML restituisce null

c# html-agility-pack html-parsing

Domanda

Sto lavorando al dispositivo Windows Phone 8 e provo ad analizzare il documento html con il pacchetto agility html da http://www.livescience.com/41480-3d-printed-kidneys-take-small-steps.html Posso ottenere il <title> tag facilmente, ma ora voglio ottenere tutti i tag <p> da quel documento. Ho provato queste due soluzioni uno e due, ma non funziona. Questo è il mio codice effettivo basato su quelle soluzioni

private void loadDoc()
    {
        try
        {
            HtmlWeb.LoadAsync("http://www.livescience.com/41480-3d-printed-kidneys-take-small-steps.html", Html_Completed);
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.ToString());
        }
    }

    private void Html_Completed(object sender, HtmlDocumentLoadCompleted e)
    {
        doc = e.Document;
        title = doc.DocumentNode.SelectSingleNode("//title");
        p = doc.DocumentNode.SelectNodes("//p");
        foreach(var node in p)
        {
          pr = node.InnerText; //that's the text you are looking for
        }
        text1.Text = title.InnerText;
        if (!pr.Equals("") && pr != "")
        {
            text2.Text = pr;
        }
        else
        {
            MessageBox.Show("null");
        }
    }

Io uso if blocco per determinare se il foreach restituisce null. Qualcuno sa come risolvere questo problema? Apprezzerò qualsiasi aiuto. Grazie.

Risposta popolare

Prova a fare:

p = doc.DocumentNode.SelectNodes(".//p");

invece di:

p = doc.DocumentNode.SelectNodes(".//p");

poiché p è un tipo di tag, non una classe o un id.




Autorizzato sotto: CC-BY-SA with attribution
Non affiliato con Stack Overflow
È legale questo KB? Sì, impara il perché
Autorizzato sotto: CC-BY-SA with attribution
Non affiliato con Stack Overflow
È legale questo KB? Sì, impara il perché