爬虫学习:Selenium笔记

页面跳转:

from selenium import webdriver
# import selenium.webdriver.support.ui as ui
import time

browser = webdriver.Firefox()
browser.get("https://bj.lianjia.com/")
browser.maximize_window()

time.sleep(1)

browser.find_element_by_class_name("btn").click()

windows = browser.window_handles
print(windows)

'''
find_element_by_link_text()和find_element_by_partial_link_text()
这两种定位方式是专门用于定位超链接的,也就是对应html页面中的<a>标签,
括号里传的值就是a标签中的超链接文字,两者的区别在于一个是完整的超链接文字,
一个是可以只写部分超链接文字。
'''
browser.find_element_by_link_text("2").click()
browser.find_element_by_link_text("下一页").click()

浏览器窗口的跳转:

from selenium import webdriver
import time

browser = webdriver.Firefox()
browser.get("https://www.sina.com.cn")

browser.find_element_by_link_text("新闻").click()  # 点击"新闻"的链接,打开第二个浏览器窗口

browser_windows = browser.window_handles  # 获取当前的所有的句柄
print(browser_windows)  # 结果为一个列表

time.sleep(2)
print(browser.current_url)  # 打印当前浏览器窗口页面地址,仍为https://www.sina.com.cn/
print(browser.current_window_handle)  # 浏览器打开的首页,即所有句柄列表里的第一个句柄

# 切换浏览器窗口页面(第二个窗口)
browser.switch_to.window(browser_windows[1])  # 切换到第二个句柄,即第二个浏览器窗口页面
time.sleep(2)
print(browser.current_url) # 获取切换之后的网址
print(browser.current_window_handle)  # 打印输出切换后的句柄

# 打开第三个窗口,句柄并切换到该窗口页面
browser.find_element_by_link_text("体育").click()  # 点击"体育"的链接,打开第三个浏览器窗口,注:有多个带体育文字的链接,但只会找第一个
print(browser.find_element_by_link_text("体育"))
browser.switch_to.window(browser.window_handles[2])  # 这里直接获取当前所有打开窗口的句柄列表,并选定第三个句柄
print("第三个页面的网址:",browser.current_url)

模拟人工手动下载声音文件:

from selenium import webdriver
import time

browser = webdriver.Firefox()
browser.get("http://www.aigei.com/sound/class/common_classes/")
browser.find_element_by_class_name("text-login").click()
time.sleep(2)

# 切换到新弹出页面
browser.switch_to.window(browser.window_handles[1])
time.sleep(2)

# 切换到iframe
login_frame = browser.find_element_by_xpath('//iframe[@frameborder="0"]')
browser.switch_to.frame(login_frame)  # 从frame中切回主文档用switch_to.default_content()
browser.find_element_by_id("nick_XXXXXX").click() # 点击登录,XX表示QQ号码
time.sleep(2)

# 返回第一个网页
browser.switch_to.window(browser.window_handles[0])
print(browser.current_url)
browser.maximize_window()
time.sleep(4)

browser.find_element_by_xpath(
    "/html/body/div[3]/div[2]/div[3]/div/div/div/div[2]/ul[1]/li/div[3]/div[4]/span[1]/a/span").click()
browser.find_element_by_xpath(
    "/html/body/div[3]/div[2]/div[3]/div/div/div/div[2]/ul[1]/li/div[3]/div[4]/span[1]/ul/li[4]/a/span[1]").click()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值