0

我浏览了维基百科上的活人类别,并收集了页面图像。问题是,一些图像存储在 wikimedia commons 站点上,而一些图像存储在原始 wikipedia:en 站点上。我想知道图像的存储位置(如果它存储在除 en:wiki 和 commons 之外的其他地方)

import pywikibot

enwiki = pywikibot.Site("en", "wikipedia")
commons = pywikibot.Site("commons","commons")
page1 = pywikibot.Page(enwiki, "50 Cent")
page2 = pywikibot.Page(enwiki, "0010x0010")
pageimage1 = page1.page_image()
pageimage2 = page2.page_image()
pageimage1.exists() //outputs False (50 Cent page image is stored on commons)
pageimage2.exists() //outputs True  (0010x0010 page imaged is stored on wikipedia:en)

这很好,如果维基百科 .exists() 输出 False,我可以检查公共资源,但我担心图像会存储在不同站点上的情况。

我已经尝试过 Page.image_repository 属性,但是即使页面图像不存在并且存储在 wikipedia:en 上,它也会返回 commons

有没有办法从 Page 对象中获取原始站点?因为我知道这可能的唯一方法是下载 HTML 页面并解析它,这太复杂了。

4

1 回答 1

1

正如 Tgr 所指出的,最好的方法是使用该FilePage.file_is_shared()方法。要上传文件,您可以执行以下操作:

import pywikibot

def repo_file(filepage):
    """Return a FilePage residing on repository."""
    if filepage.file_is_shared():
        filepage = pywikibot.FilePage(filepage.site.image_repository(), filepage.title())
    return filepage

使用您的第一个示例,它将像这样工作:

site = pywikibot.Site('wikipeda:de')
page1 = pywikibot.Page(site, '50 Cent')
page2 = pywikibot.Page(site, '0010x0010')
img1 = page1.page_image()
img2 = page2.page_image()

测试网站:

img1.site
img2.site

会给

APISite("en", "wikipedia")
APISite("en", "wikipedia")

现在上调它:

img1 = repo_file(img1)
img2 = repo_file(img2)

再次测试该站点:

img1.site
img2.site

会给

APISite("commons", "commons")
APISite("en", "wikipedia")
于 2021-04-01T10:41:33.247 回答