最近在业务办公区域对接需求的时候,发现了一位漂亮妹子的「苦恼」,简单来说就是她每天都得花一个多小时的时间去将整理好的数据录入到系统中。
小编推荐大家可以加我的扣扣群 735934841 ,免费领取Python学习资料
为什么是苦恼?
在进入正题前想聊下这位漂亮妹子「不要想多了,只是聊聊漂亮妹子的工作」,这位妹子虽然苦恼,但她做这样的事情已经一年多了,可谓毅力可嘉,有时候我就会觉得很奇怪,为什么不向产品提个需求,要求系统能支持批量导入的功能呢?
和漂亮妹子聊了下,原来曾几何时是提过类似的需求的,但因为优先级,上级重视度等等一系列问题,最后就不了了之了。
漂亮妹子一开始还比较有怨言的,久而久之也就麻木了,最后成为了一种习惯...
老实讲,对于这样的工作状态很不好,当你的工作逐步趋向于重复性操作时,你将很可能被替代。
于是,为了拯救这位漂亮妹子,利用pyhton搞了个脚本,能够自动读取excel中的数据提交表单,完成录入的操作,还提高了手动录入的准确性。
妹子惊呆了,奶茶双手奉上。
一些思路
其实类似这种录入系统,重复工作的场景真的有很多,有时候真的觉得很麻烦,尤其是遇到一些交互比较差,等待时间比较长的系统。
类似这种需求,基本上分这几个步骤:
分析页面
模拟登录
组装表单数据
循环提交
当然,你同时也要具备一些技能和知识:
python「以python举例,其他语言也可以实现」
http 协议
chrome调试「以chrome举例,其他浏览器也可以」
具体实现
由于是公司的系统,不太方便贴源码,这里记录下开发过程中的一些重点和坑。
首先是页面分析,这个就不多说了,利用好强大的Chrome就可以了。
这里重点说说模拟登录,往往这里是比较坑的,虽然内网系统相对来说比较简单,但还是碰到两种常用的登录校验模式。
一种是服务端会生成一个uuid的state,在提交登录时会校验传入的与服务端生成的是否一致。
这个时候你就要分析页面,通常会将state放在页面中
这样就比较容易了,利用python的Requests和BeautifulSoup来抓取并实现登录
session_requests=requests.session()
result=session_requests.get(login_url,headers=header)
tree=bs4.BeautifulSoup(result.text,'lxml')
state=tree.findAll('input',attrs={'name':'state'})[0]['value']
另一种是在登录时,前端将密码加密,加密后再进行提交,一开始没注意,坑了我一把,于是将这段代码翻译成python的写法
#密码加密
def deal_password(pwd):
key='asdrft745'
keylength=10
code=''
i=0
for item in pwd:
keyindex=i%keylength
code=code+chr(ord(item)^ord(key[keyindex:keyindex+1]))
i=i+1
bytesString = code.encode(encoding="utf-8")
return base64.b64encode(bytesString)
当你顺利模拟登录成功后,其实就已经成功过一大半了,后面无非就是组装数据,然后利用强大的Requests调用接口提交就可以了。
由于表单各不相同,代码也没什么好贴的,主要确认好接口数据格式,是form-data的,还是json的,做好相应的转换即可。
另外还是要伪造下header的,尤其是User-Agent,避免被误杀,或者被公司安全组查。
最后请求频次也需要注意下,千万不要用力过猛,把系统给搞挂了「虽然这种情况很少」。
最后的最后,贴下自己用到的模块,都是比较常用的,网上也有一大堆的说明教程,有兴趣的同学可以自行实战下,创新工作,告别重复劳动。
女神看完我的操作都惊呆了,以后再也不用花时间重复录入数据了,奶茶双手奉上啊,无形中为自己的形象分添色了不少,哈哈。