一、项目需求

每周从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系统,生成报表,然后发送邮件给指定人员的更多相关文章

  1. python定时执行方法

    1  time.sleep import time for i in range(5): print(i) time.sleep(10) 2 用shed import time import sche ...

  2. python 奇淫技巧之自动登录 哔哩哔哩

    前言 嘿,各位小伙伴好呀,今天要带来点什么干货呢,就从我的实际开发中来给大家带来一个案例吧,如何自动登录 哔哩哔哩 接到老大通知,让我自动写一个自动登录 哔哩哔哩 的脚本,我当然是二话不说直接开怼,咱 ...

  3. python定时执行详解

    知识点 1. sched模块,准确的说,它是一个调度(延时处理机制),每次想要定时执行某任务都必须写入一个调度. (1)生成调度器:s = sched.scheduler(time.time,time ...

  4. 用Golang让自己的电脑自动登录“上网管理”系统

    用Golang让自己的电脑自动登录 1.缘起 大天朝的网络一般都是只对某些人开放的.上行下效,同样的措施也作用在我们的教育网上.我想不出来,为什么很多领导的总有这样的恶趣味(如果做的到,他们恨不得监控 ...

  5. 【转】【Python】Python3爬虫实现自动登录、签到

    工具:Fiddler 首先下载安装Fiddler,这个工具是用来监听网络请求,有助于你分析请求链接和参数. 打开目标网站:http://www.17sucai.com/,然后点击登录 好了,先别急着登 ...

  6. Python案例之QQ空间自动登录程序实现

    不多说,直接上干货! 工具选择: 电脑系统:win7,32 位,下面第二部安装SetupTools时注意系统版本要求: Python: 2.7.11,  相信只要是2.7的就可以实现: Seleniu ...

  7. Python定时执行脚本

    最近测试hbase,老发现服务挂掉,自己不能及时发现,想了想,写了个脚本,让脚本每个小时执行一次,以便检测是否有服务挂掉,如果有服务挂掉,及时启动 import os import datetime ...

  8. python+selenium+webdriver+BeautifulSoup实现自动登录

    from selenium import webdriverimport timefrom bs4 import BeautifulSoupfrom urllib import requestimpo ...

  9. 用python实现自动化登录禅道系统 设置定时器自动执行脚本

    由于各种原因,我想试下用python实现自动登录禅道系统,并且每天定时执行.(本人第一次接触自动化,在大佬眼中门槛都没摸到的类型) 首先缕清思路: 1.实现自动登录禅道系统,用selenium实现2. ...

随机推荐

  1. WPF XMAL获取元素的父元素,子元素

    /// 获得指定元素的父元素 /// </summary> /// <typeparam name="T">指定页面元素</typeparam> ...

  2. 关于ip层的作用网址链接

    http://rabbit.xttc.edu.cn/rabbit/htm/artical/201091113054.shtml

  3. 【spring源码学习】spring的AOP面向切面编程的实现解析

    一:Advice(通知)(1)定义在连接点做什么,为切面增强提供织入接口.在spring aop中主要描述围绕方法调用而注入的切面行为.(2)spring定义了几个时刻织入增强行为的接口  => ...

  4. LG4360 [CEOI2004]锯木厂选址

    题意 原题来自:CEOI 2004 从山顶上到山底下沿着一条直线种植了 n 棵老树.当地的政府决定把他们砍下来.为了不浪费任何一棵木材,树被砍倒后要运送到锯木厂. 木材只能朝山下运.山脚下有一个锯木厂 ...

  5. linux(centos7) 安装nginx

    linux(centos7) 安装nginx 1.14(stable) 版本 Nginx配置文件常见结构的从外到内依次是「http」「server」「location」等等,缺省的继承关系是从外到内, ...

  6. nginx学习资源

    在了解nginx的时候 看到的一些资源: https://www.cnblogs.com/EdwinChan/p/8350984.html http://tengine.taobao.org/book ...

  7. python 安装相关命令-汇总

    Microsoft Windows [版本 10.0.14393] (c) 2016 Microsoft Corporation.保留所有权利. C:\Windows\system32>pyth ...

  8. MVC FileDownLoad

    public ActionResult MatDownload() { string ShopId = Session["ShopId"].ToString(); var self ...

  9. os模块sys模块-sys.argv命令行参数

    提供对操作系统进行调用的接口 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 os.chdir("dirname") 改变当前脚本工作目录:相当于s ...

  10. Docker - Upgrade from 1.12 to 1.13

    引言 历经半年,docker的更新终于来了,看着新版本中各种诱人的新特性,我们也第一时间来尝试一下. 升级 之前一直使用的是1.12,所以这次尝试的是从原来的版本升级到新版本. 1. 更新 yum p ...