找回密码
 会员注册
查看: 42|回复: 0

用Python爬取公众号历史所有文章,看这篇就够了

[复制链接]

2万

主题

0

回帖

6万

积分

超级版主

积分
64021
发表于 2024-9-12 20:15:20 | 显示全部楼层 |阅读模式
自己的很多文章都发在公众号上,想要查看所有历史文章,可不是那么方便。有没有办法能一键抓取所有文章,自动呈现在我眼前?这时,爬虫了解下?今日分享,就带着大家实操一番,爬取公众号所有历史文章。目录什么是爬虫如何爬取公众号文章Step1:注册一个公众号Step2:获取三个值Step3:编写代码写在最后什么是爬虫爬虫这个名词,由来已久了,对于非技术同学来说,可能稍微有点陌生。爬虫,是一种自动浏览网页的技术,它按照一定的规则,自动访问互联网上的网页,获取网页内容。爬虫可以用于多种目的,比如搜索引擎的数据收集、市场研究、数据挖掘等。爬虫的类型可以分为:通用爬虫:爬取整个互联网上的信息,如Google和百度的爬虫。特定爬虫:专注于特定主题或领域的信息,只爬取与特定主题相关的网页。!友情提醒:使用爬虫需遵守相关法律法规,和网站的robots.txt文件规定,避免对网站服务器造成过大负担。所以,爬取网络资源,最重要的就是可以找到目标网站的url地址。如何爬取公众号文章Step1:注册一个公众号首先,你需要有一个自己的公众号,已经有公众号的小伙伴可以略过,接着往下看。如果没有的话,大家可以自行操作,注册公众号的步骤非常简单。Step2:获取三个值登录自己的公众号,在控制台首页找到新的创作,点击图文信息:然后,找到正上面的超链接并打开:这时你就可以看到自己的所有文章列表了:(如果你想查看其他公众号,在右侧👉)停留在当前网页,按F12打开浏览器的开发者工具,找到网络,点击Fetch/XHR,过滤掉其他信息。注:我这里用的edge浏览器,其他浏览器也是类似的。拉到文章列表的最下方,找到并点击翻页按钮。此时,你会发现右侧的开发者工具界面内容多出来一条,就点它👇:在标头这里,找到cookie并复制右侧对应的值:再到负载这里,找到fakeid和token并复制保存下来。把cookies、token以及fakeid,保存下来,这三者缺一不可。Step3:编写代码有了上述这三个值,我们就可以编写Python代码了。首先,定义url,header,然后把三个值填到下面参数的对应位置。#目标urlurl="https://mp.weixin.qq.com/cgi-bin/appmsg"cookie="填写上方获取到的cookie"headers={"Cookie":cookie,"User-Agent":"Mozilla/5.0(Linux;Android6.0;Nexus5Build/MRA58N)AppleWebKit/537.36(KHTML,likeGecko)Chrome/77.0.3865.75MobileSafari/537.36",}data={"token":"填写上方获取到的token","lang":"zh_CN","f":"json","ajax":"1","action":"list_ex","begin":"0","count":"5","query":"","fakeid":"填写上方获取到的fakeid",#自己的号,设置为空"type":"9",}123456789101112131415161718192021想要看看公众号共有多少篇内容?来~defget_total_count():content_json=requests.get(url,headers=headers,params=data).json()count=int(content_json["app_msg_cnt"])returncount1234想要获取所有文章内容?来~defget_content_list(count,per_page=5):page=int(math.ceil(count/per_page))content_list=[]foriintqdm(range(page),desc="获取文章列表"):data["begin"]=i*per_pagecontent_json=requests.get(url,headers=headers,params=data).json()content_list.extend(content_json["app_msg_list"])time.sleep(random.randint(5,10))#保存成jsonwithopen("content_list.json","w",encoding="utf-8")asf:json.dump(content_list,f,ensure_ascii=False,indent=4)1234567891011我们在"app_msg_list"中可以看到,拿到了所有文章的列表:当然,你也可以把文章处理成表格,方便查看:importpandasaspddefprecess_content_list():content_list=json.load(open("content_list.json","r",encoding="utf-8"))results_list=[]foritemincontent_list:title=item["title"]link=item["link"]create_time=time.strftime("%Y-%m-%d%H:%M",time.localtime(item["create_time"]))results_list.append([title,link,create_time])name=['title','link','create_time']data=pd.DataFrame(columns=name,data=results_list)data.to_csv("data.csv",mode='w',encoding='utf-8')123456789101112用Excel打开看看吧:写在最后本文通过一个简单的实操,带大家走进爬虫的世界,手把手教你如何使用Python,一键抓取微信公众号上的所有历史文章。还想爬取文章内容,并保存到本地?如果大家感兴趣,后续我会更新更多用爬虫解决日常需求的教程。如果本文有帮助,不妨点个免费的赞和收藏备用。你的支持是我创作的最大动力。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

QQ|手机版|心飞设计-版权所有:微度网络信息技术服务中心 ( 鲁ICP备17032091号-12 )|网站地图

GMT+8, 2024-12-26 02:11 , Processed in 1.167811 second(s), 26 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表