使用Python定时执行一任务,自动登录某web系统,生成报表,然后发送邮件给指定人员
一、项目需求
每周从A系统生成一张Excel报表,发送此报表给指定人员,相关人员依据此报表去完成后续的工作。
项目限制:
1、无法通过EDI系统交互的方式从后台读取数据
2、由于公司网络环境限制,不能使用SMTP发送邮件,比如,不能通过smtp.163.com发送邮件
二、解决方案
模拟人工操作,登录系统,输入相应查询条件,生成报表,保存后发送邮件给指定人员。
采用技术:采用Python
三、关键点
1、使用selenium模拟登录浏览器
'使用IE浏览器
driver.webdriver.Ie()
driver.get("http://XXXXX")
'最大化浏览器
driver.maximize_window()
'找到登录账号的组件名
elem=driver.find_element_by_name("tbx_loginEmpNo")
'输入登录账号,假定登录账号是AAAAA
elem.send_keys(u"AAAAA")
’找到登录口令组件
elem=driver.find_element_by_name("tbx_Password")
'假定登录口令是XXXXXX
elem.send_keys(u"XXXXXX")
'点击登录按钮
driver.find_element_by_id("btnSignIn").send_keys(Keys.ENTER)
2、使用pyautogui模拟键盘操作,根据日期输入动态查询条件
'鼠标所在位置的(X,Y)坐标的获得
print(pyautogui.position())
‘可以设定鼠标移动到屏幕上任何位置,以(X,Y)坐标表示
ptautogui.moveTo(x,y,duration=1)
'模拟鼠标左键点击
ptautogui.click(x,y)
’获得当前日期
today=datetime.date.today()
‘无法直接把today输入到屏幕上的文本框里,需要转换成字符串类型
‘这里假定查询从今天往前一周的数据
sBeginDate=(today-datetime.timedelta(days=7)).strftime('%Y-%m-%d')
sEndDate=today.strftime('%Y-%m-%d')
'在往屏幕上文本框里输入日期条件时,先移到指定位置
pyautogui.moveTo(x,y,duration=1)
'点鼠标左键确定输入到文本框里
pyautogui.click(x,y)
'输入动态日期
pyautogui.typewrite(sBeginDate)
这里如果直接在pyautogui.typewrite(today)则会报错,需要把today转换成字符串
3、import win32Com.client as win32
调用Outlook,发送邮件,需要已具备公司内部邮箱账号
参考示例:
outlook=win32.Dispatch('outlook.application')
mail=outlook.CreateItem(0)
receivers=['abc123@163.com;abc234@163.com']
mail.To=receivers[0]
mail.Subject='这是一个测试邮件'
mail.Body="Dear XXX \r\n XXXX \r\n XXXX"
mail.Attachements.Add(‘C:\\aaa.xlsx’) '假设要发的附件在C盘根目录下
mail.Send()
四、定时任务
定时任务的实现是采用Windows系统里的任务,创建一任务,调用一个简单的批处理文件,设置成一周调用一次
文件名: AAA.bat
内容:
@echo off
python C:\work\python\XXXXXX.py
exit
使用Python定时执行一任务,自动登录某web系统,生成报表,然后发送邮件给指定人员的更多相关文章
- python定时执行方法
1 time.sleep import time for i in range(5): print(i) time.sleep(10) 2 用shed import time import sche ...
- python 奇淫技巧之自动登录 哔哩哔哩
前言 嘿,各位小伙伴好呀,今天要带来点什么干货呢,就从我的实际开发中来给大家带来一个案例吧,如何自动登录 哔哩哔哩 接到老大通知,让我自动写一个自动登录 哔哩哔哩 的脚本,我当然是二话不说直接开怼,咱 ...
- python定时执行详解
知识点 1. sched模块,准确的说,它是一个调度(延时处理机制),每次想要定时执行某任务都必须写入一个调度. (1)生成调度器:s = sched.scheduler(time.time,time ...
- 用Golang让自己的电脑自动登录“上网管理”系统
用Golang让自己的电脑自动登录 1.缘起 大天朝的网络一般都是只对某些人开放的.上行下效,同样的措施也作用在我们的教育网上.我想不出来,为什么很多领导的总有这样的恶趣味(如果做的到,他们恨不得监控 ...
- 【转】【Python】Python3爬虫实现自动登录、签到
工具:Fiddler 首先下载安装Fiddler,这个工具是用来监听网络请求,有助于你分析请求链接和参数. 打开目标网站:http://www.17sucai.com/,然后点击登录 好了,先别急着登 ...
- Python案例之QQ空间自动登录程序实现
不多说,直接上干货! 工具选择: 电脑系统:win7,32 位,下面第二部安装SetupTools时注意系统版本要求: Python: 2.7.11, 相信只要是2.7的就可以实现: Seleniu ...
- Python定时执行脚本
最近测试hbase,老发现服务挂掉,自己不能及时发现,想了想,写了个脚本,让脚本每个小时执行一次,以便检测是否有服务挂掉,如果有服务挂掉,及时启动 import os import datetime ...
- python+selenium+webdriver+BeautifulSoup实现自动登录
from selenium import webdriverimport timefrom bs4 import BeautifulSoupfrom urllib import requestimpo ...
- 用python实现自动化登录禅道系统 设置定时器自动执行脚本
由于各种原因,我想试下用python实现自动登录禅道系统,并且每天定时执行.(本人第一次接触自动化,在大佬眼中门槛都没摸到的类型) 首先缕清思路: 1.实现自动登录禅道系统,用selenium实现2. ...
随机推荐
- 【工作】to-do-list
当你不确定的时候,你就把你所在的工作做好,所在的你不愿意的行业做好,所谓的自由选择,它本身不自由的,不自由过程当中,如何你把它做好,就做人生的一个经历,人生的一个积累.-- 王石 TODO
- vue前端开发那些事——前言
如上图所示,用vue开发一个小型网站所涉及到的知识点.这只是前端部分已经这么多了.接下来我分解开来说. 1.Node 当我们开发vue项目的时候,首先要安装Node.js,那么我们即使当时不理解为什么 ...
- proxifier 注册码 +电脑全局代理设置
L6Z8A-XY2J4-BTZ3P-ZZ7DF-A2Q9C(Portable Edition) 5EZ8G-C3WL5-B56YG-SCXM9-6QZAP(Standard Edition) P4 ...
- matlab 与 modelsim 联调 cic抽取滤波器
注:本设计的参数为:D=2,R=5,N=3:时钟频率为50mhz,输入信号为有符号8位,根据公式bmax=bin+N*log(2,R*D):可以得到bmax=18: 1,cic抽取滤波器原理 网上资料 ...
- 【ftp】服务器的链接命令
1. 连接ftp服务器 格式:ftp [hostname| ip-address] a)在Linux命令行下输入: ftp 192.168.1.1 b)服务器询问你用户名和密码,分别输入用户名和相应密 ...
- mysql5.6.11安装
下面详细介绍5.6版本MySQL的下载.安装及配置过程. 图1.1 MySQL5.6 目前针对不同用户,MySQL提供了2个不同的版本: Ø MySQL Community Serve ...
- vue router 传参 获取不到query,params
千万要注意,获取query/params 是this.$route.query 不是this.$router.query!!!
- cookie跨站脚本漏洞解决方案
近日项目碰到一个跨脚本注入的问题: 这安全测评工具也是厉害了,直接将脚本注入到cookie里头,以前没有碰到这样的情况. 之前写过一篇文章过滤跨脚本注入的问题.<浅谈XSS攻击原理与解决方法&g ...
- python 函数名,闭包
1.函数名字的应用 函数名是什么? 函数名是函数的名字,本质:变量,特殊变量 函数名+() ———>执行此函数: 2.函数名的赋值: def func2(): print(44) f = fun ...
- fuser
fuser 命令,查看正在被占用的文件: