构建将网页上的html表格转换为变量的函数的最佳方法是什么。
我希望能够传递一些唯一标识符(如表ID或其他内容),它会将所有数据返回到DataTable之类的内容。
答案 0 :(得分:5)
您可以使用HtmlAgilityPack来解析HTML并提取表格数据。
HAP现在支持Linq你可以从这样开始:
HtmlDocument doc = ...
var myTable = doc.DocumentNode
.Descendants("table")
.Where(t =>t.Attributes["id"].Value == someTableId)
.FirstOrDefault();
if(myTable != null)
{
///further parsing here
}
答案 1 :(得分:0)
string htmlCode = "";
htmlCode = driver.PageSource.ToString();
HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(htmlCode);
var gvTender = doc.DocumentNode.Descendants("table")
.Where(table => table.Attributes.Contains("id"))
.FirstOrDefault(table => table.Attributes["id"].Value == "ctl00_cphContentArea_gvTenders");
List<HtmlNode> rows = doc.DocumentNode.SelectNodes("//tr").Skip(10).ToList();
foreach (var row in rows)
{
try
{
rowCount++;
if (rowCount >= 16)
break;
List<HtmlNode> cells = row.SelectNodes("th|td").ToList();
string s1 = cells[0].InnerText.ToString().Replace("\r\n", "").Trim();
string s2 = cells[1].InnerText.ToString().Replace("\r\n", "").Trim();
string s3 = cells[2].InnerText.ToString();
string s4 = cells[3].InnerText.ToString();
string s5 = cells[4].InnerText.ToString();
string s6 = cells[5].InnerText.ToString();
string s7 = cells[6].InnerText.ToString();
string s8 = cells[7].InnerText.ToString();
}
catch (Exception ex)
{
}
}
//Developed By -Ramdas Chavan(Datamatics)