在Python中,我們可以使用各種庫來爬取視頻流。以下是一個簡單的示例使用requests和OpenCV庫來爬取視頻流。
import cv2
import requests
import numpy as np
stream_url = "http://example.com/video/stream"
headers = {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36"}
# 打開視頻流
resp = requests.get(stream_url, headers=headers, stream=True)
resp.raise_for_status()
bytes = ''
# 循環讀取視頻流
for chunk in resp.iter_content(chunk_size=1024):
bytes += chunk
a = bytes.find('\xff\xd8')
b = bytes.find('\xff\xd9')
if a != -1 and b != -1:
jpg = bytes[a:b+2]
bytes = bytes[b+2:]
# 轉換圖像數據
img = cv2.imdecode(np.fromstring(jpg, dtype=np.uint8), cv2.IMREAD_COLOR)
# 顯示圖像
cv2.imshow('Video Stream', img)
if cv2.waitKey(1) == 27:
exit(0)
代碼使用requests庫來獲取視頻流,headers中包含User-Agent是因為有些網站需要User-Agent進行驗證。循環讀取視頻流,當找到圖像開頭和結尾時,利用OpenCV庫轉換圖像數據并顯示在窗口中。如果按下ESC鍵,程序退出。