4月初,班主任的某次周会议上,华华关切的问了一下:最近班主任们有什么难题吗?就是花费了你们大部分时间的工作!我们Python天团可以帮你们解决问题。

班主任大主管星星说:有。目前有一个大难题。我们每天都会对进群的学员登记他的真实姓名,联系方式,地址,目前薪资,期望薪资以及为什么会选择柠檬班~然后对于所有学生的缴费情况都会去腾讯进行查验,确保学生有上课的权限,并且每次会提前提醒分期的同学按时缴纳分期费用,防止逾期而没有上课的权限。

华华:这不是so easy的事情吗?

星星:不easy,首先学生并不是一天来的,而是每天不同的班级都会有不同的学员入学,那么就要分类整理。第二:每个学生的缴费信息方式不一样,有的是分期,有的是全款,有的是微信账号购买课程,所以为了把入群的qq和这些学费信息核对起来,真的是非常的困难!

华华:这好办,我帮你搞定(当然那是不可能的),会后找到了Python天团的主管:小简大佬。小简大佬,班主任团队最近遇到了一个比较繁琐的问题,就是统计学生的信息比较费时,可以帮忙用自动化搞定吗?

简佬(小简大佬的简称):好的呀,有需求吗?我们团队的可优和雨泽可以帮忙做这个事情,你把需求搞定,我们最迟一周内交付,毕竟我们还有自动化测试和测试开发以及公开课的任务在身。 有Python天团的强有力支撑,那么就可以开始行动了!

PART 1:整理需求

于是:华华联合星星,疏导了班主任的工作流程以及数据来源,整理出了一份需求。(各位亲爱的VIP学员们,你们的服务都来自于班主任的不辞劳苦!)

关于学员信息统计:

包含了如下图所示的一些信息

其中QQ来自QQ群,微信订单来自柠檬班内部的CRM系统,剩余的信息来自柠檬班的学员信息管理后台(由学员在柠檬班提供的表单上自行填写),经过几轮分析,确定数据来自这3个不同的地方。

关于学生缴费信息统计:(这关系到学员是否有上课权限,是否会错过上课时间,非常重要!)

但是这个信息会有2个问题: 1)如果学生是QQ报名的,那么可以直接根据QQ去统计信息。

2)如果学生是微信报名的,那么需要根据加入班级群的QQ去CRM系统里面找到对应的微信号,然后进行QQ微信匹配后再去腾讯课堂查询,比如说Python17群学员的QQ是:1248***816(保护学生隐私,匿了中间三位数),是通过微信报名的,那么在CRM系统里面的微信账号是:144115213097282684,我们在腾讯课堂后台只能通过这个微信号才能唯一查询到支付信息,如下所示:

3)如果学生是分期的,那么还要点击到分期的详情页去查看,分期的支付状态并登记好之后几期分期的支付时间,好定期对学员进行提醒,以免逾期。比如说Python17期某位学员的QQ是:792***306,那么查询到分期订单如下所示:

我们需要点击"分期明细”,进入到分期的详情页里面去,才能看到学生的明确支付信息以及每一期的最后支付时间,如下所示:

PART 2:编写脚本

需求整理完毕后,图文并茂的交给了简佬,当然part1部分的是简单的描述,尽量让大家可以看的明白点,比较复杂的就不写出来了! 简佬就开始分发任务:可优大佬负责学生缴费信息的统计脚本,雨泽大佬负责学员信息统计脚本,至于具体的实现过程,当然要跟大家分享一下!由华华来进行文字整理,因为华华在这个过程中充当了班主任和Python天团的桥梁和需求整理者。

关于学员信息统计的脚本实现方式:

1:首先从对应班集体的QQ群里导出学员的Q信息 2:然后从柠檬班内部的CRM系统里面导出学员的订单信息 3:两部分信息都保存至xlsx的文件里面,然后利用Python的openpyxl第三方库对两份数据进行比对,对学员是微信报名的信息与QQ进行匹配,最后完成的第一步效果如下所示:

