Python 抓取微信公众号账号信息的方法


Posted in Python onJune 14, 2019

Python 抓取微信公众号账号信息的方法

搜狗微信搜索提供两种类型的关键词搜索,一种是搜索公众号文章内容,另一种是直接搜索微信公众号。通过微信公众号搜索可以获取公众号的基本信息及最近发布的10条文章,今天来抓取一下微信公众号的账号信息

爬虫

首先通过首页进入,可以按照类别抓取,通过“查看更多”可以找出页面链接规则:

Python 抓取微信公众号账号信息的方法

import requests as req
import re
reTypes = r'id="pc_\d*" uigs="(pc_\d*)">([\s\S]*?)</a>'
Entry = "http://weixin.sogou.com/"
entryPage = req.get(Entry)
allTypes = re.findall(reTypes, getUTF8(entryPage))
for (pcid, category) in allTypes:
  for page in range(1, 100):
    url = 'http://weixin.sogou.com/pcindex/pc/{}/{}.html'.format(pcid, page)
    print(url)
    categoryList = req.get(url)
    if categoryList.status_code != 200:
      break

上面代码通过加载更多页面获取加载列表,进而从其中抓取微信公众号详情页面:

reProfile = r'<li id[\s\S]*?<a href="([\s\S]*?)" rel="external nofollow" '
allProfiles = re.findall(reOAProfile, getUTF8(categoryList))
for profile in allProfiles:
  profilePage = req.get(profile)
  if profilePage.status_code != 200:
    continue

进入详情页面可以获取公众号的 名称/ID/功能介绍/账号主体/头像/二维码/最近10篇文章 等信息:

Python 抓取微信公众号账号信息的方法 

注意事项

详情页面链接: http://mp.weixin.qq.com/profile?src=3×tamp=1477208282&ver=1&signature=8rYJ4QV2w5FXSOy6vGn37sUdcSLa8uoyHv3Ft7CrhZhB4wO-bbWG94aUCNexyB7lqRNSazua-2MROwkV835ilg==

1. 验证码

访问详情页面时有可能需要验证码,自动识别验证码还是很有难度的,因此要做好爬虫的伪装工作。

2. 未保存详情页面链接

详情页面的链接中有两个重要参数: timestamp & signature ,这说明页面链接是有时效性的,所以保存下来应该也没用;

3. 二维码

二维码图片链接同样具有时效性,因此如需要最好将图片下载下来。

用 Flask 展示结果

最近 Python 社区出现了一款异步增强版的 Flask 框架: Sanic ,基于 uvloop 和 httptools ,可以达到异步、更快的效果,但保持了与 Flask 一致的简洁语法。虽然项目刚起步,还有很多基本功能为实现,但已经获得了很多关注( 2,222 Star )。这次本打算用抓取的微信公众号信息基于 Sanic 做一个简单的交互应用,但无奈目前还没有加入模板功能,异步的 redis 驱动也还有 BUG 没解决,所以简单尝试了一下之后还是切换回 Flask + SQLite,先把抓取结果呈现出来,后续有机会再做更新。

安装 Sanic

Python 抓取微信公众号账号信息的方法

Debug Sanic

Python 抓取微信公众号账号信息的方法 

Flask + SQLite App

from flask import g, Flask, render_template
import sqlite3
app = Flask(__name__)
DATABASE = "./db/wx.db"
def get_db():
  db = getattr(g, '_database', None)
  if db is None:
    db = g._database = sqlite3.connect(DATABASE)
  return db
@app.teardown_appcontext
def close_connection(exception):
  db = getattr(g, '_database', None)
  if db is not None:
    db.close()
@app.route("/<int:page>")
@app.route("/")
def hello(page=0):
  cur = get_db().cursor()
  cur.execute("SELECT * FROM wxoa LIMIT 30 OFFSET ?", (page*30, ))
  rows = []
  for row in cur.fetchall():
    rows.append(row)
  return render_template("app.html", wx=rows, cp=page)
if __name__ == "__main__":
  app.run(debug=True, port=8000)

总结

