我正在尝试从 Youtube 频道检索 Youtube 视频列表,例如“https://www.youtube.com/user/YouTube/videos”,以获得第 n 个第一个视频(感谢key = "videoId"
)。
它曾经像魅力一样发挥作用,直到几天前它开始征求我的同意。
我在 SO 上尝试了很多东西,但没有运气,我仍然看到要求我接受 cookie 才能观看视频的消息。
import requests
import re
url='https://www.youtube.com/user/YouTube/videos'
s1 = requests.session()
s1.get(url)
print("Original Cookies")
print(s1.cookies)
cookieValueNum = (re.findall(r'\d+', str(s1.cookies)))[0]
cookieValue = ('YES+cb.20210328-17-p0.en-GB+FX+'+str(cookieValueNum))
cookie = {'name': 'CONSENT', 'value': cookieValue, 'domain': '.youtube.com'}
print("==========")
print("After new Cookie added")
s1.cookies.update(cookie)
print(s1.cookies)
print(s1.get(url, cookies=cookie).text)
它仍然返回相同的消息,询问我是否同意 cookies(显然是 html 格式,这是我在私人会话中打开 Youtube 时得到的图片):
当时我的想法是复制Consent
cookie 并将其发送回以便能够访问页面内容。
知道我做错了什么吗?
这个想法是不使用 Youtube API,而仅在需要时请求/BeautifulSoup。
您需要删除第一响应 cookie。我不确定如何在 requests.session 中执行此操作,但以下任何操作都适合我。
requests.get('https://www.youtube.com/user/YouTube/videos', cookies={'CONSENT': 'PENDING+999'})
requests.get('https://www.youtube.com/user/YouTube/videos', cookies={'CONSENT': 'YES+cb.20210328-17-p0.en-GB+FX+{}'.format(random.randint(100, 999))})
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)