4:然后根据学员的QQ信息,利用Python的Python-mysql-connector第三方库进行数据库查询,获取到学员的详细信息,如下所示:

脚本的话~~也截图小小的看看,部分代码,并不完整哦!学完柠檬班的Python自动化,你也可以!

关于学员缴费信息统计的脚本实现方式:

1:利用学生信息统计的结果进行查询,如果QQ查询不到,就用QQ对应的微信号去进行查询

2:如果是全款,那么就直接登记信息,如果是分期,就登记分期链接,后期再单独进行分期详细信息的统计与登记。

3:以上两步是非常清晰的,实现方式无外乎就是web页面元素的定位,方式有多种,xpath css或id,但是这个脚本,有两个亮点要跟大家分享下,希望大家以后遇到这个问题也可以用类似的方法去处理。

亮点一:查询之前先固定查询的条件

这里有两个显式的条件需要固定,一个是时间,我们只查询2019年1月1号开始的订单,那么这里就设计到日历的固定于选择:

页面的HTML源码如下所示:

我们可优大佬实现的方式是:

另外一个需要固定的条件是:课程包名称,这个是非selected控件,经过观察是支持模糊查询,并且需要从模糊查询的结果里面选择对应的下拉元素才可以生效的! 页面的HTML源码如下所示:

我们可优大佬实现的步骤是:先输入查询的课程条件(尽量可以唯一确定到唯一一个元素,然后选择下拉框的第一个元素,第0个元素显示的是"”全部"”),比如我们输入的是:python全栈自动化测试工程师第7-19期,那么下拉框就会显示可以选择的课程包名称,实现代码如下:

效果如下所示:

我们通过代码选择下拉列表的第一个元素,然后神奇的事情就发生啦!后面出现了隐藏元素,班级!

如下所示:

那么接下来就是选择班级,但是我们的查询班级下拉框也是非selected的,而且不支持输入只能从下拉元素中选择,页面的HTML源码如下所示:

我们实现的代码如下所示:

至此查询的难题已经全部实现,除了这里有点浪费时间,其他的都非常简单!

亮点二:利用正则匹配分期的数据

学习自动化,不仅仅要学习Python编程能力还需要学习其他的知识,比如说正则!而且这些在柠檬班自动化的授课里面全都有!这里截取部分代码,仅供参阅!

这个过程从构思到实现,都是在工作日时间实现的,5月1号,此项目正式上线!并且已经部署到班主任专用的电脑上的jenkins上!这样可以定时的去跑任务啦!班主任也可以开始利用Python来武装自己了!这个年代,不学点自动化,都不好意思说自己是Python班的班主任啦!

如果最近你发现班主任们变美了,心情也美美哒,每天跟你说话都是元气满满的,那么一定是因为Python给他们工作减负,他们多了时间化妆和休息!

有兴趣的同学可以多多关注柠檬班的Python自动化课程,可以找专业的Python自动化辅导员来领取专业的学习资料! 柠檬班等你很久了,特意为你准备了一波自动化测试秘籍,助你突破薪资技能瓶颈!

包括 Jmeter、Python编程、Selenium、unittest+Http技术+ddt;appium自动化;还有自动化面试题,以及项目案例分享。有兴趣的可以加我哦,免费送!

