多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
[TOC] ## wechatpy 介绍 在章节《订阅号开发环境》中,已经安装了`wechatpy`,wechatpy 是一个微信 (WeChat) 的第三方 Python SDK, 实现了微信公众号、企业微信和微信支付等 API。 参考文档:[https://wechatpy.readthedocs.io/zh\_CN/master/index.html](https://wechatpy.readthedocs.io/zh_CN/master/index.html) ``` class WeChatClient(BaseWeChatClient): """ 微信 API 操作类 通过这个类可以操作微信 API,发送主动消息、群发消息和创建自定义菜单等。 """ ``` 在本章节中,先以素材资源管理为例,先掌握对素材资源的管理,为后面章节中应答消息,主动发送消息等场景中使用素材资源做准数据准备。 ## 实例化WechatClient ``` from wechatpy.client import WeChatClient app = { "appid": "wx3a07084cc1a11915", "appsecret": "8f9a6bb1f66b59aa705ecd9938a3874c" } wx = WeChatClient(app.get("appid"), app.get("appsecret")) ``` ### 上传临时媒体素材接口 media 公众号经常有需要用到一些临时性的多媒体素材的场景,例如在使用接口特别是发送消息时,对多媒体文件、多媒体消息的获取和调用等操作,是通过media\_id来进行的。素材管理接口对所有认证的订阅号和服务号开放。通过本接口,公众号可以新增临时素材(即上传临时多媒体文件)。 #### 上传临时图片 ``` resp = wx.media.upload("image", open("D://666.png", "rb")) print(resp) { 'type': 'image', 'media_id': '1pnGyv1G8nGdT2A9Thm70I-n7_cQ9CuE-6Jj3tTGdWxpE6IFU5q1GNS6JHEDynqL', 'created_at': 1557050593 } ``` #### 上传临时缩略图 ``` resp = wx.media.upload("thumb", open("D://wx.jpg", "rb")) print(resp) { 'type': 'thumb', 'thumb_media_id': 'StquJqb_PqfYLtE1hwy4UcZGNlncMggH_DreS0YEI8uDCywvPzfQg8yYdsPpi1Tc', 'created_at': 1557051046 } ``` #### 上传临时视频 ``` resp = wx.media.upload("video", open("D://hello.mp4", "rb")) print(resp) { 'type': 'video', 'media_id': 'jCMhWTXbm90l0zWFirVwHPzWi_SO6A4lnqqcj_91fxKWkHdQnyZY14uFJQYJHLcC', 'created_at': 1557050806 } ``` ### 上传永久媒体素材接口 material 对于常用的素材,开发者可通过本接口上传到微信服务器,永久使用。新增的永久素材也可以在公众平台官网素材管理模块中查询管理。 #### 上传永久图片 ``` resp = wx.material.add("image",open("D://666.png","rb")) print(resp) { 'media_id': 'BzzIfj9NcYYTuaPR_j133jbk4KxYuPvhoZx68usaDi0', 'url': 'http://mmbiz.qpic.cn/mmbiz_png/QuFmLYzPJ2BbITcU1VNpEhH8XUsXbtcibQejDaVQMIicE6Wa6v3O5EUsfA3CNumdQAdsx2HrCDrmX6f6zaPk4reg/0?wx_fmt=png' } ``` #### 上传永久缩略图 ``` resp = wx.material.add("thumb",open("D://wx.jpg","rb")) print(resp) { 'media_id': 'BzzIfj9NcYYTuaPR_j133nS16LBGp7_ZcN5o9ihrBDw', 'url': 'http://mmbiz.qpic.cn/mmbiz_jpg/QuFmLYzPJ2BbITcU1VNpEhH8XUsXbtcibqwCkTuX97EFSfqqbzYVfK8Em7WdHCicMta8sMoUJCLSTLoMjUJkpYsw/0?wx_fmt=jpeg' } ``` #### 上传永久视频 ``` resp = wx.material.add("video",open("D://hello.mp4","rb"),title="视频标题...",introduction="视频简介...") print(resp) {'media_id': 'BzzIfj9NcYYTuaPR_j133ietkr1Oy2009whI6vdTLR8'} ``` #### 上传图文消息(群发消息)内的图片 ``` resp = wx.media.upload_image(open("D://666.png","rb")) print(resp) http://mmbiz.qpic.cn/mmbiz_png/QuFmLYzPJ2BbITcU1VNpEhH8XUsXbtcibQejDaVQMIicE6Wa6v3O5EUsfA3CNumdQAdsx2HrCDrmX6f6zaPk4reg/0 ``` #### 新增永久图文素材 ``` resp = wx.material.add_articles(articles=[ { "thumb_media_id": "%s" % wx.material.add("thumb", open("D://wx.jpg", "rb")).get("media_id"), # 图文消息的封面图片素材id(必须是永久mediaID) "author": "观小鱼", "title": "Python实战", "content": "python实战总结<br><img src=%s>" % wx.media.upload_image(open("D://666.png", "rb")), # 图文消息的具体内容,支持HTML标签 "digest": "通过python实战项目,快速掌握python开发", # 图文消息的摘要 "content_source_url": "https://www.kancloud.cn/@guanfuchang", # 图文消息的原文地址 "show_cover_pic": 1, # 显示封面 "need_open_comment": 1, # 打开评论 "only_fans_can_comment": 1 # 粉丝才可以评论 } ]) print(resp) { 'media_id': 'BzzIfj9NcYYTuaPR_j133mW-veyn3sNRANnduEtdnss' } ``` ### 获取素材 #### 获取临时素材下载地址 公众号可以使用本接口获取临时素材(即下载临时的多媒体文件),注意:*媒体文件在微信后台保存时间为3天,即3天后media\_id失效。* ``` resp = wx.media.get_url("1pnGyv1G8nGdT2A9Thm70I-n7_cQ9CuE-6Jj3tTGdWxpE6IFU5q1GNS6JHEDynqL") print(resp) https://api.weixin.qq.com/cgi-bin/media/get?access_token=21_yblTNnELBMPr73XmbLOaeVNjSKsruUGFv9Y4amhVVrbelomKcFbKb0wfLrJvrpoX-7K-vt8i-nWs9zCmEx7FVV4T9oq8xAV3n7TndwNzWa_kkVPGdzbq_yj8hbQCYWgAIAVRP&media_id=1pnGyv1G8nGdT2A9Thm70I-n7_cQ9CuE-6Jj3tTGdWxpE6IFU5q1GNS6JHEDynqL ``` #### 批量获取永久素材列表 "image","voice","video","news" 在新增了永久素材后,开发者可以分类型获取永久素材的列表。 ``` resp = wx.material.batchget(media_type="news",offset=0,count=2) print(resp) { 'item': [{ 'media_id': 'BzzIfj9NcYYTuaPR_j133mW-veyn3sNRANnduEtdnss', 'content': { 'news_item': [{ 'title': 'Python实战', 'author': '观小鱼', 'digest': '通过python实战项目,快速掌握python开发', 'content': 'python实战总结<br /><img data-src="http://mmbiz.qpic.cn/mmbiz_png/QuFmLYzPJ2BbITcU1VNpEhH8XUsXbtcibQejDaVQMIicE6Wa6v3O5EUsfA3CNumdQAdsx2HrCDrmX6f6zaPk4reg/0%3E">', 'content_source_url': 'https://www.kancloud.cn/@guanfuchang', 'thumb_media_id': 'BzzIfj9NcYYTuaPR_j133keapTcjqt-9xZQkkN0qQ9Q', 'show_cover_pic': 1, 'url': 'http://mp.weixin.qq.com/s?__biz=MzA3NzgzMzA5Nw==&mid=100000028&idx=1&sn=01235aff2dee3ba7941ee3ff0be73444&chksm=1f4ab7fa283d3eec80b03af52b3b51a3affa140830a8dcb4baba7ec1c480055acab98a4e610f#rd', 'thumb_url': 'http://mmbiz.qpic.cn/mmbiz_jpg/QuFmLYzPJ2BbITcU1VNpEhH8XUsXbtcibqwCkTuX97EFSfqqbzYVfK8Em7WdHCicMta8sMoUJCLSTLoMjUJkpYsw/0?wx_fmt=jpeg', 'need_open_comment': 1, 'only_fans_can_comment': 1 }], 'create_time': 1557115885, 'update_time': 1557115885 }, 'update_time': 1557115885 }, { 'media_id': 'BzzIfj9NcYYTuaPR_j133kSfaJsfBYCH8seLSfKaXGg', 'content': { 'news_item': [{ 'title': 'Happy Day', 'author': 'xxx', 'digest': 'digest', 'content': 'content', 'content_source_url': 'http://www.qq.com', 'thumb_media_id': 'BzzIfj9NcYYTuaPR_j133h2JwAhVA-Z-fLxFgOBY-Nw', 'show_cover_pic': 1, 'url': 'http://mp.weixin.qq.com/s?__biz=MzA3NzgzMzA5Nw==&mid=100000004&idx=1&sn=6ed39350fdb884b51d997ef04ed36b43&chksm=1f4ab7e2283d3ef417e4855ed52c88927a3a8ad0301289b8e0dfcb1f65fef9c412b6eb768b1b#rd', 'thumb_url': 'http://mmbiz.qpic.cn/mmbiz_png/QuFmLYzPJ2DK93uoeUAibJSqQBmgeR1uhdicrQKxT3QzZVdfWUIHa6fmFfuaibLNibqYGVHQcwyzCbsbPWTN82Vs9g/0?wx_fmt=png', 'need_open_comment': 1, 'only_fans_can_comment': 1 }], 'create_time': 1556162229, 'update_time': 1556162229 }, 'update_time': 1556162229 }], 'total_count': 2, 'item_count': 2 } ``` #### 获取永久素材 在新增了永久素材后,开发者可以根据media\_id通过本接口下载永久素材。公众号在公众平台官网素材管理模块中新建的永久素材,可通过"获取素材列表"获知素材的media\_id。 ``` resp = wx.material.get(media_id="BzzIfj9NcYYTuaPR_j133mW-veyn3sNRANnduEtdnss") print(resp) [{ 'title': 'Python实战', 'author': '观小鱼', 'digest': '通过python实战项目,快速掌握python开发', 'content': 'python实战总结<br /><img data-src="http://mmbiz.qpic.cn/mmbiz_png/QuFmLYzPJ2BbITcU1VNpEhH8XUsXbtcibQejDaVQMIicE6Wa6v3O5EUsfA3CNumdQAdsx2HrCDrmX6f6zaPk4reg/0%3E">', 'content_source_url': 'https://www.kancloud.cn/@guanfuchang', 'thumb_media_id': 'BzzIfj9NcYYTuaPR_j133keapTcjqt-9xZQkkN0qQ9Q', 'show_cover_pic': 1, 'url': 'http://mp.weixin.qq.com/s?__biz=MzA3NzgzMzA5Nw==&mid=100000028&idx=1&sn=01235aff2dee3ba7941ee3ff0be73444&chksm=1f4ab7fa283d3eec80b03af52b3b51a3affa140830a8dcb4baba7ec1c480055acab98a4e610f#rd', 'thumb_url': 'http://mmbiz.qpic.cn/mmbiz_jpg/QuFmLYzPJ2BbITcU1VNpEhH8XUsXbtcibqwCkTuX97EFSfqqbzYVfK8Em7WdHCicMta8sMoUJCLSTLoMjUJkpYsw/0?wx_fmt=jpeg', 'need_open_comment': 1, 'only_fans_can_comment': 1 }] ``` >[warning] 更多接口信息,请参考源码`WeChatClient`类 <hr style="margin-top:100px"> :-: ![](https://box.kancloud.cn/331f659e8e6cddb0d9f182e00e32803f_258x258.jpg) ***微信扫一扫,关注“python测试开发圈”,获取更多测试开发分享!***