背景:

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. python 容器 生成器 迭代器 总结

    一.容器 容器是一种把多个元素组织在一起的数据结构,容器中的元素可以逐个地迭代获取,可以用in, not in关键字判断元素是否包含在容器中.通常这类数据结构把所有的元素存储在内存中. >> ...

  2. bzoj 5498: [2019省队联测]皮配【dp】

    是个神仙dp-- 参考:https://www.luogu.org/blog/xzz-233/solution-p5289 设f[i][j][k]是前i个有限制的城市,所有学校中选蓝色阵营有j人,有限 ...

  3. bzoj 3513: [MUTC2013]idiots【生成函数+FFT】

    想了好长时间最后发现真是石乐志 第一反应就是两边之和大于第三边,但是这个东西必须要满足三次-- 任意的两边之和合通过生成函数套路+FFT求出来(记得去掉重复选取的),然后这任意两边之和大于任意第三边可 ...

  4. PostgreSQL - psql的使用与退出

    PostgreSQL连接数据库的两种方式 PostgreSQL在安装时自带了pgAdmin和psql,pgAdmin是可视化工具,psql是命令行工具.虽然pgAdmin操作起来会更加直观简单,但是在 ...

  5. 将tomcat添加到系统服务

    一.安装服务 执行“service.bat install 二.卸载服务 在命令行中进入/Tomcat路径/bin/,执行“service.bat remove”  

  6. April Fools Contest 2017 E

    Description Input The input consists of four lines, each line containing a single digit 0 or 1. Outp ...

  7. 1-18String类简介

    字符串(String)的不可变性 String类在java.lang包下面,是Object类的直接子类,通过API或者源码可以看到,String类是final修饰的,这说明String类不能被继承. ...

  8. RHEL 6.5----rsync+inotify数据同步服务

    Rsync特性: 可以镜像保存整个目录树和文件系统: 可以保持原文件的权限.时间.软硬链接等: 安装简单. 传输特点: 速度快:rsync首次同步会复制同步全部内容,以后只传输修改过的文件: 压缩传输 ...

  9. Oozie的架构

    Oozie的架构图,如下: 从oozie的架构图中,可以看到所有的任务都是通过oozie生成相应的任务客户端,并通过任务客户端来提交相应的任务. 继续...

  10. PHP连接数据操作步骤

    数据库的操作步骤: 端口号:0到65535 3306:mysql数据库的默认端口号(可修改) mysql_connect(“本机地址”,“用户名”,“密码”,); new_link:如果用同样的参数第 ...