日常办公会用到的python模块-Python如何去实际提高工作的效率?也许这个会有用!...相关推荐

  1. 如何安装python模块, python模块安装失败的原因以及解决办法

    Python 模块安装 一. 打开命令提示符 win + R 输入 cmd 点击确定 或者win + S 搜索输入 cmd 二. 环境变量没有问题的前提下 输入安装命令 pip install 模块名 ...

  2. 【Python】分享几个简单易懂的Python技巧,能够极大的提高工作效率哦!

    今天和大家来分享几个关于Python的小技巧,都是非常简单易懂的内容,希望大家看了之后能够有所收获. 01 将字符串倒转 my_string = "ABCDE" reversed_ ...

  3. python 模块(Module)和包

    阿里云大学人工智能学前小测验-Python测验 19.以下关于模块说法正确的是 A. 一个.py就是一个模块 B. 任何一个普通的xx.py文件可以作为模块导入 C. 模块文件的扩展名一定是 .py ...

  4. Python如何安装模块,python模块安装失败的原因以及解决办法

    前言 今天来给刚开始学习python的朋友讲解一下 如何安装python模块, python模块安装失败的原因以及解决办法 很多朋友拿到代码之后,就开始复制粘贴 --> 然后右键进行运行 结果就 ...

  5. python 模块 导入机制 模块搜索 Python包 发布python模块或程序

    python 模块 python模块:以.py结尾的代码文件.        顶层文件: 程序执行入口        模块文件1        模块文件2        模块文件3 在python中一 ...

  6. Python模块、包与面向对象综合案例

    目录 一.Python内置模块 1.什么是Python模块 2.模块的分类 3.模块的导入方式 4.使用import导入模块 5.使用from 模块名 import 功能名 ☆ from 模块名 im ...

  7. python模块手册_金字塔python开发手册

    python_API 基本方法 编写策略过程中所需要使用的基本函数.其中init和handle_bar是必须实现的两个方法,其余是可选择实现的方法. init (必须实现) init(context) ...

  8. maya python3_安装了Anaconda之后,Maya运行报错,Python 找不到 Maya 的 Python 模块

    以前Maya用的好好地,结果安装了Anaconda之后,maya启动以后,日志就会报错(如下),只能自主建模,不能打开以前创建的模型,也不能导入fbx,错误提示就是Maya找不到Python模块,在网 ...

  9. 日常办公会用到的python模块-新课介绍 | 用Python自动办公,做职场高手

    有一次廷聿给我看了他做的写字机器人,当时我就震惊了-- 类似这样懒到家的黑科技操作还有:每天早上8点-8点零5分之间随机自动打卡.自动发日报周报.邮件自动回复等等. 他把这些美名其曰「办公自动化」,并 ...

最新文章

  1. 崛起的Python,真的影响了76万人?
  2. mfc将文件内容引入编辑框_南开大学黄津辉教授团队联合加拿大麦克马斯特大学Ravi教授团队发表微型MFC水质传感器实际废水检测适用性的研究...
  3. MAC显示隐藏文件和文件夹
  4. SpringFox 3.0.0(包含springfox-swagger2-3.0.0)——无法访问/swagger-ui.html解决方案
  5. request.setCharacterEncoding(utf-8);
  6. 【华为云技术分享】如何拆分用户故事
  7. 离破产仅一步之遥的A站,还能挺过去吗?
  8. Java中this关键字的详解
  9. 声音就是你的武器!这样的攻防大赛你一定没有见过!
  10. linux设备数内核选项,linux内核设备树修改指南 / linux kernel device tree modify guide
  11. Blender制作火焰烟雾特效
  12. 大国的崛起:第二集:小国大业 荷兰
  13. 学校计算机社团面试问题及答案,社团二轮面试题目
  14. 程序员如何防止加班猝死
  15. Django框架学习记录(3)
  16. 计算机二级选择题题库
  17. 简述keepalived和其工作原理,keepalived搭建mysql高可用,vip飘逸,避免单点故障@xinxin
  18. Arduino使用TM1637四位数码管
  19. 使用 Arduino 和电位器控制直流电机速度
  20. 爱的时候,好好爱(转)

热门文章

  1. phantomjs 抓取html,javascript – 如何使用PhantomJS获取网站的HTML源代码
  2. php 文档在线查看器,Office Web Viewer 在线Office文档查看器API
  3. 反转 鼠标_梦幻西游:剧情反转?挖图挖出环装,在晶清加持下3000W到手
  4. Android 10 中有关限制非 SDK 接口的更新
  5. Kali国内源更新sources.list
  6. 开发日记-20190914 关键词 汇编语言王爽版 第六章
  7. 开发日记-20190626 Linux系统管理技术手册(第二版) 第一章习题答案(个人版)
  8. 开发日记-20190417 关键词 代码之间耦合度的一刀两断 (思路篇)
  9. python | ^ ~
  10. elasticsearch原理学习笔记