小程序模板网

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

发布时间:2018-05-04 15:54 所属栏目:小程序开发教程

背景

每逢周六,如果手头项目不紧,有空闲的话,大家会酝酿一个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.  
  2.  
  3. def screencap():
  4. mcom = "adb shell /system/bin/screencap -p /sdcard/mscreen.png"
  5. os.system(mcom)
  6. mcom = "adb pull /sdcard/mscreen.png ./mscreen.png"
  7. os.system(mcom)
  8.  

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

 

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

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



易优小程序(企业版)+灵活api+前后代码开源 码云仓库:starfork
本文地址:https://www.eyoucms.com/wxmini/doc/course/24232.html 复制链接 如需定制请联系易优客服咨询:800182392 点击咨询
QQ在线咨询