zoukankan      html  css  js  c++  java
  • Selenium2+python自动化34-获取百度输入联想词【转载】

    前言

    最近有小伙伴问百度输入后,输入框下方的联想词如何定位到,这个其实难度不大,用前面所讲的元素定位完全可以定位到的。

    本篇以百度输入框输入关键字匹配后,打印出联想词汇。

    一、定位输入框联想词

    1.首先在百度输入框输入关键词,如:博客,然后输入框下方会自动匹配出关键词。

    2.这时候可以用firebug工具定位到联想出来的词,可以看到下方匹配出来的词都有共同的class属性,这时候就可以全部定位到了。

    二、打印全部匹配出来的词

    1.通过get_attribute()方法获取到文本信息

    三、点击其中一个

    1.点击其中的一个联想词,如:第二个

    2.这里可以先加一个判断,如果获取到了就点击,没获取到就不点击了,以免抛异常。

    (如果想依次点击,用for循环就可以了)

    三、参考代码

    # coding:utf-8
    from selenium import webdriver
    import time
    driver = webdriver.Firefox()
    driver.implicitly_wait(10)
    driver.get("http://www.baidu.com")
    time.sleep(1)
    driver.find_element_by_id("kw").send_keys(u"博客")
    # 获取百度输入框的
    time.sleep(1)
    bd = driver.find_elements_by_class_name("bdsug-overflow")
    for i in bd:
        print i.get_attribute("data-key")

    # 点击其中的一个,如:第二个
    if len(bd) > 1:
        bd[1].click()
        # 打印当前页面url
        print driver.current_url
    else:
        print "未获取到匹配的词"

  • 相关阅读:
    oculus按键大全
    10 soundJs 初体验
    09 获取服务器时间
    08 基本数据类型转换
    07 如果再使用animateCC2018或者苹果系统使用animate时出现Uncaught ReferenceError: lib is not defined的错误
    AS3.0和php数据交互POST方式
    06 显示fps帧频
    05 js利用ajax向服务器发送请求并返回json值
    04 ajax执行php并传递参数
    03php拉取服务器信息并生成json
  • 原文地址:https://www.cnblogs.com/caoj/p/7813686.html
Copyright © 2011-2022 走看看