语言:Python

京东商城想要找到某个未加载出的元素,需要将页面加载出来。

使用js实现

流程:

1. 需要引入包:

# 引入需要的包
import time from selenium import webdriver from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.wait import WebDriverWait

2. 创建浏览器对象等

# 创建浏览器对象
driver = webdriver.Chrome()
url = "http://www.baidu.com"
driver.get(url) # 窗口最大化
driver.maximize_window()

3. 定位京东商城网站,点击等操作

# 等待搜索框元素出现,使用显性等待
loc = (By.ID, 'kw')
WebDriverWait(driver, 20).until(EC.visibility_of_element_located(loc)) # 定位、点击元素操作,需要使用等待
jd_link = driver.find_element_by_id("kw")
jd_link.send_keys("京东商城", Keys.ENTER)
loc = (By.XPATH, '//a[contains(text(),"正品低价、品质保障")])
WebDriverWait(driver, 20).until(EC.visibility_of_element_located(loc))
driver.find_element(*loc).click()
# 窗口句柄操作
“”“
一般情况下使用最新窗口,则:
win = driver.window_handles
driver.switch_to.window(win[-1])
”“” win = driver.window_handles
driver.switch_to.window(win[-1]) # 需要根据实际的窗口尺寸,来决定每次滚动距离,所以需要获取实际窗口尺寸
# window.outerHeight:包含工具栏和滚动条
# window.innerHeight:不包含工具栏和滚动条,仅内容可视区域 lo = (By.XPATH, '//*[@id="J_top"]/div[1]/a/h3') # 获取当前窗口宽高: get_window_size()方法
win_size = driver.get_window_size()
# 获取当前窗口内容可视区,execute_script()方法
inner_height = driver.execute_script("
var a = window.innerHeight;
return a;
")
print("当前窗口的内容可视区域-高度:",inner_height) # 获取当前整个html页面的body高度。
body_height = driver.execute_script("
var a = document.body.scrollHeight;
return a;
")
print("当前整个html页面的body-高度:",body_height)

4. 不断向下滑动,直至找到目标元素

# 创建目标高度
scrolled_height = 0
new_body_height = body_height
old_body_height = 0
break_flag = False # 循环操作,直至找到目标元素
while new_body_height != old_body_height:
distance = int((new_body_height -scrolled_height)/ (inner_height * 0.5)) + 1
for i in range(distance):
# 滚动距离为 窗口内容可视区域的百分之50.可灵活配置哦!
driver.execute_script("
var a = window.innerHeight;
window.scrollBy(0,a*0.5);
")
# 滚动一次,页面内容会更新一部分。在滚动之后,查找当前页面是否包含了它。
# 如果没有,继续滚动。如果有,退出。
try:
WebDriverWait(driver, 10).until(EC.visibility_of_element_located(lo))
except:
pass
else:
print("找到啦!!!")
driver.find_element(*lo).click()
break_flag = True
# 终止for循环
break
if break_flag is True:
# 终止While循环
break
# time.sleep(3)
# 更新滚动
old_body_height = new_body_height
scrolled_height = new_body_height
new_body_height = driver.execute_script("
var a = document.body.scrollHeight;
return a;
")
print("老-当前整个html页面的body-高度:", old_body_height)
print("新-当前整个html页面的body-高度:", new_body_height)

selenium实现京东商城首页查找元素的更多相关文章

  1. Android 深入ViewPager补间动画,实现类京东商城首页广告Banner切换效果

    如有转载,请声明出处: 时之沙: http://blog.csdn.net/t12x3456 某天看到京东商城首页的滑动广告的Banner,在流动切换的时候有立体的动画效果,感觉很有意思,然后研究了下 ...

  2. 使用Python学习selenium测试工具-4:查找元素

    转自:https://blog.csdn.net/wd168/article/details/51819930 web通常包含了Hyper Text Markup Language (HTML).Ca ...

  3. 京东商城首页jquery轮播特效

    <!DOCTYPE html><html> <head> <meta charset="utf-8" /> <title> ...

  4. 封装查找元素以及集成日志输出,Base模块

    关于查找元素封装,Base模块 """ Selenium 封装基类 封装查找元素以及集成日志输出 """ from HTMLReport i ...

  5. Scrapy实战篇(八)之Scrapy对接selenium爬取京东商城商品数据

    本篇目标:我们以爬取京东商城商品数据为例,展示Scrapy框架对接selenium爬取京东商城商品数据. 背景: 京东商城页面为js动态加载页面,直接使用request请求,无法得到我们想要的商品数据 ...

  6. selenium常用操作,查找元素,操作Cookie,获取截图,获取窗口信息,切换,执行js代码

    目录: 1. 常用操作 2. 查找元素 3. 操作Cookie 4. 获取截图 5. 获取窗口信息 6. 切换 7. 执行JS代码 简介 selenium.webdriver.remote.webdr ...

  7. (java)selenium webdriver学习--通过id、name定位,输入内容,搜索,关闭操作、通过tagname查找元素

    selenium webdriver学习--通过id.name定位,输入内容,搜索,关闭操作:通过tagname查找元素 打开谷歌浏览器,输入不同的网站,搜索框的定位含有不同元素(有时为id,有时为n ...

  8. 01-02 Flutter仿京东商城项目 功能分析、底部导航Tab切换以及路由配置、架构搭建:(Flutter仿京东商城项目 首页布局以及不同终端屏幕适配方案)

    Flutter和Dart交流学习群:交流群:452892873 01Flutter仿京东商城项目 功能分析.底部导航Tab切换以及路由配置.架构搭建 02Flutter仿京东商城项目 首页布局以及不同 ...

  9. <自动化测试>之<selenium API 查找元素操作底层方法>

    搜罗了一些查找元素的除标准语句外,另外的语句使用方法,摘自 开源中国 郝云鹏driver = webdriver.Chrome(); 打开测试页面 driver.get( "http://b ...

随机推荐

  1. 开源笔记软件Joplin

    Joplin is a free, open source note taking and to-do application, which can handle a large number of ...

  2. 数据结构实验之栈与队列一:进制转换(SDUT 2131)

    题目链接 题解: 特判一下n==0的时候. #include <bits/stdc++.h> using namespace std; int a[1000]; int main() { ...

  3. Linux下更换为阿里yum源

    更新日期: 2018-08-06 1.yum源的工作原理 yum是为了解决安装包的依赖关系而生的,如果要源码安装一个软件,需要频繁下载各个包,并解决包的依赖关系.这就好比学门课程,要学会这门课程,就要 ...

  4. .net core Redis库 CSRedis

    由于servicestack.redis收费,基于有人说StackExchange.Redis 使用会出现一些问题比如会超时, 找到了CSRedis这个库,很强大很实用.另外有兴趣的朋友还可以试试另一 ...

  5. 利用django框架,手把手教你搭建数据可视化系统(一)

    如何使用django去构建数据可视化的 web,可视化的结果可以呈现在web上. 使用django的MTV模型搭建网站 基础铺垫-MTV模型 Created with Raphaël 2.1.0Req ...

  6. 捣乱Linux环境下的C语言

    #include <stdlib.h> 头文件作用.CSDN C 标准库 – <stdlib.h> | 菜鸟教程  https://www.runoob.com/cprogra ...

  7. sprintf简介

    sprintf 基本用法 输入一段有特点的字符串 #include <cstdio> #include <cstring> using namespace std; int m ...

  8. epoll反应堆

    /* * epoll基于非阻塞I/O事件驱动 */ #include <stdio.h> #include <sys/socket.h> #include <sys/ep ...

  9. python小技巧之把list组合成chain

    a=[] for i in range(10): a.append(i) for i,j in zip(a[:-1],a[1:]): print('%s=>%s'%(i,j)) 输出结果: 0= ...

  10. Tomcat的server.xml

    慕课网:https://www.imooc.com/video/19201 Server:指整个tomcat服务器,它其中包含多个组件,它主要负责管理和启动各个service,同时监听8005端发过来 ...