python 打卡程序_如何用python实现腾讯文档自动打卡并定时执行

最近学了些Web,了解了一些selenum包内函数使用,就写了下自动健康打卡,并用windows任务计划程序定时执行,健康打卡这个针对特定网站,所以对于通用化使用倒没有太大用处,但关于腾讯文档如何填写,因为定位不了表格就没得想法。。然后和同伴讨论了下,一开始采用的是先填写,再查找并替换,即先填写一些无关信息,比如名字简写,然后再通过点击编辑栏中的查找功能,在上面输入栏进行字符增减操作。

# 1.0版本,通过先填写内容,再替换实现

driver.find_element_by_xpath('//*[@id="editmenu"]/div/div/div[1]').click()

ActionChains(driver).key_down(Keys.CONTROL).key_down('f').perform() # 打开查找功能

time.sleep(3)

try:

driver.find_element_by_id('search-panel-input').send_keys("xxx") # 这里很魔性,一直没找出原因,同伴告诉我才知道如何修改

driver.find_element_by_id('search-panel-input').send_keys("xxx")# xxx是自己随便写的标识符

time.sleep(3)

driver.find_element_by_id('alloy-simple-text-editor').click()

for i in range(1,4): # 删去标识符

driver.find_element_by_id('alloy-simple-text-editor').send_keys(Keys.BACK_SPACE)

elmet = driver.find_element_by_id('alloy-simple-text-editor')

elmet.send_keys('ok') # 输入ok

time.sleep(1)

elmet.send_keys(Keys.ENTER)

print("已完成打卡!!!")

except:

print("出现某些异常!")

上面这个可以针对大多数填写情况,但这种过于繁琐。

一开始也注意到了域名的特殊性,即如下所示,打开腾讯文档,我们会发现,每次点击一个表格,域名后面的&c=xx 会更改,但不知道如何利用。

bcb2553fc66446208fb066b81ec27b4d.png

后面经同伴提醒后面的A0A0代表页数就恍然大悟,其实原先的思路绕了一个大圈去定位表格,没想到表格信息就已经存在访问的域名中,然后就想直接通过datetime获取当前day,然后根据腾讯文档表格中的日期获取列号,这里注意下,程序中对应的是如下图所示的表格,因为这里A对应的是空,所以得+1。

157c47e87af34e9b9938b97e4cc27e7e.png

代码如下所示

# -*- coding: utf-8 -*-

"""

Created on Sun Apr 5 11:14:09 2020

@author: 虫二

"""

from selenium import webdriver

from selenium.webdriver.support.ui import Select

from selenium.webdriver.common.keys import Keys

import time

import datetime

# 填写腾讯文档

def visit_txt():

data = datetime.date.today()# 获取当前时间

now = data.day

# 获取行列式得根据实际需求修改

start = 2 # 根据第一列时间,需要修改

c = chr(now-start+1+65) # 获取列号, 65即是'A'

h = 8# 行号,即你要填写对应的行号

print(c)

url = "http:... c=" + c + str(h) +"A0A0" # 需要修改

driver = webdriver.Chrome("chromedriver.exe")

driver.get(url)

driver.implicitly_wait(10)

elmet = driver.find_element_by_class_name("unlogin-container")

elmet.click()

driver.implicitly_wait(10)

# 得提前登录qq,因为这里用了快捷登录接口

driver.switch_to.frame("login_frame")

elmet = driver.find_element_by_id("img_out_qq号")# 需要修改

elmet.click()

# 转换frame

driver.switch_to.parent_frame()

time.sleep(5)

try:

elmet = driver.find_element_by_id('alloy-simple-text-editor')

elmet.click()

elmet.send_keys('xxx') # 输入xxx,即你想输入的字符

time.sleep(1)

elmet.send_keys(Keys.ENTER)

time.sleep(3)

print("今天已成功打卡!!!")

except:

print("出现某些异常,请检查!!!")

if __name__ == "__main__" :

visit_txt()

任务计划程序

Window有个任务计划程序功能,还是很有用的,可以定时执行程序。

打开后点击创建,然后继续下一步设置名称,触发器…

e0fbf82255ba4daaadf68ef58a20944f.jpg

需要注意的是下面这部分,第一个程序和脚本就找到你配置好环境中的python.exe,比如D:\Anaconda3\python.exe,参数就填写你要运行的程序,起始地址可以填写python.exe父目录,比如D:\Anaconda3

f1cc3235ba684c979aca4fc7f7ee78d6.jpg

题外话

这次有同伴的帮助,爬出了不少坑,这过程中也学到了挺多东西,也发现了解的确实很少,还得继续去了解相关内容.

另:运行程序需配置python环境,安装selenium等相关包,并安装chrome.exe,这个配置过程可能会有点麻烦,但还是挺有意思的,建议用anaconda3环境,比较容易上手和管理库,安装教程其他博客都写的很详细。

关于anaconda3遇到了一个坑,就是Anaconda3环境中有两个python.exe脚本,需要注意的是它们的目录不同,例如在D:\Anaconda3目录下的是用conda管理库的,就是平时用conda install xxx,下载的所在的环境。

但在D:\Anaconda3\envs\temp.py\python.exe,则是基于pip管理库的,这个是基本的python,所以很多库都没有。

所以在配置Pycharm和VScode时需要注意这个脚本路径。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值