开发工具与关键技术:Python IDEL、Python
作者:曾浩源
撰写时间:2019年08月07日
写一个小功能来模拟搜狗翻译发送请求,让这个小功能拥有翻译的功能。
首先打开搜狗翻译,然后F12或右键选择检查,找到Network,再搜狗翻译内进行一次翻译,之后Name下就出现一堆东西,如:
![](http://imgsrc.baidu.com/forum/w%3D580/sign=b9b8cdd3990a304e5222a0f2e1caa7c3/e42f8854b319ebc4f3e2cf4e8c26cffc1f17166a.jpg)
看着大概也知道,出来translateV2、suggV2和translateV2ForPicSet其余都是一些图片,以上三个都是post请求,这里选择的是suggV2,它是释义而且传的数据也少所以选它了,至于其他两个,到时候自己试试吧。
从这里就可以知道了请求url地址(Requset URL),和所要传输的数据(From Data)
接下来就是将所要的内容赋予我们Python里的变量:
![](http://imgsrc.baidu.com/forum/w%3D580/sign=97ced0873aa85edffa8cfe2b795609d8/0a35560635fae6cd507612b601b30f2440a70fc2.jpg)
之后就是发送数据,但这是post请求,不是get请求,get请求直接拼接所要传输的数据就行了,而post请求要被编码为字节数据,所以我们要转编码。发送数据就是请求,和转编码它们需要我们在python内引用urllib模块,请求要urllib内的request(urllib.request 用于打开网址的可扩展库。)、转编码需要urllib内的parse(urllib.parse URL解析组件)
所以在最前面引入需要的模块![](http://imgsrc.baidu.com/forum/w%3D580/sign=e592d752c7ea15ce41eee00186023a25/c17eb6a95edf8db12dbac5b30723dd54574e7475.jpg)
在data赋值完成后,将data转码为utf-8,这要看别人网页的请求头是啥了,现在一般都是utf-8。
在Python中,我们通常使用urllib中的urlencode方法将字典编码,所以:
data = urllib.parse.urlencode(data).encode('utf-8')
编码完成后就可以直接使用urllib.request.urlopen()方法向要打开的url链接发送我们的数据data 了:
response = urllib.request.urlopen(url,data)
响应后,我们需要读取响应,再把它转码为utf-8
html = response.read().decode('utf-8')
读取到之后,但它是字符串形式:
![](http://imgsrc.baidu.com/forum/w%3D580/sign=7825cf40d733c895a67e9873e1127397/6a1d138ea0ec08fa263cab7057ee3d6d54fbdacd.jpg)
发现它很像是一个字典,其实就是字典的字符串格式,我们现在就需要把它从字符串转为字典,这里需要引用一个模块,json模块。
在代码最上面的引用代码后加入
import json
获取到响应回来的内容赋值给html后,转为字典如下:
target=json.loads(html)
输出:
![](http://imgsrc.baidu.com/forum/w%3D580/sign=f8c1d91cbcfb43161a1f7a7210a64642/100e83e83901213f7da2f70b5ae736d12e2e9570.jpg)
我们需要的是 键:data的值,它的值是一个列表,需要第一个也就是索引0,列表里又是字典,需要的是 键:v的值
所以:![](http://imgsrc.baidu.com/forum/w%3D580/sign=fc296bf69eef76c6d0d2fb23ad14fdf6/4b96563e8794a4c264ea5efc00f41bd5ac6e393f.jpg)
作者:曾浩源
撰写时间:2019年08月07日
写一个小功能来模拟搜狗翻译发送请求,让这个小功能拥有翻译的功能。
首先打开搜狗翻译,然后F12或右键选择检查,找到Network,再搜狗翻译内进行一次翻译,之后Name下就出现一堆东西,如:
![](http://imgsrc.baidu.com/forum/w%3D580/sign=b9b8cdd3990a304e5222a0f2e1caa7c3/e42f8854b319ebc4f3e2cf4e8c26cffc1f17166a.jpg)
看着大概也知道,出来translateV2、suggV2和translateV2ForPicSet其余都是一些图片,以上三个都是post请求,这里选择的是suggV2,它是释义而且传的数据也少所以选它了,至于其他两个,到时候自己试试吧。
从这里就可以知道了请求url地址(Requset URL),和所要传输的数据(From Data)
接下来就是将所要的内容赋予我们Python里的变量:
![](http://imgsrc.baidu.com/forum/w%3D580/sign=97ced0873aa85edffa8cfe2b795609d8/0a35560635fae6cd507612b601b30f2440a70fc2.jpg)
之后就是发送数据,但这是post请求,不是get请求,get请求直接拼接所要传输的数据就行了,而post请求要被编码为字节数据,所以我们要转编码。发送数据就是请求,和转编码它们需要我们在python内引用urllib模块,请求要urllib内的request(urllib.request 用于打开网址的可扩展库。)、转编码需要urllib内的parse(urllib.parse URL解析组件)
所以在最前面引入需要的模块
![](http://imgsrc.baidu.com/forum/w%3D580/sign=e592d752c7ea15ce41eee00186023a25/c17eb6a95edf8db12dbac5b30723dd54574e7475.jpg)
在data赋值完成后,将data转码为utf-8,这要看别人网页的请求头是啥了,现在一般都是utf-8。
在Python中,我们通常使用urllib中的urlencode方法将字典编码,所以:
data = urllib.parse.urlencode(data).encode('utf-8')
编码完成后就可以直接使用urllib.request.urlopen()方法向要打开的url链接发送我们的数据data 了:
response = urllib.request.urlopen(url,data)
响应后,我们需要读取响应,再把它转码为utf-8
html = response.read().decode('utf-8')
读取到之后,但它是字符串形式:
![](http://imgsrc.baidu.com/forum/w%3D580/sign=7825cf40d733c895a67e9873e1127397/6a1d138ea0ec08fa263cab7057ee3d6d54fbdacd.jpg)
发现它很像是一个字典,其实就是字典的字符串格式,我们现在就需要把它从字符串转为字典,这里需要引用一个模块,json模块。
在代码最上面的引用代码后加入
import json
获取到响应回来的内容赋值给html后,转为字典如下:
target=json.loads(html)
输出:
![](http://imgsrc.baidu.com/forum/w%3D580/sign=f8c1d91cbcfb43161a1f7a7210a64642/100e83e83901213f7da2f70b5ae736d12e2e9570.jpg)
我们需要的是 键:data的值,它的值是一个列表,需要第一个也就是索引0,列表里又是字典,需要的是 键:v的值
所以:
![](http://imgsrc.baidu.com/forum/w%3D580/sign=fc296bf69eef76c6d0d2fb23ad14fdf6/4b96563e8794a4c264ea5efc00f41bd5ac6e393f.jpg)