python 提取字符串中的数字、中文以及class有多个样式,find_element_by_css_selector定位方法

提取字符串中的数字、中文:

在这里插入图片描述
如上图,我要获取图片页面中下一页和总共有多少页,这个时候需要对页面进行提取数字甚至中文,代码如下:

# get_attribute('innerText')和get_attribute('textContent')、get_attribute('outerText')都可以获取的定位到元素中的内容
# 获取总页数文本内容
page_total_text1 = self.driver.find_element_by_xpath('//div[@class="total"]').get_attribute('innerText')
page_total_text2 = self.driver.find_element_by_xpath('//div[@class="total"]').get_attribute('textContent')
page_total_text = self.driver.find_element_by_xpath('//div[@class="total"]').get_attribute('outerText')

# 提取字符串中的数字
page_total = re.findall("\\d+", page_total_text)[0]

# 提取字符串中的中文
pre = re.compile(u'[\u4e00-\u9fa5]+')
res = re.findall(pre, page_total_text)
res1 = ''.join(res)

# 判断变量字符类型,如果是字符型需要转换成int类型
if isinstance(page_total, str):
    page_total = int(page_total)

代码运行结果,如下图:
在这里插入图片描述

class有多个样式,find_element_by_css_selector定位方法:

selenium的官方文档可以通过find_element_by_css_selector来定位元素,如下例子:

content = driver.find_element_by_css_selector('li.item')

但是,很多网页源码中,class的值有多个,换句话说,有多个样式该怎么办呢?如图:
在这里插入图片描述
这时候,我们可以通过下面这种方法来定位:

content_list = driver.find_elements_by_css_selector("a.J_Ajax.num.icon-tag")
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值