博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python 抓取微信公众号账号信息
阅读量:5977 次
发布时间:2019-06-20

本文共 2050 字,大约阅读时间需要 6 分钟。

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

爬虫

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

import requests as reqimport rereTypes = r'id="pc_\d*" uigs="(pc_\d*)">([\s\S]*?)'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'

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

注意事项

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

1. 验证码

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

2. 未保存详情页面链接

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

3. 二维码

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

用 Flask 展示结果

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

安装 Sanic

Debug Sanic

Flask + SQLite App

from flask import g, Flask, render_templateimport sqlite3app = 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_appcontextdef close_connection(exception):    db = getattr(g, '_database', None)    if db is not None:        db.close()@app.route("/
")@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)复制代码

【】

转载地址:http://ugsox.baihongyu.com/

你可能感兴趣的文章
精品软件 推荐 相当优秀的轻量级文本编辑器 Notepad2
查看>>
Lync 2013快速入门手册之三:组织Lync会议
查看>>
SQL SERVER 2008 表与约束的创建维护
查看>>
我的友情链接
查看>>
zabbix企业应用之监控mysql 5.6版本
查看>>
BGP选路原则与专有命令的研究
查看>>
关于java的引用、C++的指针、引用的深入分析
查看>>
CMD 修改Host文件 BAT
查看>>
linux用户管理的命令及手动添加用户
查看>>
Windows 7 家庭版如何启用Administrator账户
查看>>
android幻灯片效果实现-Gallery
查看>>
node中exports与module.exports的区别
查看>>
redis 安装及php扩展编译安装
查看>>
批量有效地修改package名
查看>>
android或ios app请求参数格式
查看>>
Camera Vision - video surveillance on C#
查看>>
如何理解网络连接中的"3次握手"?
查看>>
使用Dubbo服务出现java.io.IOException: invalid constant type: 18异常解决办法
查看>>
PYKit目录
查看>>
JSON使用总结
查看>>