Hinzufügen von HTML-Tabelle zu Datagridview mit HTML Agility-Paket

c# datagridview html html-agility-pack parsing

Frage

Ich schreibe eine einfache App zum Parsen von HTML-Tabelle zu Datagridview mit Hilfe von HTML Agility Pack. aber wenn ich den Code starte, bekomme ich einen Fehler "Diese Zeile gehört schon zu dieser Tabelle"

Ich muss einfache HTML-Tabelle wie unten analysieren

<html>
<head>
</head>
<body>
<table>
  <tr>
    <td>Alfreds Futterkiste</td>
    <td>Maria Anders</td>
    <td>Germany</td>
  </tr>
   <tr>
    <td>Alfreds Futterkiste</td>
    <td>Maria Anders</td>
    <td>Germany</td>
  </tr>
</table>
</body>
</html>

Das ist mein Code

private void button1_Click(object sender, EventArgs e)
    {
        var htmlCode = richTextBox1.Text.Trim();
        var doc = new HtmlDocument();
        doc.LoadHtml(htmlCode);

        dt = new DataTable();
        dt.Columns.Add("Company", typeof (string));
        dt.Columns.Add("Contact", typeof (string));
        dt.Columns.Add("Country", typeof (string));

        var count = 0;


        foreach (var table in doc.DocumentNode.SelectNodes("//table"))
        {
            foreach (var row in table.SelectNodes("//tr"))
            {
                var dr = dt.NewRow();

                var i = 0;
                foreach (var cell in row.SelectNodes("//td"))
                {


                    dr["Company"] = cell.InnerText.Replace("&nbsp;", "");
                    dr["Contact"] = cell.InnerText.Replace("&nbsp;", "");
                    dr["Country"] = cell.InnerText.Replace("&nbsp;", "");

                }


                dt.Rows.Add(dr);
            }


            grid.DataSource = dt;
        }
    }

Ich brauche eine einfache Ausgabe auf Datagridview wie folgt

Bildbeschreibung hier eingeben

Wie kann ich dies mit dem HTML Agility-Paket tun?

Akzeptierte Antwort

Verschieben Sie die folgende Zeile

dt.Rows.Add(dr);

außerhalb der foreach-Schleife über die Tabellenzellen. Sie versuchen, dieselbe Zeile mehrfach zu der DataTable hinzuzufügen.

int i = 0;
foreach (var cell in row.SelectNodes("//td"))
{
    dr[i++] = cell.InnerText;
}
dt.Rows.Add(dr);


Related

Lizenziert unter: CC-BY-SA with attribution
Nicht verbunden mit Stack Overflow
Lizenziert unter: CC-BY-SA with attribution
Nicht verbunden mit Stack Overflow