美文网首页小程序微信小程序从基础到进阶程序员
为头脑王者微信小程序做一个外挂

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

作者: gaoshine | 来源:发表于2018-01-28 00:40 被阅读890次

    0.背景

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

    Screen Shot 2018-01-28 at 00.05.38.png

    1.思路

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

    1. 截取手机的屏幕 ,获取题目的图片
    2. 裁剪图片,获取题目部分的图片
    3. 图片通过OCR识别成文字,这个就是题目关键字
    4. 把题目关键字通过搜索引擎查询,把查询结果显示出来
    截取手机的屏幕 ,获取题目的图片 裁剪后的图片,只有题目 OCR返回文字 就是题目关键字 Screen Shot 2018-01-28 at 01.00.27.png 通过搜索引擎查询出结果

    2.运行

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

    3.总结

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


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

    4.代码

    '''
    这款头脑王者微信小程序,最近是特别的火,借助微信朋友圈的这把火烧的得更旺了
    我们周末的一个weekend小项目,做了一个 头脑王者小助手
    '''
    
    
    import os
    from PIL import Image
    from aip import AipOcr  # 引入baidu文字识别OCR SDK
    from urllib.parse import quote
    
    # 定义常量
    APP_ID = '你的APP_ID'
    API_KEY = '你的API_KEY'
    SECRET_KEY = '你的SECRET_KEY'
    
    
    # 读取图片
    def get_file_content(filePath):
        with open(filePath, 'rb') as fp:
            return fp.read()
    
    
    '''
    适用于安卓手机,通过adb命令截屏,并把图片传给电脑
    '''
    
    
    def screencap():
        mcom = "adb shell /system/bin/screencap -p /sdcard/mscreen.png"
        os.system(mcom)
        mcom = "adb pull /sdcard/mscreen.png ./mscreen.png"
        os.system(mcom)
    
    
    '''
    裁剪图片,只把题目部分的截图保存
    
    '''
    
    
    def cropimg():
        im = Image.open("mscreen.png")
        img_size = im.size
        print("图片宽度和高度分别是{}".format(img_size))
        x = 50
        y = 400
        w = 650
        h = 200
        region = im.crop((x, y, x+w, y+h))
        region.save("screen.png")
        return "screen.png"
    
    
    def ocr(imgUrl):
        # 初始化ApiOcr对象
        aipOcr = AipOcr(APP_ID, API_KEY, SECRET_KEY)
        # 调用通用文字识别接口
        result = aipOcr.basicGeneral(get_file_content(imgUrl))
    
        print(result['words_result_num'])
        s = ''
        for i in range(result['words_result_num']):
            s += result['words_result'][i]['words']
        print(s)
        return s
    
    
    def baidu(word):
        url = "http://www.baidu.com/s?wd=%s" %  quote(word)
        print(url)
        import webbrowser
        webbrowser.open(url)
    
    
    
    if __name__ == "__main__":
    
        # 通过adb命令截屏,并把图片传给电脑
        #screencap()
    
        # 裁剪图片,只把题目部分的截图保存
        url = cropimg()
    
        # 调用baidu通用文字识别接口,返回识别的文字
        s = ocr(url)
        print(s)
        # 打开默认浏览器,百度一下获取的题目内容
        baidu(s)
    
    
    

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

    相关文章

      网友评论

        本文标题:为头脑王者微信小程序做一个外挂

        本文链接:https://www.haomeiwen.com/subject/mlaoaxtx.html