如果你还想从头学起Selenium,可以看看这个系列的文章哦!
https://www.cnblogs.com/poloyy/category/1680176.html
其次,如果你不懂前端基础知识,需要自己去补充哦,博主暂时没有总结(虽然我也会,所以我学selenium就不用复习前端了哈哈哈...)
注意,目前的实战都是流水账式写的,后面才会结合框架 PO模式
目的是为了掌握所学的Selenium基础
实战题目
- 打开 12306 网站 https://kyfw.12306.cn/otn/leftTicket/init
- 出发城市 填写 ‘南京南’, 到达城市 填写 ‘杭州东'
- 发车时间 选 06:00--12:00
- 发车日期选当前时间的下一天,也就是日期标签栏的,第二个标签
- 我们要查找的是所有 二等座还有票的车次,打印出这些有票的车次的信息,结果如下:
G7641
G1505
G7393
G7689
代码思路(人为测试时的操作步骤)
- 点击【出发城市】,输入并点击南京南
- 点击【到达城市】,输入并点击杭州东
- 选择发车时间 06:00--12:00
- 选择第二个日期标签
- 获取到车次列表
- 循环列表,获取车次号和二等座那一列的数据
- 正则匹配是否有坐
- 输出车次号
代码
代码语言:javascript复制#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
__title__ =
__Time__ = 2020-03-31 21:30
__Author__ = 小菠萝测试笔记
__Blog__ = https://www.cnblogs.com/poloyy/
"""
import re
from time import sleep
from selenium.webdriver.support.select import Select
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
driver = webdriver.Chrome("../resources/chromedriver.exe")
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://kyfw.12306.cn/otn/leftTicket/init")
driver.maximize_window()
# 出发城市 填写 ‘南京南’,
from_ = wait_element(By.CSS_SELECTOR, "input#fromStationText")
from_.click()
from_.send_keys("南京南")
# 选择南京南
driver.find_element_by_css_selector("div#citem_0").click()
# 到达城市 填写 ‘杭州东’
to = wait_element(By.CSS_SELECTOR, "input#toStationText")
to.click()
to.send_keys("杭州东")
# 选择杭州东
driver.find_element_by_css_selector("div#citem_0").click()
# 发车时间 选 06:00--12:00
select = Select(driver.find_element_by_css_selector("select#cc_start_time"))
# 选择
select.select_by_visible_text("06:00--12:00")
# 发车日期选当前时间的下一天,也就是日期标签栏的,第二个标签
date_range = driver.find_elements_by_css_selector("div#date_range>ul>li")
date_range[1].click()
# 数据列表
lists = wait_elements(By.CSS_SELECTOR, "tbody#queryLeftTable>tr")[0::2]
print(len(lists))
# 循环数据
for data in lists:
number = data.find_element_by_css_selector("td>div>div.train a.number").text
two = data.find_elements_by_css_selector("td")[3].text
if re.findall("有|d ", two):
print(number)
sleep(10)
driver.quit()