加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

将数据从HTML表导入到C#中的DataTable

发布时间:2020-12-14 19:43:54 所属栏目:资源 来源:网络整理
导读:我想从 HTML表中导入一些数据(这里是一个链接 http://road2paris.com/wp-content/themes/roadtoparis/api/generated_table_august.html),并在我的表单应用程序中显示DataGridView中的前16个人.从我读到的最好的方法是使用HTML Agility包,所以我下载并包含在
我想从 HTML表中导入一些数据(这里是一个链接 http://road2paris.com/wp-content/themes/roadtoparis/api/generated_table_august.html),并在我的表单应用程序中显示DataGridView中的前16个人.从我读到的最好的方法是使用HTML Agility包,所以我下载并包含在我的项目中.我知道首先要做的是加载html文件的内容.这是我过去常用的代码:
string htmlCode = "";
        using (WebClient client = new WebClient())
        {
            client.Headers.Add(HttpRequestHeader.UserAgent,"AvoidError");
            htmlCode = client.DownloadString("http://road2paris.com/wp-content/themes/roadtoparis/api/generated_table_august.html");
        }
        HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument();

        doc.LoadHtml(htmlCode);

然后我卡住了.我不知道如何使用html表中的数据填充我的数据表.我尝试了很多不同的解决方案,但似乎没有什么工作正常.如果有人能帮助我,我会很高兴的.

解决方法

HtmlDocument doc = new HtmlDocument();
doc.LoadHtml(htmlCode);
var headers = doc.DocumentNode.SelectNodes("//tr/th");
DataTable table = new DataTable();
foreach (HtmlNode header in headers)
    table.Columns.Add(header.InnerText); // create columns from th
// select rows with td elements 
foreach (var row in doc.DocumentNode.SelectNodes("//tr[td]")) 
    table.Rows.Add(row.SelectNodes("td").Select(td => td.InnerText).ToArray());

您需要HTML Agility Pack库才能使用此代码.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读