Python - 如何获取维基百科将我重定向到的页面?

tgw*_*tdt 5 python redirect http python-3.x python-requests

我想存储一些不同的维基百科链接,但我不想将同一页面的两个不同链接存储两次。例如,以下链接不同,但它们指向相同的维基百科页面:

https://en.wikipedia.org/w/index.php?title=(1S)-1-Methyl-2,3,4,9-tetrahydro-1H-pyrido-3,4-b-indole&redirect=no 
https://en.wikipedia.org/w/index.php?title=(1S)-1-methyl-2,3,4,9-tetrahydro-1H-pyrido-3,4-b-indole&redirect=no
__________________________________________________|___________________________________________________________
Run Code Online (Sandbox Code Playgroud)

唯一的区别是一个大写字符。或者以下链接:

https://en.wikipedia.org/wiki/(0,1)-matrix 
https://en.wikipedia.org/wiki/(0,1)_matrix 
___________________________________|______ 
Run Code Online (Sandbox Code Playgroud)

这只是因为一个有“-”而另一个有“_”(“”)。所以我想要的是只存储其中之一或以下链接:

https://en.wikipedia.org/wiki/Tetrahydroharman 
https://en.wikipedia.org/wiki/Logical_matrix 
Run Code Online (Sandbox Code Playgroud)

我已经尝试过这个问题的答案。但这对我不起作用。(结果是我的初始 URL,而不是 wiki 在浏览器中将我重定向到的那个 URL)那么我怎样才能实现我正在寻找的东西呢?

Abd*_*res 6

MediaWiki Action API提供了维基百科中使用的各种端点。您可以查询端点https://en.wikipedia.org/w/api.php以获取重定向的目标页面。

您可以将结果检索为 JSON 并解析它以获取元素的值元素标题

例子:

此查询将检索“Halab”城市的目标页面:

https://en.wikipedia.org/w/api.php?action=query&titles=Halab&redirects&format=json

结果:

{  
   "batchcomplete":"",
   "query":{  
      "redirects":[  
         {  
            "from":"Halab",
            "to":"Aleppo"
         }
      ],
      "pages":{  
         "159244":{  
            "pageid":159244,
            "ns":0,
            "title":"Aleppo"
         }
      }
   }
}
Run Code Online (Sandbox Code Playgroud)

在Python中:

import json
import requests

query = requests.get(r'https://en.wikipedia.org/w/api.php?action=query&titles={}&redirects&format=json'.format('Halab'))

data = json.loads(query.text)
Run Code Online (Sandbox Code Playgroud)


Ami*_*thi 4

由于维基百科没有正确的 301/302 重定向,因此当您打开链接时会返回正确的 200 成功响应,然后使用 JS 更改 url

我想出了一个快速可行的解决方案。&redirect=no首先,从 URL 中删除

In [42]: import requests

In [43]: r = requests.get('https://en.wikipedia.org/w/index.php?title=(1S)-1-Met
    ...: hyl-2,3,4,9-tetrahydro-1H-pyrido-3,4-b-indole')

In [44]: tmp = r.content.replace('<link rel="canonical" href="', 'r@ndom}-=||').
    ...: split('r@ndom}-=||')[-1]

In [45]: idx = tmp.find('"/>')

In [46]: real_link = tmp[:idx]

In [47]: real_link
Out[47]: 'https://en.wikipedia.org/wiki/Tetrahydroharman'
Run Code Online (Sandbox Code Playgroud)

真实的 URL 值存储在<link rel="canonical" href="标签中。

您可以使用上面的方法,这对于您的用例来说足够好,或者您可以使用 bs4 等库来解析页面并获取链接或使用正则表达式提取链接。