使用 Python 抓取力扣周賽 Guardian 和 Knight 門檻分

歷史分?jǐn)?shù) (最近三次結(jié)算)

日期 (G / K / A) Guardian Knight
2022/1/26
794 / 3970 / 15881
最高: 3489.204 int65536
最低: 2204.994 jelly97
最高: 2204.888
zhao-yang-24
最低: 1855.839 tan-ya-wen
2022/1/18
780 / 3902 / 15611
最高: 3489.204 int65536
最低: 2202.661
Raymond_YP
最高: 2202.449
tangyao0792
最低: 1854.801
yongyongyong
2022/1/13
775 / 3876 / 15507
最高: 3489.204 int65536
最低: 2201.923
charleswang2001
最高: 2201.813
love-a-wild-horse
最低: 1854.794 blue_k

更多歷史分?jǐn)?shù)

計(jì)算方式

力扣競(jìng)賽 - 勛章及成就規(guī)則
簡(jiǎn)而言之就是
Guardian1600 分以上的所有參與競(jìng)賽人員的前 5%
Knight1600 分以上的所有參與競(jìng)賽人員的前 25%

代碼

import re
import sys
from functools import cache

import requests as req

url = 'https://leetcode-cn.com/graphql'


# 分頁加載排名列表
@cache
def loadPage(page):
    query = "{\nlocalRanking(page:" + str(page) + ") {\nrankingNodes {\ncurrentRating\nuser {\nusername\n}\n}\n}\n}\n"
    retry = 0
    while retry < 3:
        resp = req.post(url=url, json={'query': query})
        if resp.status_code == 200:
            nodes = resp.json()['data']['localRanking']['rankingNodes']
            return [(int(nd['currentRating']), nd['user']['username']) for nd in nodes]
        else:
            retry += 1
    return None


# 根據(jù)用戶名獲取其個(gè)人主頁顯示的真實(shí)排名
# 排行榜上部分coder沒有真實(shí)排名幔翰,導(dǎo)致排行榜上的排名與個(gè)人主頁排名并不一致
# 實(shí)測(cè)LC的計(jì)算使用的排名是個(gè)人主頁的排名
@cache
def getUserRank(uid):
    operationName = "userContest"
    query = "query userContest($userSlug: String!){\n userContestRanking(userSlug: $userSlug){" \
            "\ncurrentRatingRanking\nratingHistory\n}\n}\n "
    variables = {'userSlug': uid}
    retry = 0
    while retry < 3:
        resp = req.post(url=url, json={
            'operationName': operationName,
            'query': query,
            'variables': variables
        })
        if resp.status_code == 200:
            ranking = resp.json()['data']['userContestRanking']
            score = None
            if ranking and 'ratingHistory' in ranking:
                s = ranking['ratingHistory']
                mth = re.search(r'(\d+(?:\.\d+)?)(?:, null)*]$', s)
                if mth:
                    score = mth.group(1)
            return (ranking['currentRatingRanking'], score) if ranking else (None, None)
        else:
            retry += 1
    return None, None


# 使用二分的方式獲取1600分以上的人數(shù)酣难,并使用 getUserRank 方法校準(zhǔn)
def get1600Count() -> int:
    l, r = 1, 1000
    while l < r:
        mid = (l + r) // 2
        scores = loadPage(mid)
        print(f'第 {mid} 頁:', scores)
        if not scores:
            return 0
        if scores[-1][0] < 1600:
            r = mid
        else:
            l = mid + 1
    scores = loadPage(l)
    print('校準(zhǔn)中...')
    while True:
        for (score, uid) in scores[::-1]:
            if score >= 1600:
                if ret := (getUserRank(uid)[0]):
                    return ret
        l -= 1
        scores = loadPage(l)


# 獲取指定排名的用戶,并使用 getUserRank 方法校準(zhǔn)
@cache
def getUser(rank):
    if rank <= 0:
        raise Exception('無效的排名')
    p = (rank - 1) // 25 + 1
    of = (rank - 1) % 25
    scores = loadPage(p)
    if of >= len(scores):
        raise Exception('無效的排名')
    while True:
        ranking = getUserRank(scores[of][1])[0]
        if ranking == rank:
            uid = scores[of][1]
            return getUserRank(uid)[1], uid
        if ranking > rank:
            # 特殊情況,排名很靠后時(shí)哟冬,順序是亂的
            for i in [0, 1, -1]:
                if i != 0:
                    scores = loadPage(p + i)
                for _, uid in scores:
                    r, s = getUserRank(uid)
                    if r == rank:
                        return s, uid
            raise Exception('校準(zhǔn)失敗')
        if not ranking or ranking < rank:
            of += 1 if not ranking else rank - ranking
        if of >= len(scores):
            p += of // len(scores)
            of %= len(scores)
            scores = loadPage(p)


total = get1600Count()
if not total:
    print('網(wǎng)絡(luò)故障')
    sys.exit()
print(f'1600 分以上共計(jì) {total} 人')

guardian = int(total * 0.05)
knight = int(total * 0.25)
g_first, g_last = getUser(1), getUser(guardian)
print(f'Guardian(top 5%): 共 {guardian} 名撇他,守門員 {g_last[0]} 分(uid: {g_last[1]}),最高 {g_first[0]} 分(uid: {g_first[1]})')
k_first, k_last = getUser(guardian + 1), getUser(knight)
print(f'Knight(top 25%): 共 {knight} 名识椰,守門員 {k_last[0]} 分(uid: {k_last[1]})入愧,最高 {k_first[0]} 分(uid: {k_first[1]})')
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子棺蛛,更是在濱河造成了極大的恐慌怔蚌,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件旁赊,死亡現(xiàn)場(chǎng)離奇詭異桦踊,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)终畅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門籍胯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人离福,你說我怎么就攤上這事杖狼。” “怎么了妖爷?”我有些...
    開封第一講書人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵蝶涩,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我絮识,道長(zhǎng)绿聘,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任次舌,我火速辦了婚禮熄攘,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘彼念。我一直安慰自己挪圾,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開白布国拇。 她就那樣靜靜地躺著洛史,像睡著了一般。 火紅的嫁衣襯著肌膚如雪酱吝。 梳的紋絲不亂的頭發(fā)上也殖,一...
    開封第一講書人閱讀 49,741評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音务热,去河邊找鬼忆嗜。 笑死,一個(gè)胖子當(dāng)著我的面吹牛崎岂,可吹牛的內(nèi)容都是我干的捆毫。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼冲甘,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼绩卤!你這毒婦竟也來了途样?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤濒憋,失蹤者是張志新(化名)和其女友劉穎何暇,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體凛驮,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡裆站,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了黔夭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片宏胯。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖本姥,靈堂內(nèi)的尸體忽然破棺而出肩袍,到底是詐尸還是另有隱情,我是刑警寧澤扣草,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布了牛,位于F島的核電站,受9級(jí)特大地震影響辰妙,放射性物質(zhì)發(fā)生泄漏鹰祸。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一密浑、第九天 我趴在偏房一處隱蔽的房頂上張望蛙婴。 院中可真熱鬧,春花似錦尔破、人聲如沸街图。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽餐济。三九已至,卻和暖如春胆剧,著一層夾襖步出監(jiān)牢的瞬間絮姆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來泰國(guó)打工秩霍, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留篙悯,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓铃绒,卻偏偏與公主長(zhǎng)得像鸽照,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子颠悬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容