溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

酷! 程序員用Python帶你玩轉(zhuǎn)沖頂大會(huì)

發(fā)布時(shí)間:2020-10-20 03:17:11 來源:腳本之家 閱讀:141 作者:lijiao 欄目:開發(fā)技術(shù)

2018年1月3日,王思聰被迫動(dòng)用自己的微博,為一個(gè)誕生不到10天的App打了廣告,“每天我都發(fā)獎(jiǎng)金,今晚9點(diǎn)就發(fā)10萬”。對(duì)他而言,這天的微博并非生日宴會(huì),而是戰(zhàn)場。王思聰?shù)囊粍t微博開啟了“全民競答”類APP的爆紅之路。

酷! 程序員用Python帶你玩轉(zhuǎn)沖頂大會(huì)

一時(shí)間,直播巨頭們都跟上“王校長”的節(jié)奏,“沖頂大會(huì)”之外,映客旗下的“芝士超人”、今日頭條旗下的“百萬英雄”和花椒直播旗下的“百萬作戰(zhàn)”紛紛亮相,每天狂撒百萬現(xiàn)金。

酷! 程序員用Python帶你玩轉(zhuǎn)沖頂大會(huì)

“沖頂大會(huì)”、“芝士超人”、“百萬英雄”等知識(shí)競答游戲火了,獎(jiǎng)金數(shù)額也從最初的人民幣5萬、10萬漲到了100萬、101萬。

為了能夠全部答對(duì)12道題,平分?jǐn)?shù)額如此龐大的獎(jiǎng)金池,參賽者開始想方設(shè)法提高自己答題的正確率。

正如節(jié)目主持人介紹的一樣,許多答題者開始尋找身邊的朋友共同答題,以求覆蓋到更多類型的知識(shí)點(diǎn),提高通關(guān)的幾率。

各種各樣的微信、QQ答題群誕生,每個(gè)人都在群聊里分享自己認(rèn)為正確的答案。

酷! 程序員用Python帶你玩轉(zhuǎn)沖頂大會(huì)

讓你猜不到的是,答題游戲居然也有外掛!

為了能夠全部答對(duì)12道題,平分?jǐn)?shù)額如此龐大的獎(jiǎng)金池,參賽者開始想方設(shè)法提高自己答題的正確率。

已經(jīng)有程序員設(shè)計(jì)了“輔助程序”,用于快速檢索答案。

酷! 程序員用Python帶你玩轉(zhuǎn)沖頂大會(huì)

這個(gè)用Python程序可以修剪并識(shí)別圖片中的文字內(nèi)容(問題和選項(xiàng)),然后通過百度進(jìn)行搜索關(guān)鍵字出現(xiàn)的次數(shù),最后將統(tǒng)計(jì)的信息展示出來。這樣一來,答題者就可以根據(jù)統(tǒng)計(jì)數(shù)據(jù)來選擇相應(yīng)的答案,極大提高了答題的正確率。

那么程序員到底應(yīng)該如何玩呢?

首先用 WDA 來獲取屏幕截圖。WDA 本是 Facebook 開發(fā)的一套 iOS 測試框架,前幾天看見大家都用來做微信“跳一跳”的外掛,便特意去了解了一下,發(fā)現(xiàn)也能用在沖頂大會(huì)上。

之后 crop 出題目所在的位置(可能需要適配手機(jī)屏幕),然后調(diào)用開放的 OCR 接口讀取出文字文本,最后調(diào)用搜索引擎,就可以達(dá)到之前 gif 圖的效果。這套環(huán)境是 iOS + Mac,如果是安卓應(yīng)該有更方便的方法。

其實(shí)最初的想法是希望搜索+選擇答案全部自動(dòng)化完成的,思路是 OCR 題目和候選答案,組成三個(gè)組合扔到百度或谷歌里搜索,然后哪個(gè)組合的結(jié)果出現(xiàn)次數(shù)最多就選擇哪個(gè)。試了幾個(gè)問題后發(fā)現(xiàn)并不是這樣,比如上面圖片的“駱駝的駝峰是存儲(chǔ)什么的?”,可能多數(shù)人都會(huì)認(rèn)為是水,因此出現(xiàn)的次數(shù)最多,其實(shí)是錯(cuò)誤答案。

最后還有兩個(gè)痛點(diǎn):

免費(fèi) OCR 接口調(diào)用次數(shù)有限,所以不能一直去截屏識(shí)別,只能等題目出現(xiàn)時(shí)運(yùn)行程序。
官方也很套路,有的問題是沒法搜索的。比如這種:

酷! 程序員用Python帶你玩轉(zhuǎn)沖頂大會(huì)

最后附上代碼:

# python3
import wda
import io
import urllib.parse
import webbrowser
import requests
import time
import base64
from PIL import Image

c = wda.Client()
# 百度OCR API
api_key = ''
api_secret = ''
token = ''


while True:
  time.sleep(0.5)
  c.screenshot('1.png')
  im = Image.open("./1.png")
  region = im.crop((75, 315, 1167, 789)) # iPhone 7P
  imgByteArr = io.BytesIO()
  region.save(imgByteArr, format='PNG')
  image_data = imgByteArr.getvalue()
  base64_data = base64.b64encode(image_data)
  r = requests.post('https://aip.baidubce.com/rest/2.0/ocr/v1/general_basic',
           params={'access_token': token}, data={'image': base64_data})
  result = ''
  for i in r.json()['words_result']:
    result += i['words']
  result = urllib.parse.quote(result)
  webbrowser.open('https://baidu.com/s?wd='+result)
  break

(代碼來源:https://livc.io/blog/204)

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI