背景:

Dnf的周年庆活动之一,游戏在6月22日 06:00~6月23日 06:00之间登陆过游戏后可以于6月25日 16:00~7月04日 06:00领取奖励

目标:连续四天自动运行脚本,自动领取所有奖励,每天领取一个

进度:当前未知登陆后是否还有选择区服弹窗,故当前仅处理到成功点击为止

思路:

python+selenium自动化点击,程序定时运行

实现方法:timer_exerice.py编写死循环定时器,30s判断一次是否到达相应时间,若到达时间,开始执行selenium_exerice.py,自动打开网页,登录账号,点击领取按钮

代码:

编写定时器。每日调整next_time即可

调用os模块是为了执行selenium_exerice.py,这方法比较简单粗暴

import datetime
import os
import time
def time_timer(now_time):
next_time = datetime.datetime.strptime("2019-6-21 15:17:00", "%Y-%m-%d %H:%M:%S")
timer_start_time = (next_time - now_time).total_seconds()
return timer_start_time def time_main():
while True:
now_time = datetime.datetime.now()
d = time_timer(now_time)
if d > 0:
print("距离目标时间还有%s秒" % (int(d)))
time.sleep(30)
else:
print("开始执行")
os.system(r"python D:\\Pyexerice\\selenium_exerice2.py")
break if __name__ == "__main__":
time_main()

编写自动登录点击代码

from selenium import webdriver
from selenium.webdriver.common.keys import Keys
import unittest,time
class Dnf_login(unittest.TestCase):
def setUp(self):
self.driver = webdriver.Chrome(r"C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe")
self.driver.implicitly_wait(30)
self.base_url = "https://dnf.qq.com/cp/a20190618login/?e_code=479698&idataid=266454"
self.verificationErrors = []
self.accept_next_alert = True
print("正在访问Dnf11周年庆活动界面") def test_dnf_login(self):
driver=self.driver
driver.maximize_window()
driver.get(self.base_url)
login_Hierarchy1=driver.find_element_by_id("unlogin")
login_Hierarchy2=login_Hierarchy1.find_element_by_id("btn_qqlogin")
driver.execute_script("arguments[0].click();",login_Hierarchy2)
time.sleep(5)
#授权登录界面点击账号密码登录
driver.switch_to.frame("loginIframe")
driver.find_element_by_id("switcher_plogin").click()
driver.find_element_by_id("u").clear()
driver.find_element_by_id("u").send_keys("username")
driver.find_element_by_id("p").clear()
driver.find_element_by_id("p").send_keys("password")
driver.find_element_by_id("p").send_keys(Keys.ENTER)
print("登录成功")
time.sleep(5)
# 点击领取按钮
# 按层查找按钮所在位置,处理点击
draw_Hierarchy1 = driver.find_element_by_class_name("dan-con")
draw_Hierarchy2 = draw_Hierarchy1.find_element_by_id("lotteryBtn1")
driver.execute_script("arguments[0].click();", draw_Hierarchy2)
print("点击成功")
time.sleep(5) def tearDown(self):
self.driver.quit()
self.assertEqual([], self.verificationErrors)
print("已关闭游览器") if __name__ == "__main__":
unittest.main()

采坑过程

1.Selenium中单击Element:ElementClickInterceptedException报错

如上图所示,最一开始的时候我的写法是

login_Hierarchy1=driver.find_element_by_id("unlogin")
login_Hierarchy2=login_Hierarchy1.find_element_by_id("btn_qqlogin").click()

然后报错信息如标题,不会处理找百度,参考

https://blog.csdn.net/qq_41424519/article/details/87906207

修改代码后可以成功点击登录按钮

2.登录授权界面switch_to.frame()

和1一样,一开始直接定位报错,百度查资料发现登录按钮在iframe上,

所以switch_to.frame()切换,定位成功

因为还没开放领取,不知道后面是不是还有填写区服的界面,所以暂时没有处理后续,仅到执行完点击后关闭界面,执行结果如下

python+selenium自动化登录dnf11周年活动界面领取奖励登录部分采坑总结[1]的更多相关文章

  1. Python+selenium 自动化-启用带插件的chrome浏览器,调用浏览器带插件,浏览器加载配置信息。

    Python+selenium 自动化-启用带插件的chrome浏览器,调用浏览器带插件,浏览器加载配置信息.   本文链接:https://blog.csdn.net/qq_38161040/art ...

  2. python selenium自动化点击页面链接测试

    python selenium自动化点击页面链接测试 需求:现在有一个网站的页面,我希望用python自动化的测试点击这个页面上所有的在本窗口跳转,并且是本站内的链接,前往到链接页面之后在通过后退返回 ...

  3. Python+Selenium自动化总结

    Python+Selenium自动化总结 1.环境搭建 1.1.安装selenium模块文件 pip install selenium 1.2.安装ChromeDriver驱动 [1]下载安装Chro ...

  4. Python+Selenium自动化-定位一组元素,单选框、复选框的选中方法

    Python+Selenium自动化-定位一组元素,单选框.复选框的选中方法   之前学习了8种定位单个元素的方法,同时webdriver还提供了8种定位一组元素的方法.唯一区别就是在单词elemen ...

  5. Python+Selenium自动化-模拟键盘操作

    Python+Selenium自动化-模拟键盘操作   0.导入键盘类Keys() selenium中的Keys()类提供了大部分的键盘操作方法:通过send_keys()方法来模拟键盘上的按键. # ...

  6. Python+Selenium自动化-设置等待三种等待方法

    Python+Selenium自动化-设置等待三种等待方法   如果遇到使用ajax加载的网页,页面元素可能不是同时加载出来的,这个时候,就需要我们通过设置一个等待条件,等待页面元素加载完成,避免出现 ...

  7. Python+Selenium自动化-清空输入框、输入内容、点击按钮

    Python+Selenium自动化-清空输入框.输入内容.点击按钮   1.输入内容 send_keys('valve'):输入内容valve #定位输入框 input_box = browser. ...

  8. Python+Selenium自动化-设置浏览器大小、刷新页面、前进和后退

    Python+Selenium自动化-设置浏览器大小.刷新页面.前进和后退   1.设置浏览器大小 maximize_window():设置浏览器大小为全屏 set_window_size(500,5 ...

  9. Python+Selenium自动化-获取页面信息

    Python+Selenium自动化-获取页面信息   1.获取页面title title:获取当前页面的标题显示的字段 from selenium import webdriver import t ...

随机推荐

  1. USB转串口 FT232/PL2303芯片使用体会

    现在笔记本上很少带有串口了,而串口又是做电子设计必备的通讯接口之一,好在USB转串口比较方便,市面上常用的USB转串口芯片有很多,最常见的有FT232.PL2303.CH340三种 原理:单片机的TX ...

  2. hbase表结构 + hbase集群架构及表存储机制

    本博文的主要内容有    .hbase读取数据过程 .HBase表结构 .附带PPT http://hbase.apache.org/ 读写的时候,就需要用hbase了,换句话说,就是读写的时候.需要 ...

  3. hdu 2818 Building Block 种类并查集

    在进行并的时候不能瞎jb并,比如(x, y)就必须把x并给y ,即fa[x] = y #include <iostream> #include <string> #includ ...

  4. python之迷宫BFS

    # @File: maze_queue_bfs from collections import deque maze = [ [1, 1, 1, 1, 1, 1, 1, 1, 1, 1], [1, 0 ...

  5. Codeforces Round #410 (Div. 2) A

    Description Mike has a string s consisting of only lowercase English letters. He wants to change exa ...

  6. Random Query CodeForces - 846F

    题目 翻译: 给出一个n个数字的数列a[1],...,a[n],f(l,r)表示使a[l],a[l+1],...,a[r]组成的新序列中的重复元素只保留一个后,剩下元素的数量(如果l>r,则在计 ...

  7. 在HTML页面中实时获取新消息的方法 “JavaScript中的setInterval用法”

    JavaScript中的setInterval用法(资料来源:博主---八神吻你   ) setInterval动作的作用是在播放动画的时,每隔一定时间就调用函数,方法或对象.可以使用本动作更新来自数 ...

  8. 2018 ACM-ICPC亚洲区域赛(青岛)

    Problem C---zoj 4060 Flippy Sequence 解题思路:要求进行两次操作,每次操作选择一个区间,问将s串变成t串中所选的两个区间构成的4元组有多少个.做法:找出s串与t串不 ...

  9. B. Connecting Universities DFS,无向树

    http://codeforces.com/problemset/problem/700/B 题意是,在一颗树中,有k个大学,要求两两匹配,他们之间的距离作为贡献,使得距离总和最大. 一开始的时候无从 ...

  10. MySQL防止重复插入记录SQL

    INSERT INTO sysuser(') DUAL:表示虚拟表 sysuser:表名称