前几天,杨超越编程大赛火了,大家都在报名参加,而我也是其中的一员。
在我们的项目中,我负责的是数据爬取这块,我主要是把对于杨超越 的每一条评论的相关信息。
数据格式:{"name":评论人姓名,"comment_time":评论时间,"comment_info":评论内容,"comment_url":评论人的主页}
以上就是我们需要的信息。
爬虫前的分析:
以上是杨超越的微博主页,这是我们首先需要获取到的内容。
因为我们需要等到这个主页内这些微博详情页 的链接,但是我们向下刷新,会发现微博的主页信息是ajax动态加载出来的,
这张图片就是我们向下刷新获取到 的新的链接,这个就是我们需要获取到的信息页面信息。
接下来 就是获取详情页面的信息,详情页中含有评论的相关信息,通过向下刷新,我们也会发现,相关的评论信息也是通过ajax加载出来的 ,
ok,以上就是我们针对整个流程大致的一个分析过程。
具体操作流程:
我们首相将主页获取完成以后,我们就会发现,其中 的内容带有相关的反爬措施,获取到的源码中的信息含有很多的转义符“\”,并且其中的相关“<”和“>”是通过html的语言直接编写的,这样会导致我们的页面解析出现一定的问题,我们可以用replace方法直接将这些转义符全部去掉,然后我们就可以对这个页面进行正则处理,同时我也尝试过用其他的解析方法,但是其中遇到了很多 的问题,所以我就不过多的介绍了。
当我们获取到了每一篇微博的链接以后,还需要获取一个很关键的值 id ,这个值有什么用呢,其主要的作用就是在评论页面的ajax页面的拼接地址上需要使用到。接下来就是需要寻找出我们找到的这两个ajax的url有什么特点或者是规律:
当我们从这些ajax中找到规律以后,不难发现,这个爬虫差不多大功告成了。
下面我就展示一下我的代码:
注意:请在headers中添加自己的cookie
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
# -*- coding: utf-8 -*- # created : 2018/8/26 18:33 # author :guoli import requests import json import time from lxml import etree import html import re from bs4 import beautifulsoup class weibospider: def __init__( self ): # 获取首页的相关信息: self .start_url = 'https://weibo.com/u/5644764907?page=1&is_all=1' self .headers = { "accept" : "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8" , "accept-encoding" : "gzip, deflate, br" , "accept-language" : "zh-cn,zh;q=0.9,en;q=0.8" , "cache-control" : "max-age=0" , "cookie" : 使用自己本机的cookie, "referer" : "https://www.weibo.com/u/5644764907?topnav=1&wvr=6&topsug=1" , "upgrade-insecure-requests" : "1" , "user-agent" : "mozilla/5.0 (windows nt 10.0; wow64) applewebkit/537.36 (khtml, like gecko) chrome/72.0.3626.96 safari/537.36" , } self .proxy = { 'http' : 'http://180.125.70.78:9999' , 'http' : 'http://117.90.4.230:9999' , 'http' : 'http://111.77.196.229:9999' , 'http' : 'http://111.177.183.57:9999' , 'http' : 'http://123.55.98.146:9999' , } def parse_home_url( self , url): # 处理解析首页面的详细信息(不包括两个通过ajax获取到的页面) res = requests.get(url, headers = self .headers) response = res.content.decode().replace( "\\", " ") # every_url = re.compile('target="_blank" href="(/\d+/\w+\?from=\w+&wvr=6&mod=weibotime)" rel="external nofollow" ', re.s).findall(response) every_id = re. compile ( 'name=(\d+)' , re.s).findall(response) # 获取次级页面需要的id home_url = [] for id in every_id: base_url = 'https://weibo.com/aj/v6/comment/big?ajwvr=6&id={}&from=singleweibo' url = base_url. format ( id ) home_url.append(url) return home_url def parse_comment_info( self , url): # 爬取直接发表评论的人的相关信息(name,info,time,info_url) res = requests.get(url, headers = self .headers) response = res.json() count = response[ 'data' ][ 'count' ] html = etree.html(response[ 'data' ][ 'html' ]) name = html.xpath( "//div[@class='list_li s_line1 clearfix']/div[@class='wb_face w_fl']/a/img/@alt" ) # 评论人的姓名 info = html.xpath( "//div[@node-type='replywrap']/div[@class='wb_text']/text()" ) # 评论信息 info = " ".join(info).replace(" ", " ").split(" \n") info.pop( 0 ) comment_time = html.xpath( "//div[@class='wb_from s_txt2']/text()" ) # 评论时间 name_url = html.xpath( "//div[@class='wb_face w_fl']/a/@href" ) # 评论人的url name_url = [ "https:" + i for i in name_url] comment_info_list = [] for i in range ( len (name)): item = {} item[ "name" ] = name[i] # 存储评论人的网名 item[ "comment_info" ] = info[i] # 存储评论的信息 item[ "comment_time" ] = comment_time[i] # 存储评论时间 item[ "comment_url" ] = name_url[i] # 存储评论人的相关主页 comment_info_list.append(item) return count, comment_info_list def write_file( self , path_name, content_list): for content in content_list: with open (path_name, "a" , encoding = "utf-8" ) as f: f.write(json.dumps(content, ensure_ascii = false)) f.write( "\n" ) def run( self ): start_url = 'https://weibo.com/u/5644764907?page={}&is_all=1' start_ajax_url1 = 'https://weibo.com/p/aj/v6/mblog/mbloglist?ajwvr=6&domain=100406&is_all=1&page={0}&pagebar=0&pl_name=pl_official_myprofilefeed__20&id=1004065644764907&script_uri=/u/5644764907&pre_page={0}' start_ajax_url2 = 'https://weibo.com/p/aj/v6/mblog/mbloglist?ajwvr=6&domain=100406&is_all=1&page={0}&pagebar=1&pl_name=pl_official_myprofilefeed__20&id=1004065644764907&script_uri=/u/5644764907&pre_page={0}' for i in range ( 12 ): # 微博共有12页 home_url = self .parse_home_url(start_url. format (i + 1 )) # 获取每一页的微博 ajax_url1 = self .parse_home_url(start_ajax_url1. format (i + 1 )) # ajax加载页面的微博 ajax_url2 = self .parse_home_url(start_ajax_url2. format (i + 1 )) # ajax第二页加载页面的微博 all_url = home_url + ajax_url1 + ajax_url2 for j in range ( len (all_url)): print (all_url[j]) path_name = "第{}条微博相关评论.txt" . format (i * 45 + j + 1 ) all_count, comment_info_list = self .parse_comment_info(all_url[j]) self .write_file(path_name, comment_info_list) for num in range ( 1 , 10000 ): if num * 15 < int (all_count) + 15 : comment_url = all_url[j] + "&page={}" . format (num + 1 ) print (comment_url) try : count, comment_info_list = self .parse_comment_info(comment_url) self .write_file(path_name, comment_info_list) except exception as e: print ( "error:" , e) time.sleep( 60 ) count, comment_info_list = self .parse_comment_info(comment_url) self .write_file(path_name, comment_info_list) del count time.sleep( 0.2 ) print ( "第{}微博信息获取完成!" . format (i * 45 + j + 1 )) if __name__ = = '__main__' : weibo = weibospider() weibo.run() |
以上所述是小编给大家介绍的python爬虫爬取微博评论详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:https://blog.csdn.net/qq_41733098/article/details/88539402