C# 从WebBrowserControl中单击的HtmleElement获取XPath
如何从WebBrowserControl中单击的HtmleElement获取XPath 以下是检索单击的HtmlElement的方式:C# 从WebBrowserControl中单击的HtmleElement获取XPath,c#,xpath,webbrowser-control,C#,Xpath,Webbrowser Control,如何从WebBrowserControl中单击的HtmleElement获取XPath 以下是检索单击的HtmlElement的方式: System.Windows.Forms.HtmlDocument document = this.webBrowser1.Document; document.MouseUp += new HtmlElementEventHandler(this.htmlDocument_Click); private void htmlDocument_Click(obj
System.Windows.Forms.HtmlDocument document = this.webBrowser1.Document;
document.MouseUp += new HtmlElementEventHandler(this.htmlDocument_Click);
private void htmlDocument_Click(object sender, HtmlElementEventArgs e)
{
HtmlElement element = this.webBrowser1.Document.GetElementFromPoint(e.ClientMousePosition);
}
我想单击网站上的特定元素(价格、文章编号、描述等),并获取它们的XPath表达式
谢谢大家! XPath表达式不是HTML的标准特性(与XML不同)。如果您希望获得稍后可用于的元素XPath,则至少有两个选项:
HtmlElement element = this.webBrowser1.Document.GetElementFromPoint(e.ClientMousePosition);
var savedId = element.Id;
var uniqueId = Guid.NewGuid().ToString();
element.Id = uniqueId;
var doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(element.Document.GetElementsByTagName("html")[0].OuterHtml);
element.Id = savedId;
var node = doc.GetElementbyId(uniqueId);
var xpath = node.XPath;