python脚本开发_python的第一个脚本的编写

我写的第一个python 脚本是一个用来提取动态网页的数据,尽行计算,并且提交的。

网页的要求很明显,就是给了一个算式。让提交者在1.5S内提交出来。由于这个算是过于庞大,所以直接算?不存在的。

脚本的功能在这个时候就体现出来了。

在这次的做题过程中我遇到的问题有好多。首先是我的编写平台pycharm,因为这是我的第一个Python脚本,也是我的第一个程序,所以对于pycharm的使用相当的不熟悉。然后就是在引用requests库的时候。上面提示没有这个库,但是我明明已经用pip install requests安装了啊。很可惜,pycharm的使用不是这样子的,而是在它的setting里面进行的安装。这是第一个问题,我解决了。

然后就是用的requests.get(url)获得的数据,然后是转换成了text文本的格式,也就是将网页的内容全部转换成了字符的形式,下面这一步其实挺简单的,也很自然,就是怎么样把字符提取出来,我是先用的

nPos = r.text.index('exp')

print(nPos)

也就是查找到了对应的id是exp的那些数字所在的地方。

m1=m[515:523]

m2=m[524:532]

m3=m[533:540]

m4=m[541:549]

提取出来了这些数字对应的字符串,

然后就是使用的NUM()函数,把这些字符串里面的数字(字母)摘出来,

再用int()把字符变量转换成数字,要不然数学计算是无法进行的。

计算出来answer

这也是对应的变量的提交方向,下面是我遇到的最大的问题,就是我一开始在提交的时候用的是构造字典

com={'answer':answer}

succeed=requests.get(url,params=com)

print(succeed.text)

我本以为这就完了,

但是我没有考虑到两次提交带来的cookie的值是不一样的(学长说使用模拟抓包可以抓取自己编写的脚本的包使用的是proxies模块),所以就是说这是一个重新的请求,也就是第一次请求得到的数据已经

不同于这一次请求的到的数据了,这是两次独立的请求。

然后,最终的解决方案是。。。

在一开始的时候使用requests.Session()这样的话,就可以保持在一个session()回话里面了,所以以后的时候可以在一开始就直接用frist=requests.Session()

然后就是很自然的就转换到了含有flag的里面了。这道题终于完成了

补充:

(url参数分为两种,输入参数和查询参数,例如下面这个url:

https://www.google.com.hk:8080/home/search;p1=12432?neww=abc#1234

其中分号后面的就是输入参数,也就是urlparse取出的params

问号后面的参数就是查询参数,也就是urlparse取出的query

作者:杨星

链接:https://www.zhihu.com/question/26161977/answer/97267537

来源:知乎

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值