前言

第一次写博客,主要内容是爬取微信公众号的文章,将文章以PDF格式保存在本地。

爬取微信公众号文章(使用wechatsogou)

1.安装

pip install wechatsogou --upgrade

wechatsogou是一个基于搜狗微信搜索的微信公众号爬虫接口

2.使用方法

使用方法如下所示

import wechatsogou

# captcha_break_time为验证码输入错误的重试次数,默认为1

ws_api = wechatsogou.WechatSogouAPI(captcha_break_time=3)

# 公众号名称

gzh_name = ''

# 将该公众号最近10篇文章信息以字典形式返回

data = ws_api.get_gzh_article_by_history(gzh_name)

data数据结构:

{

'gzh': {

'wechat_name': '', # 名称

'wechat_id': '', # 微信id

'introduction': '', # 简介

'authentication': '', # 认证

'headimage': '' # 头像

},

'article': [

{

'send_id': int, # 群发id,注意不唯一,因为同一次群发多个消息,而群发id一致

'datetime': int, # 群发datatime 10位时间戳

'type': '', # 消息类型,均是49(在手机端历史消息页有其他类型,网页端最近10条消息页只有49),表示图文

'main': int, # 是否是一次群发的第一次消息 1 or 0

'title': '', # 文章标题

'abstract': '', # 摘要

'fileid': int, #

'content_url': '', # 文章链接

'source_url': '', # 阅读原文的链接

'cover': '', # 封面图

'author': '', # 作者

'copyright_stat': int, # 文章类型,例如:原创啊

},

...

]

}

这里需要得到两个信息:文章标题,文章url。

得到文章url以后,就可以根据url将html页面转换成pdf文件了。

生成PDF文件

1.安装wkhtmltopdf

2.安装pdfkit

pip install pdfkit

3.使用方法

import pdfkit

# 根据url生成pdf

pdfkit.from_url('http://baidu.com','out.pdf')

# 根据html文件生成pdf

pdfkit.from_file('test.html','out.pdf')

# 根据html代码生成pdf

pdfkit.from_string('Hello!','out.pdf')

如果直接用上面得到的文章url去生成pdf,会出现pdf文件不显示文章图片的问题。

解决办法:

# 该方法根据文章url对html进行处理,使图片显示

content_info = ws_api.get_article_content(url)

# 得到html代码(代码不完整,需要加入head、body等标签)

html_code = content_info['content_html']

然后根据html_code构造完整的html代码,调用pdfkit.from_string()方法生成pdf文件,这时候会发现文章中的图片在pdf文件中显示出来了。

完整代码

import os

import pdfkit

import datetime

import wechatsogou

# 初始化API

ws_api = wechatsogou.WechatSogouAPI(captcha_break_time=3)

def url2pdf(url, title, targetPath):

'''

使用pdfkit生成pdf文件

:param url: 文章url

:param title: 文章标题

:param targetPath: 存储pdf文件的路径

'''

try:

content_info = ws_api.get_article_content(url)

except:

return False

# 处理后的html

html = f'''

{title}

{title}

{content_info['content_html']}

'''

try:

pdfkit.from_string(html, targetPath + os.path.sep + f'{title}.pdf')

except:

# 部分文章标题含特殊字符,不能作为文件名

filename = datetime.datetime.now().strftime('%Y%m%d%H%M%S') + '.pdf'

pdfkit.from_string(html, targetPath + os.path.sep + filename)

if __name__ == '__main__':

# 此处为要爬取公众号的名称

gzh_name = ''

targetPath = os.getcwd() + os.path.sep + gzh_name

# 如果不存在目标文件夹就进行创建

if not os.path.exists(targetPath):

os.makedirs(targetPath)

# 将该公众号最近10篇文章信息以字典形式返回

data = ws_api.get_gzh_article_by_history(gzh_name)

article_list = data['article']

for article in article_list:

url = article['content_url']

title = article['title']

url2pdf(url, title, targetPath)

