Come sommare il valore decimale da una colonna in una tabella in un file html per C #

c# html-agility-pack html-parsing linq

Domanda

Questo codice intende sommare una colonna di valori decimali ma genera un'eccezione nella int.Parse() . Si prega di vedere vicino alla fine di questo post per come ho provato a rivedere il codice per correggere questo e l'errore che ho ricevuto con quel tentativo.

    static void Main()
    {
        String htmlFile = "C:/Temp/Test11.html";

        HtmlDocument doc = new HtmlDocument();
        doc.Load(htmlFile);

    // Site Collection Storage Used (GB)
    var sum = doc.DocumentNode.SelectSingleNode("//table")
        // The sum will be of the row elements
        .Elements("tr")
        // Skip this many rows from the top
        .Skip(1)
        // .ElementAt(2) = third column
        // .Last() = last column
        .Sum(tr => int.Parse(tr.Elements("td").ElementAt(3).InnerText)); 
    Console.WriteLine("Site Collection Storage Used (GB): " + sum);
        Console.ReadLine();
    }

Ecco l'eccezione:

    static void Main()
    {
        String htmlFile = "C:/Temp/Test11.html";

        HtmlDocument doc = new HtmlDocument();
        doc.Load(htmlFile);

    // Site Collection Storage Used (GB)
    var sum = doc.DocumentNode.SelectSingleNode("//table")
        // The sum will be of the row elements
        .Elements("tr")
        // Skip this many rows from the top
        .Skip(1)
        // .ElementAt(2) = third column
        // .Last() = last column
        .Sum(tr => int.Parse(tr.Elements("td").ElementAt(3).InnerText)); 
    Console.WriteLine("Site Collection Storage Used (GB): " + sum);
        Console.ReadLine();
    }

Ho provato a sostituire int.Parse () con Decimal.Parse () ma mi dice:

    static void Main()
    {
        String htmlFile = "C:/Temp/Test11.html";

        HtmlDocument doc = new HtmlDocument();
        doc.Load(htmlFile);

    // Site Collection Storage Used (GB)
    var sum = doc.DocumentNode.SelectSingleNode("//table")
        // The sum will be of the row elements
        .Elements("tr")
        // Skip this many rows from the top
        .Skip(1)
        // .ElementAt(2) = third column
        // .Last() = last column
        .Sum(tr => int.Parse(tr.Elements("td").ElementAt(3).InnerText)); 
    Console.WriteLine("Site Collection Storage Used (GB): " + sum);
        Console.ReadLine();
    }

Dopo aver cambiato int.Parse() in Decimal.Parse() non vedo dove c'è un int da convertire.

Per favore aiutami con questo codice per raggiungere il mio obiettivo.

Ecco il file html per riferimento:

    static void Main()
    {
        String htmlFile = "C:/Temp/Test11.html";

        HtmlDocument doc = new HtmlDocument();
        doc.Load(htmlFile);

    // Site Collection Storage Used (GB)
    var sum = doc.DocumentNode.SelectSingleNode("//table")
        // The sum will be of the row elements
        .Elements("tr")
        // Skip this many rows from the top
        .Skip(1)
        // .ElementAt(2) = third column
        // .Last() = last column
        .Sum(tr => int.Parse(tr.Elements("td").ElementAt(3).InnerText)); 
    Console.WriteLine("Site Collection Storage Used (GB): " + sum);
        Console.ReadLine();
    }

Risposta accettata

La conversione è quasi certamente al di fuori dell'istruzione LINQ: se sum è un int, è qui che sarebbe necessario un cast esplicito. Dichiarare la somma come decimale o inserire un cast esplicito risolverebbe il problema:

    // Site Collection Storage Used (GB)
    sum = (int)doc.DocumentNode.SelectSingleNode("//table")
        // The sum will be of the row elements
        .Elements("tr")
        // Skip this many rows from the top
        .Skip(1)
        // .ElementAt(2) = third column
        // .Last() = last column
        .Sum(tr => decimal.Parse(tr.Elements("td").ElementAt(3).InnerText)); 
    Console.WriteLine("Site Collection Storage Used (GB): " + sum);

Ecco un link a una demo rapida su ideone (non è possibile utilizzare il pacchetto agility HTML su ideone, quindi ho copiato i tuoi dati in una serie di stringhe).




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é