使用HTML Agility pack将HTML表添加到datagridview

时间:2017-02-26 17:43:08

标签: c# html parsing datagridview html-agility-pack

我编写了一个简单的应用程序,用于在HTML Agility包的帮助下将HTML表解析为datagridview。但是当我运行代码时,它会给我一个错误“这行已经属于这个表”

我需要解析简单的HTML表格,如下所示

<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>

这是我的代码

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;
        }
    }

我需要像datagridview这样的简单输出

enter image description here

如何使用HTML Agility pack执行此操作?

1 个答案:

答案 0 :(得分:2)

移动以下行

dt.Rows.Add(dr);

在foreach循环之外的表格单元格上方。您尝试多次向DataTable添加同一行。

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