zoukankan      html  css  js  c++  java
  • Selenium系列(十九)

    如果你还想从头学起Selenium,可以看看这个系列的文章哦!

    https://www.cnblogs.com/poloyy/category/1680176.html

    其次,如果你不懂前端基础知识,需要自己去补充哦,博主暂时没有总结(虽然我也会,所以我学selenium就不用复习前端了哈哈哈...)

    注意,目前的实战都是流水账式写的,后面才会结合框架+PO模式

    目的是为了掌握所学的Selenium基础

    实战题目

    1. 访问: https://www.vmall.com/
    2. 获取一级菜单下包含哪些二级菜单,不包含查看全部
    3. 然后获取下面,热销单品中所有 顶部 带有 爆款字样的产品名称及价格

    代码思路(人为测试时的操作步骤)

    1. 定位一级菜单的选项列表
    2. 循环列表,每次都将鼠标悬浮在当前选项上,然后打印二级菜单的列表
    3. 热销单品在页面下方,需要滑动页面
    4. 定位热销单品列表
    5. 循环,获取标题和价格,打印爆款

    代码

    #!/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"	{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()
  • 相关阅读:
    webstorm 取消拖动代码
    可读流
    页面上怎么使用svg
    从element-ui按需引入去探索
    vue组件库用markdown生成文档
    create-react-app中的babel配置探索
    svg 使用中的疑惑点
    express中是如何处理IP的?
    koa中是如何封装获取客户端IP的?
    博客园文章添加目录
  • 原文地址:https://www.cnblogs.com/poloyy/p/12632293.html
Copyright © 2011-2022 走看看