随笔 - 172  文章 - 52  评论 - 6  阅读 - 17万

selenium模拟登录京东,手动解决验证码问题,抓取购物车价格

  selenium模拟登录京东,未解决验证码问题,但是可以在下方设置time.sleep(),时间长一点手动操作验证码,实现成功登录,并抓取了购物车价格:

复制代码
import selenium
import selenium.webdriver
import selenium.webdriver.common.keys
import lxml
import lxml.etree
import time
#测试已成功登录,并抓取了购物车的价格
driver = selenium.webdriver.Chrome()
driver.get("https://passport.jd.com/uc/login?ltype=logout&ReturnUrl=https://home.jd.com/")
time.sleep(3)
#切换到账户登录
elem=driver.find_element_by_xpath("//*[@class=\"login-tab login-tab-r\"]/a") #点到账户登录
elem.click()   #点击一下

user=driver.find_element_by_id("loginname")
password=driver.find_element_by_id("nloginpwd")
submit=driver.find_element_by_id("loginsubmit")
user.clear()  #清理user  因为已经有了,再写会出现问题

user.send_keys("用户名")
password.send_keys("密码")
time.sleep(1)
submit.click()  #点击一下


time.sleep(13)
driver.get("https://cart.jd.com/")
time.sleep(30)    #如果特定验证码比较麻烦,手动搞定
print(driver.page_source) #打印网页源代码

data=driver.page_source
mytree=lxml.etree.HTML(data)
print(mytree.xpath("//*[@class=\"plus-switch\"]/strong/text()"))  #提取购物车的价格  text()为提取标签之间的内容
time.sleep(10)
driver.close()
复制代码

 

posted on   共感的艺术  阅读(693)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示