我有一个问题-我正在使用Selenium(firefox)Web驱动程序打开网页,单击一些链接等,然后捕获屏幕截图。
我的脚本可以从CLI正常运行,但是通过cronjob运行时,它并没有通过第一个find_element()测试。我需要添加一些调试,或一些帮助我弄清为什么失败的东西。
基本上,我必须先单击“登录”锚点,然后才能进入登录页面。元素的构造为:
<a class="lnk" rel="nofollow" href="/login.jsp?destination=/secure/Dash.jspa">log in</a>
我正在通过LINK_TEXT方法使用find_element:
login = driver.find_element(By.LINK_TEXT, "log in").click()
我有点Python Noob,所以我在和这种语言作斗争…
A)如何检查链接是否已被python实际拾取?我应该使用try / catch块吗?
B)是否有比LINK_TEXT更好/更可靠的方法来定位DOM元素?例如,在JQuery中,可以使用更具体的选择器$(’a.lnk:contains(log in)’)。do_something();
我已经解决了主要问题,这只是手指上的麻烦-我用错误的参数调用脚本-简单的错误。
我仍然想要一些有关如何检查元素是否存在的指针。同样,使用隐式/显式Waits的示例/解释,而不是使用糟糕的time.sleep()调用。
A)是的。检查元素是否存在的最简单方法是find_element在内简单调用try/catch。
find_element
try/catch
B)是的,出于两个原因,我总是尝试不使用元素文本来标识元素:
解决方案之一:
对于后续问题,使用try/catch可以知道如何确定元素是否存在,可以在这里找到很好的等待示例: