[英]Speed up selenium webdriver?
我正在使用Selenium Webdriver自动执行网页使用。 不允许使用无头浏览器。
Selenium在完全加载的单个页面上查找多个元素似乎相当慢。
有没有人有任何技巧来加快速度? 我通常通过xpath搜索对象。
我已经搜索过Google并阅读过类似的帖子 。 我正在寻找新想法
在这种情况下,我想使用页面源创建一个org.w3c.dom文档,然后使用javax.xml库解析它:
public static Document getWebpageDocument_fromSource(String source) throws InterruptedException, IOException {
try {
HtmlCleaner cleaner = new HtmlCleaner();
CleanerProperties props = cleaner.getProperties();
props.setAllowHtmlInsideAttributes(true);
props.setAllowMultiWordAttributes(true);
props.setRecognizeUnicodeChars(true);
props.setOmitComments(true);
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = null;
try {
builder = builderFactory.newDocumentBuilder();
} catch (ParserConfigurationException e) {
e.printStackTrace();
}
TagNode tagNode = new HtmlCleaner().clean(source);
Document doc = new DomSerializer(new CleanerProperties()).createDOM(tagNode);
return doc;
} catch (ParserConfigurationException ex) {
ex.printStackTrace();
return null;
}
}
然后像这样通过xpath访问元素:
String myXpathStr = "//*[@id='news-main']/div";
XPath xPath = XPathFactory.newInstance().newXPath();
NodeList articleBlocks = (NodeList)xPath.compile(myXpathStr).evaluate(doc, XPathConstants.NODESET);
希望能有所帮助。 我也同意id和css更快的其他答案。 我发现xpath更加强大,但是我对CSS路径没有太多的经验
我通过id
, class name
和其他易于识别的元素进行搜索。 但是速度将取决于网络连接和硬件。 您可以HTMLDriver
使用HTMLDriver
,因为它将是驱动程序的最快版本。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.