Selenium系列(十九) - Web UI 自动化基础实战(6)
2020-04-04 16:14
1081 查看
如果你还想从头学起Selenium,可以看看这个系列的文章哦!
https://www.cnblogs.com/poloyy/category/1680176.html
其次,如果你不懂前端基础知识,需要自己去补充哦,博主暂时没有总结(虽然我也会,所以我学selenium就不用复习前端了哈哈哈...)
注意,目前的实战都是流水账式写的,后面才会结合框架+PO模式
目的是为了掌握所学的Selenium基础
实战题目
- 访问: https://www.vmall.com/
- 获取一级菜单下包含哪些二级菜单,不包含查看全部
- 然后获取下面,热销单品中所有 顶部 带有 爆款字样的产品名称及价格
代码思路(人为测试时的操作步骤)
- 定位一级菜单的选项列表
- 循环列表,每次都将鼠标悬浮在当前选项上,然后打印二级菜单的列表
- 热销单品在页面下方,需要滑动页面
- 定位热销单品列表
- 循环,获取标题和价格,打印爆款
代码
#!/usr/bin/env python # -*- coding: utf-8 -*- """ __title__ = __Time__ = 2020/4/2 20:04 __Author__ = 小菠萝测试笔记 __Blog__ = https://www.cnblogs.com/poloyy/ """ from time import sleep from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.support import expected_conditions as ec from selenium.webdriver.support.wait import WebDriverWait from selenium.webdriver.common.action_chains import ActionChains driver = webdriver.Chrome("../resources/chromedriver.exe") action = ActionChains(driver) def wait_element(by_, element_): element = WebDriverWait(driver, timeout=10).until( ec.presence_of_element_located((by_, element_)) ) return element def wait_elements(by_, element_): element = WebDriverWait(driver, timeout=10).until( ec.presence_of_all_elements_located((by_, element_)) ) return element # 打开网站 driver.get("https://www.vmall.com/") # 列表 lists = wait_elements(By.XPATH, '//div[@id="category-block"]/div/ol/li') for one in lists: one_v = one.find_element_by_xpath("./input[2]").get_attribute("value") print(f"一级菜单:{one_v}") # hover action.move_to_element(one).perform() # hover出来的面板 items = one.find_elements_by_xpath('./div[contains(@class,"category-panels")]/ul/li[@class="subcate-item"]') for item in items: value = item.find_element_by_xpath('./input[1]').get_attribute("value") print(f"\t{value}") # 往下滚动1000px js = "document.documentElement.scrollTop = 1000" driver.execute_script(js) # 打印爆款 hot_lists = driver.find_elements_by_xpath( '//div[contains(@class,"home-hot-goods")]//ul[@class="grid-list clearfix"]/li') for hot in hot_lists: title = hot.find_element_by_xpath('./a/div[@class="grid-title"]') price = hot.find_element_by_xpath('./a/p[@class="grid-price"]') print(f"爆款:{title.text}, 价格:{price.text}") sleep(5) driver.quit()
相关文章推荐
- Selenium系列(十四) - Web UI 自动化基础实战(1)
- Selenium系列(十六) - Web UI 自动化基础实战(3)
- CrazyWing:Python自动化运维开发实战 十九、html基础入门
- 实战域树部署,Active Directory系列之十九
- Selenium2学习-019-WebUI自动化实战实例-017-获取浏览器类型
- Ruby On Rails系列从入门到精通实战教程(Ruby基础+Rails框架+网上商城项目实战)
- 【云星数据---Apache Flink实战系列(精品版)】:Apache Flink实战基础0015--flink分布式部署0010
- selenium 自动化测试工具基础知识
- Selenium2学习-027-WebUI自动化实战实例-025-JavaScript 在 Selenium 自动化中的应用实例之三(页面滚屏,模拟鼠标拖动滚动条)
- Selenium2 Python 自动化测试实战学习笔记(八)
- 自动化基础普及之selenium是啥?
- 基于《Selenium 2自动化测试实战》的学习笔记(8)—— 鼠标事件
- selenium实战练习之:粉丝反馈表单的自动化脚本
- Selenium2 Python 自动化测试实战学习笔记(四)
- Spark入门实战系列--2.Spark编译与部署(上)--基础环境搭建
- Selenium2 Python 自动化测试实战学习笔记(九)
- 【自动化测试技术QTP基础系列六】---QTP脚本录制及回放
- 【自动化测试技术QTP基础系列五】---自动化概述
- 【自动化测试技术QTP基础系列九】---脚本调试
- 轻松自动化---selenium-webdriver(python) 系列教程