在我们使用selenium进行抓取网页的时候,可能有的时候会抓取不到内容。
例如:driver.find_element_by_xxx().text() 为空的解决办法
在用driver.find_element_by_xxx().text()获取文本的时候,得到的文本为空,
那么当前定位的元素可能被隐藏了。
我们先查看当前的元素的原始代码
我们发现是有内容的,但是取出时是空。怎么判断是否被隐藏呢,可以通过.is_displayed()方法来判断。
我们可以看到返回时False,确实被隐藏了。这时我们就需要考虑怎么才能获取到我们需要的数据了。
在某些情况下,我们需要获取隐藏元素的文本。这些内容可以使用
element.attribute('attributeName'), 通过**textContent, innerText, innerHTML**等属性获 取。(划重点)
innerHTML 会返回元素的内部 HTML, 包含所有的HTML标签。
textContent 和 innerText 只会得到文本内容,而不会包含 HTML 标签。
我们看下最终的效果
文章来源:https://www.toymoban.com/news/detail-410703.html
文章来源地址https://www.toymoban.com/news/detail-410703.html
到了这里,关于selenium无法获取到标签的文本内容(text)的解决方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!