发布时间:2025-12-09 13:40:15 浏览次数:4
爬虫的动态处理方法(我用较为简单的一些网址举例 比如豆瓣的热门电影)
动态爬虫与静态爬虫的最大区别就是源代码与网页内容不同,动态爬虫可以通过抓包(就是直接利用浏览器的F12进行network抓包,获取相关对应的文件)
截图如下(示例):按F12进入开发者模式,第二步点击左上角刷新重新加载一下内容,第三步在红框里选取需要的内容,可以通过“预览”来查看是否对应查找正确之后然后在“标头”里找到“请求URL”以及“User-Agent”,把这些找到后基本工作就差不多完成了
先引入所需要的库
代码如下:
import reimport urllib.requestimport pandas as pd这是我常用的几个库
url=('https://movie.douban.com/j/search_subjects?type=movie&tag=%E7%83%AD%E9%97%A8&page_limit=50&page_start=0')headers={ 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.82 Safari/537.36' }requests=urllib.request.Request(url,headers=headers)respon=urllib.request.urlopen(requests)html=respon.read().decode('utf-8')url=('https://movie.douban.com/j/search_subjects?type=movie&tag=%E7%83%AD%E9%97%A8&page_limit=50&page_start=0')headers={ 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.82 Safari/537.36' }requests=urllib.request.Request(url,headers=headers)respon=urllib.request.urlopen(requests)html=respon.read().decode('utf-8')photo=re.compile(r'"cover":"(.*?),"id"')list1=re.findall(photo,html)name=re.compile(r'"title":"(.*?)",')list2=re.findall(name,html)# print(html)rat=re.compile(r'"rate":"(.*?),')list3=re.findall(rat,html)xx={ '电影名':list2,'评分':list3}df=pd.DataFrame(xx,index=range(1,51))print(df)