selenium-旧元素参考:该元素未附加到页面
我试图了解为什么在尝试显示从网站上获取的项目时会出现错误。我也在浏览器中使用google chrome。
chromeDriver.Navigate().GoToUrl("somewebsites");chromeDriver.FindElement(By.Id("something.link.text")).Click();
chromeDriver.Manage().Timeouts().ImplicitlyWait(TimeSpan.FromSeconds(5));
还有我代码的其他部分
var item = chromeDriver.FindElementsByXPath("//*[starts-with(@id,\"g_1_\")]/td[3]/span");foreach (var value in item)
{
Console.WriteLine(value.Text);
}
每当我使用“
,它给出一个错误。我无法显示提取的数据。
在错误消息中,它说“
”。我检查了其他帖子,但没有弄清楚。我该如何解决?
据我了解,selenium的响应速度比网站开放时间快得多,因此它会产生错误。同样,它很少给出selenium无法定位的元素。有什么建议吗?
编辑:如果我从显示功能中删除“ ”,它将显示“
”。字符串有问题吗?
EDIT2:我可以像这样保存从网站获取的数据:
为此,我编写了以下内容:
string[] test= new string[100];for (int i = 0; i < 100; i++)
{
kaan[i] = driver.FindElements(By.XPath("//*[starts-with(@id,\"g_1_\")]/td[3]/span")).ToString();
}
如何转换成文字
回答:
我没有在c#中工作,但是在java / selenium中工作。但是,我可以为您提供克服陈旧的想法。
通常,如果在启动Webelement后更改了元素属性或某些内容,则将获得Stale
Exception。例如,在某些情况下,如果用户尝试在同一页面上单击同一元素,但在页面刷新后单击,则会获得跟踪例外。
为了克服这个问题,如果页面被更改或刷新,我们可以创建新的Web元素。下面的代码可以给您一些想法(它在Java中,但是概念是相同的)
例:
webElement element = driver.findElement(by.xpath("//*[@id='StackOverflow']")); element.click();
//page is refreshed
element.click();//This will obviously throw stale exception
为了克服这个问题,我们可以将xpath存储在某个字符串中,并在使用时使用它创建一个新的webelement。
String xpath = "//*[@id='StackOverflow']";driver.findElement(by.xpath(xpath)).click();
//page has been refreshed. Now create a new element and work on it
driver.fineElement(by.xpath(xpath)).click(); //This works
在这种情况下,我们将收集一组网络元素并进行迭代以获取文本。但是,在收集Web元素后,Web元素似乎发生了一些变化,并且gettext引发了陈旧。我们可以使用循环并在旅途中创建元素并获取文本。
for(int i = 0; i<5; i++){
String value = driver.findElement(by.xpath("//.....["+i+"]")).getText);
System.out.println(value);
}
希望这对您有所帮助。谢谢。
以上是 selenium-旧元素参考:该元素未附加到页面 的全部内容, 来源链接: utcz.com/qa/420428.html