以上所述是小编给大家介绍的Python 抓取微信公众号账号信息,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
Python ORM框架SQLAlchemy学习笔记之映射类使用实例和Session会话介绍
Jun 10 Python
python实现的希尔排序算法实例
Jul 01 Python
python机器学习之决策树分类详解
Dec 20 Python
Python语言描述连续子数组的最大和
Jan 04 Python
python批量设置多个Excel文件页眉页脚的脚本
Mar 14 Python
Django使用详解:ORM 的反向查找(related_name)
May 30 Python
Python 中 -m 的典型用法、原理解析与发展演变
Nov 11 Python
pyenv虚拟环境管理python多版本和软件库的方法
Dec 26 Python
如何在Django中使用聚合的实现示例
Mar 23 Python
Pycharm及python安装详细步骤及PyCharm配置整理(推荐)
Jul 31 Python
Python requests模块cookie实例解析
Apr 14 Python
python 一维二维插值实例
Apr 22 Python
python字典一键多值实例代码分享
Jun 14 #Python
Python 窗体(tkinter)按钮 位置实例
Jun 13 #Python
python3 tkinter实现点击一个按钮跳出另一个窗口的方法
Jun 13 #Python
python tkinter canvas 显示图片的示例
Jun 13 #Python
Python通用函数实现数组计算的方法
Jun 13 #Python
PyCharm搭建Spark开发环境实现第一个pyspark程序
Jun 13 #Python
Pycharm如何打断点的方法步骤
Jun 13 #Python
You might like
数据库相关问题
2006/10/09 PHP
php selectradio和checkbox默认选择的实现方法详解
2013/06/29 PHP
详解php的socket通信
2015/08/11 PHP
php输出反斜杠的实例方法
2019/09/19 PHP
张孝祥JavaScript学习阶段性总结(2)--(X)HTML学习
2007/02/03 Javascript
javascript中onmouse事件在div中失效问题的解决方法
2012/01/09 Javascript
JS操作图片(增,删,改) 例子
2013/04/17 Javascript
利用CSS、JavaScript及Ajax实现高效的图片预加载
2013/10/16 Javascript
JavaScript判断微信浏览器实例代码
2016/06/13 Javascript
js输入框使用正则表达式校验输入内容的实例
2017/02/12 Javascript
使用jQuery的load方法设计动态加载及解决被加载页面js失效问题
2017/03/01 Javascript
微信小程序 判断手机号的实现代码
2017/04/19 Javascript
Bootstrap模态框插件使用详解
2017/05/11 Javascript
jQuery图片查看插件Magnify开发详解
2017/12/25 jQuery
Vue 源码分析之 Observer实现过程
2018/03/29 Javascript
Vue封装的组件全局注册并引用
2019/07/24 Javascript
vue.js使用v-model实现父子组件间的双向通信示例
2020/02/05 Javascript
Python中exit、return、sys.exit()等使用实例和区别
2015/05/28 Python
CentOS中使用virtualenv搭建python3环境
2015/06/08 Python
python3.0 模拟用户登录,三次错误锁定的实例
2017/11/02 Python
python测试mysql写入性能完整实例
2018/01/18 Python
python中使用zip函数出现错误的原因
2018/09/28 Python
Python对切片命名的实现方法
2018/10/16 Python
python实现批量文件重命名
2019/10/31 Python
Tensorflow 多线程与多进程数据加载实例
2020/02/05 Python
已安装tensorflow-gpu,但keras无法使用GPU加速的解决
2020/02/07 Python
python解析xml文件方式(解析、更新、写入)
2020/03/05 Python
探索欧洲最好的品牌:Bombinate
2019/06/14 全球购物
食堂员工工作职责
2013/12/18 职场文书
《蜗牛》教学反思
2014/02/18 职场文书
公司副总经理任命书
2014/06/05 职场文书
行政执法队伍作风整顿个人剖析材料
2014/10/11 职场文书
财务个人年度总结范文
2015/02/26 职场文书
2015年幼师个人工作总结
2015/10/15 职场文书
详解redis分布式锁的这些坑
2021/05/19 Redis
python异步的ASGI与Fast Api实现
2021/07/16 Python