语言: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. codeforces#562 Div2 C---Increasing by modulo【二分】

    题目:http://codeforces.com/contest/1169/problem/C 题意: 有n个数,每次可以选择k个,将他们+1并对m取模.问最少进行多少次操作,使得序列是非递减的. 思 ...

  2. nginx大概工作机制

    1.master和worker nginx启动后,会有2种进程:worker和master;worker可能有多个:

  3. vue上传大文件的解决方案

    众所皆知,web上传大文件,一直是一个痛.上传文件大小限制,页面响应时间超时.这些都是web开发所必须直面的. 本文给出的解决方案是:前端实现数据流分片长传,后面接收完毕后合并文件的思路. 实现文件夹 ...

  4. asmlinkage的用法

    转自:https://www.cnblogs.com/china_blue/archive/2010/01/15/1648523.html https://blog.csdn.net/liujiaoy ...

  5. Java 显示锁 之 队列同步器AQS(六)

    1.简述 锁时用来控制多个线程访问共享资源的方式,一般情况下,一个锁能够防止多个线程同时访问共享资源.但是有些锁可以允许多个线程并发的访问共享资源,比如读写锁. 在Java 5.0之前,在协调对共享对 ...

  6. MongoDB系列一:MongoDB文档型数据库特点介绍

    一.MongoDB数据库的存储特点: 1.MongoDB是文档型数据库,存储的是文档(将json二进制化为Bson存储): 2.存储的每篇文档都可以有自己独特的存储结构,颠覆了传统数据库必须按照表和列 ...

  7. 20175329&20175313&20175318 2019-2020 《信息安全系统设计基础》实验三

    20175329&20175313&20175318 2019-2020 <信息安全系统设计基础>实验三

  8. AB窗体互传参数本质

    一.找了好几个,都不靠谱,不是说不靠谱,自己感觉太繁琐,根本就是本窗体的属性(对象)的传递,1实例化2把实例化后的窗体属性=本窗体的对象 二.传递的的时候都是在互相引用的时候传递,推荐的个人认为最简单 ...

  9. 如何解决Sublime text中文乱码问题

    Sublime Text 2是一个非常不错的源代码及文本编辑器,但是不支持GB2312和GBK编码在很多情况下会非常麻烦.不过Sublime Package Control所以供的插件可以让Subli ...

  10. leetcode 日常清单

    a:excellent几乎一次ac或只有点小bug很快解决:半年后再重刷: b:经过艰难的debug和磕磕绊绊或者看了小提示才刷出来: c:经过艰难的debug没做出来,看答案刷的: 艾宾浩斯遗忘曲线 ...