python爬取正确但不出文件_使用Python爬取微信公众号文章并保存为PDF文件(解决图片不显示的问题)...相关推荐

  1. python批量保存网页为pdf_爬取微信公众号文章并保存为PDF文件(Python方法)

    {title} {content_info['content_html']}

  2. (Java篇)爬取微信公众号文章并保存为 PDF 格式

    前言 背景: 某一天,拿着自己的手机看着技术文章,然而手机看技术文章,有时候确实蛋疼,因为一旦代码多起来,小屏幕看的还是眼花:又或者某一天觉得这一篇文章,觉得写的很棒棒哦,于是先收藏,打算过几天看,然 ...

  3. 微信公众号内,实现下载 PDF 文件。

    背景:需要在 微信公众号 内实现,通过点击一个[下载PDF文件]按钮,预期将 PDF 文件下载到本地自行打印. 前言:首先,本文采用的是 配合 后端 的实现方案.后端 返回file文件,通过 a 链接 ...

  4. python程序设计基础山东联盟化工集团有限公司_智慧树app答案微信公众号,Python程序设计基础(山东联盟)知到答案...

    问题:无脊椎动物中唯一会飞的动物是A.昆虫 B.蝙蝠C.鸟类 D.蜘蛛 更多相关问题 (11分)如果你翻动花园.庭院中的花盆或石块,常常会看到一些身体略扁.长椭圆形.灰褐色或黑色的小动物在爬行, 生物 ...

  5. python爬虫(17)爬出新高度_抓取微信公众号文章(selenium+phantomjs)

    个人博客请访问 http://www.x0100.top 一.思路分析 目前所知晓的能够抓取的方法有: 1.微信APP中微信公众号文章链接的直接抓取(http://mp.weixin.qq.com/s ...

  6. python爬取微信公众号文章

    爬取微信公众号文章 获取微信公众号的url 获取每一篇文章的url ​ 选择一个公众号进入,选择一个目录进入后点复制链接,然后去浏览器打开.按F12打开检查的模式,在Console中输入$x('标签路 ...

  7. python爬取微信公众号文章(包含文章内容和图片)

    之前虽然做过网页爬取,但微信爬取一直没做过,因为我一直不知道网页可以进微信公众平台,只用过微信客户端进微信公众号.既然可以通过网页进微信公众平台,那么爬取微信公众号文章就流程上就没太多难度了. 自己在 ...

  8. python爬虫能爬取微信密码吗_爬虫如何爬取微信公众号文章

    下篇文章:python爬虫如何爬取微信公众号文章(二) 下下篇连接python爬虫如何实现每天爬取微信公众号的推送文章 因为最近在法院实习,需要一些公众号的数据,然后做成网页展示出来便于查看,之前我倒 ...

  9. html如何获取请求头变量的值。_如何使用 Python 爬取微信公众号文章

    我比较喜欢看公众号,有时遇到一个感兴趣的公众号时,都会感觉相逢恨晚,想一口气看完所有历史文章.但是微信的阅读体验挺不好的,看历史文章得一页页的往后翻,下一次再看时还得重复操作,很是麻烦. 于是便想着能 ...

最新文章

  1. 时序预测竞赛之异常检测算法综述
  2. (转)Invoke and BeginInvoke
  3. LeetCode 2115. 从给定原材料中找到所有可以做出的菜(拓扑排序)
  4. python之socket编程
  5. Java面试详解(2020版):500+ 面试题和核心知识点详解
  6. linux 压缩为多个文件,在Linux中,如何将输入流压缩为多个输出文件?
  7. [zz]C#中的Type类和Assembly类
  8. Controller接口控制器(2)
  9. 专业五线谱作曲打谱软件Overture的常用快捷键功能大全
  10. 访问json接口浏览器提示下载文件
  11. Python 正则表达式详解(建议收藏!)
  12. 七万字详解paddle-openVINO【CPU】-从环境配置-模型部署全流程
  13. 微信小程序报错 40125 已解决
  14. 第三阶段应用层——1.2 数码相册—字符编码
  15. Unity学习-Prinmatives原形
  16. 微信小程序功能:商品收藏-图片预览-客服-分享-加入购物车
  17. Excel之如何使用VLOOKUP函数合并两张表
  18. 基于最大似然估计(matlab实验)
  19. spss 构建决策树 树形图 正在处理不显示问题
  20. 《Spring实战》读书笔记-第3章 高级装配,最新Java大厂高频面试题

热门文章

  1. 拒绝云服务商白嫖,Elasticsearch 和 Kibana 变更开源许可协议
  2. Deno 冲上榜首,Vue.js 首次屈居第二,JavaScript 2020 年度“新起之秀”都有谁?
  3. Spring Boot太难了?那是你不知道这3个要点!
  4. 真棒!20 张图揭开内存管理的迷雾
  5. 阿里“去 IOE”十二年,弹性计算如何二次去 I 和 E?
  6. “数学不好,干啥都不行!”高级开发:方向不对,努力也白费!
  7. 170 亿参数加持,微软发布史上最大 Transformer 模型 T-NLG!
  8. 学编程不如学自动化?
  9. 我在 1969 年写代码
  10. Android 设备正在“绞杀”密码!