爬虫之所以火
因为懒他可以代替我们做很多的事情
例如你有一个文件夹的图片需要翻译,一个一个的拖进搜狗图片翻译,再转回来将图片另存,再改名字,再拖下一个,再......太庸俗了!简直戕贼身心。对于这种情况,爬虫会助你一臂之力。
好了,废话不多说,直入主题,正如标题所讲。当你在玩英文——全英文——还不支持中文的游戏时,如果有一个程序可以一直在你旁边帮你翻译那该多好,但有几点需要解决:
1.全截屏(或部分截屏)
2.图片翻译
3.图片显示
貌似很简单,其实确实挺简单的
1.截屏
说到图片操作,就不得不提一Pillow库了,这是一个第三方库,需要额外安装,简略步骤:
命令提示符中输入“pip install pillow”十有九会成功,如果你是哪十分之一没下载成功,去百度搜索寻求解决方案。
使用ImageGrab来截屏,方法如下:
from PIL import ImageGrab
box = (x1,y1,x2,y2)
im = ImageGrab.grab(box)
im.save('a.png')
x1,y1是图片左上角的坐标
x2,y2是图片右下角的坐标
可以成功导出名为a.png的图片
如果你不知道电脑上的坐标,可以按一下右上角‘PrtScrSysrq键’截屏,打开“图画”
确认画布比屏幕小后(建议缩到最小),点击粘贴,选中铅笔,这时铅笔所指到的地方的坐标就会显示在左下角,左下角往右数第三框时整个画布的大小(我的是1400,900)
2.图片翻译
当然要用到爬虫啦,这里我们用搜狗翻译当工具,顺带提一句,搜狗翻译是真的很好用,很适合在看的是学生的读者使用。
操作后的Network(网络):
可见data由这三样数据构成
知识点:
遇到传文件的请求时,requests的post有一个files参数
因此可以这样构建请求:
import requests
url = 'https://fanyi.sogou.com/api/transpc/picture/upload'
files = {'fileData': open('a.png','rb')}#单独创建文件字典
data = {
'fuuid': '027d63fb-be3d-4a3c-b8d6-6e20c74e3b1c',
'extraData': '{"from":"auto","to":"zh-CHS","imageName":"a.png"}'英译中的写法
}
headers = {
'Cookie': '您的Cookie',
'User-Agent': '您的User-Agent'
}
r = requests.post(url=url, data=data, headers=headers, files=files)
如果这个操作你理解了,一个大坎你就跨过去了
用上面的代码翻译图a.png
a.png:
响应如下:
{"status":0,"info":"success","data":{"result_type":"text_image","imageId":"07f5e3111f3b49cb99f4d98f91f104cf","zly":"zly","pic":"/9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAYEBQYFBAYGBQYHBwYIChAKCgkJChQODwwQFxQYGBcUFhYaHSUfGhsjHBYWICwgIyYnKSopGR8tMC0oMCUoKSj/2wBDAQcHBwoIChMKChMoGhYaKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCj/wAARCAEfATEDASIAAhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQAAAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6e