您好,登錄后才能下訂單哦!
本篇文章為大家展示了利用python實現爬取微博評論的方法,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
第一步:確定評論用戶的id
# -*- coding:utf-8 -*- import requests import re import time import pandas as pd urls = 'https://m.weibo.cn/api/comments/show?id=4073157046629802&page={}' headers = {'Cookies':'Your cookies', 'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/66.0.3359.181 Safari/537.36'}
tags = re.compile('</?\w+[^>]*>')
def get_comment(url): j = requests.get(url, headers=headers).json() comment_data = j['data']['data'] for data in comment_data: try:
comment = tags.sub('', data['text']) # 去掉html標簽 reply = tags.sub('', data['reply_text']) weibo_id = data['id'] reply_id = data['reply_id'] comments.append(comment) comments.append(reply) ids.append(weibo_id) ids.append(reply_id)
df = pd.DataFrame({'ID': ids, '評論': comments}) df = df.drop_duplicates() df.to_csv('觀察者網.csv', index=False, encoding='gb18030')
實例擴展:
# -*- 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實現爬取微博評論的方法,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。