用户
 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,登录网站

小程序社区 首页 教程 查看内容

为头脑王者微信小程序做一个外挂

Rolan 2018-1-29 00:21

背景每逢周六,如果手头项目不紧,有空闲的话,大家会酝酿一个weekend的小项目, 这个周六下午,大家聊起了"头脑王者"这个微信小程序,大家讨论的不亦乐乎,忽然有人提议为这款游戏做一款问题查询辅助类的程序,算不上外挂, ...

背景

每逢周六,如果手头项目不紧,有空闲的话,大家会酝酿一个weekend的小项目, 这个周六下午,大家聊起了"头脑王者"这个微信小程序,大家讨论的不亦乐乎,忽然有人提议为这款游戏做一款问题查询辅助类的程序,算不上外挂,姑且叫助手之类的吧. 
离下班还有一个小时,于是乎大家开干...... 


1.思路

既然开始了,马上就有了思路:

截取手机的屏幕 ,获取题目的图片 
裁剪图片,获取题目部分的图片 
图片通过OCR识别成文字,这个就是题目关键字 
把题目关键字通过搜索引擎查询,把查询结果显示出来

截取手机的屏幕 ,获取题目的图片 

裁剪后的图片,只有题目 

OCR返回文字 就是题目关键字 

通过搜索引擎查询出结果

2.运行

因为是周末项目,只有一个小时的时间,做的比较匆忙,算是抛砖引玉吧. 
本来像抓取过来搜索结果,再做正则表达式处理,没想到遇到了百度https加密的小坑,就直接采用webbrowser.open的方式打开. 
实测手机出现题目,执行程序大概2秒钟就可以返回查询结果,这个要远远高于你手工的操作,程序自动处理手机截屏,题目关键字的OCR识别,自动打开浏览器并查询关键字,全部自动化了,希望能在"头脑王者"过关斩将中助你一臂之力!

3.总结

作为一个weekend的练手项目,主要是提高我们程序人员的兴趣,扩大大家的知识面,这个提升大家的开发水平有很大帮助. 
另外,我们程序猿们不仅有寻找BUG的烦恼,也有享受编程的快乐和生活的乐趣, Hello, World!

两枚程序猿祝你周末愉快!

4.代码

这款头脑王者微信小程序,最近是特别的火,借助微信朋友圈的这把火烧的得更旺了 
我们周末的一个weekend小项目,做了一个 头脑王者小助手

  1. import os
  2. from PIL import Image
  3. from aip import AipOcr # 引入baidu文字识别OCR SDK
  4. from urllib.parse import quote
  1. # 定义常量
  2. APP_ID = '你的APP_ID'
  3. API_KEY = '你的API_KEY'
  4. SECRET_KEY = '你的SECRET_KEY'
  1. # 读取图片
  2. def get_file_content(filePath):
  3. with open(filePath, 'rb') as fp:
  4. return fp.read()

适用于安卓手机,通过adb命令截屏,并把图片传给电脑

  1. def screencap():
  2. mcom = "adb shell /system/bin/screencap -p /sdcard/mscreen.png"
  3. os.system(mcom)
  4. mcom = "adb pull /sdcard/mscreen.png ./mscreen.png"
  5. os.system(mcom)

裁剪图片,只把题目部分的截图保存

  1. def cropimg():
  2. im = Image.open("mscreen.png")
  3. img_size = im.size
  4. print("图片宽度和高度分别是{}".format(img_size))
  5. x = 50
  6. y = 400
  7. w = 650
  8. h = 200
  9. region = im.crop((x, y, x+w, y+h))
  10. region.save("screen.png")
  11. return "screen.png"
  12. def ocr(imgUrl):
  13. # 初始化ApiOcr对象
  14. aipOcr = AipOcr(APP_ID, API_KEY, SECRET_KEY)
  15. # 调用通用文字识别接口
  16. result = aipOcr.basicGeneral(get_file_content(imgUrl))
  17. print(result['words_result_num'])
  18. s = ''
  19. for i in range(result['words_result_num']):
  20. s += result['words_result'][i]['words']
  21. print(s)
  22. return s
  23. def baidu(word):
  24. url = "http://www.baidu.com/s?wd=%s" % quote(word)
  25. print(url)
  26. import webbrowser
  27. webbrowser.open(url)
  28. if __name__ == "__main__":
  29. # 通过adb命令截屏,并把图片传给电脑
  30. #screencap()
  31. # 裁剪图片,只把题目部分的截图保存
  32. url = cropimg()
  33. # 调用baidu通用文字识别接口,返回识别的文字
  34. s = ocr(url)
  35. print(s)
  36. # 打开默认浏览器,百度一下获取的题目内容
  37. baidu(s)

注意:本代码的百度API需要换成你自己的API参数,这个不费事也就分分钟的事情申请一个就OK.

鲜花
鲜花
鸡蛋
鸡蛋
分享至 : QQ空间
收藏
原作者: gaoshine 来自: 简书

相关阅读

  • wxbkaishui34 2018-2-3 22:30
    好麻烦 直接服务器抓包不就好了 。。。