Exemple #1
0
def retrieve_pages(session, pagetitles):
    all_pages = []
    chunks = chunker(pagetitles, CHUNK_SIZE)
    for i, chunk in enumerate(chunks):
        review.show_progress(
            i * CHUNK_SIZE + len(chunk), len(pagetitles),
            "Retrieving chunks '{}'-'{}'".format(chunk[0], chunk[-1])
        )
        response = session.post(API_LOCATION, data={
            "action": "query",
            "format": "json",
            "redirects": "",
            "prop": "categories|info|revisions",
            "cllimit": "max",
            "inprop": "displaytitle",
            "rvprop": "content",
            "titles": "|".join(chunk)
        }).json()
        if "warnings" in response:
            print("\tWarning\n", response["warnings"], file=sys.stderr)
        all_pages.extend(
            list(response["query"]["pages"].values())
        )
        time.sleep(RETRIEVING_DELAY)

    review.show_progress(len(pagetitles), len(pagetitles), "Retrieved chunks.", True)
    return all_pages
Exemple #2
0
def format_pages(all_pages):
    formatted_pages = OrderedDict()
    for i, page in enumerate(sorted(all_pages, key=lambda k: k["title"])):
        title = page["title"]
        review.show_progress(i+1, len(all_pages), "Formatting "+title)
        content = mwparserfromhell.parse(page["revisions"][0]["*"])
        categories = [category["title"] for category in page["categories"]]
        displaytitle = page["displaytitle"]
        formatted_pages[title] = {
            "content": content,
            "categories": categories,
            "displaytitle": displaytitle
        }
    review.show_progress(len(all_pages), len(all_pages), "Formatted all.", True)

    return formatted_pages
Exemple #3
0
def retrieve_pagelist(session, language):
    review.show_progress(0, 1, "Retrieving pagelist...")
    all_pages = session.get(API_LOCATION, params={
        "action": "query",
        "format": "json",
        "redirects": "",
        "prop": "revisions",
        "rvprop": "content",
        "rvsection": "1",
        "titles": "Team Fortress Wiki:Reports/All articles/{}".format(language)
    }).json()

    pages_query = list(all_pages["query"]["pages"].values())[0]
    pages_query = pages_query["revisions"][0]["*"]
    language_pagelist = [page[4:-2] for page in pages_query.splitlines()[1:]]
    review.show_progress(1, 1, "Retrieved pagelist.", True)
    return language_pagelist