概述:

本文主要分享一下博主在学习wxpy 的过程中开发的一个小程序。博主在最近有一个监控报警的需求需要完成,然后刚好在学习wxpy 这个东西,因此很巧妙的将工作和学习联系在一起。

博文中主要使用到的技术设计到Python,Redis,以及Java。涉及到的技术看似很多,但是主要的语言是基于Python进行开发的。

架构涉及主要采用了 生产者消费者的涉及模式,使用Redis作为消息队列进行解耦操作。

主要架构涉及如下:

接下来开始介绍一下程序的实现过程,主要讲解wxpy -> python.redis -> Java.redis

1、Wxpy初体验

项目使用的python 是3.5版本的,因此语法会和2.x版本有所区别,wxpy 支持python3.4-3.6 以及python2.7版本 ,因此在python版本上不用太过于纠结

1.1 安装wxpy

在这里默认大家以及安装好了pip,我们需要安装wxpy 以及wechat_sender 两个包,这里推荐使用国内的豆瓣源,如果大家网速过硬 请忽略。。。。

1.2 wxpy 登陆

wxpy 使用起来非常简单,我们只需要创建一个bot 对象,程序运行后,会弹出二维码,扫描二维码后显示登陆成功。

下述代码在登陆完成后,会向我们的文件传输助手发送一个“hello world!”。(每个程序都需要一个hello world)

from wxpy import * bot = Bot() bot.file_helper.send('hello world!') print("ending")

关于Bot()对象的相关参数说明,我们可以在源码中的注释中看到:

"""

:param cache_path:

* 设置当前会话的缓存路径,并开启缓存功能;为 `None` (默认) 则不开启缓存功能。

* 开启缓存后可在短时间内避免重复扫码,缓存失效时会重新要求登陆。

* 设为 `True` 时,使用默认的缓存路径 'wxpy.pkl'。

:param console_qr:

* 在终端中显示登陆二维码,需要安装 pillow 模块 (`pip3 install pillow`)。

* 可为整数(int),表示二维码单元格的宽度,通常为 2 (当被设为 `True` 时,也将在内部当作 2)。

* 也可为负数,表示以反色显示二维码,适用于浅底深字的命令行界面。

* 例如: 在大部分 Linux 系统中可设为 `True` 或 2,而在 macOS Terminal 的默认白底配色中,应设为 -2。

:param qr_path: 保存二维码的路径

:param qr_callback: 获得二维码后的回调,可以用来定义二维码的处理方式,接收参数: uuid, status, qrcode

:param login_callback: 登陆成功后的回调,若不指定,将进行清屏操作,并删除二维码文件

:param logout_callback: 登出时的回调

"""

这里介绍一下两个主要使用到的参数:

cache_path: 在开发过程中可以设置为True 避免每次登陆都需要重新扫描,具有缓存的作用。

qr_path:用于保存二维码生成图片,主要解决服务器图片展示不方便的问题

1.3 wxpy 好友与聊天群

如代码所示,我们可以通过Bot.friends 以及Bot.groups 来获取到所有的好友以及聊天群,这里需要注意的是,聊天群需要保存到通讯录中,不然可能会出现找不到聊天群的情况。

在搜索方法中,可以提供的参数有:姓名,city,province,sex 等相关变量。

from wxpy import *

bot = Bot()

# 获取所有好友

friends = bot.friends()

# 遍历输出好友名称

for friend in friends:

print(friend)

# 找到好友

friend = bot.friends.search('被单')[0]

print(friend)

friend.send("hello world!")

# 获取所有聊天群

groups = bot.groups()

for group in groups:

print(group)

# 找到目标群

group = groups.search("409")[0]

group.send("hello world!")

1.4 wxpy 消息处理

接下来主要介绍一下用户发送消息的类型,目前wxpy 支持发送文本,图片,视频以及文件。主要的发送方式如代码所示:

这里比较重要的就是关于 @bot.register() 的使用,该注释主要用于注册消息接收器,我们可以根据特定的需求,配置不一样的消息接收器。

Bot.register(chats=None, msg_types=None, except_self=True, run_async=True, enabled=True) 详情可以查看源码中的介绍

关于消息处理API,读者可以在该地址下查看详细的配置,这里不做过多的描述。

代码中有使用到:embed() 这个方法, 主要用于阻塞进程,避免由于程序运行结束导致无法接收消息。

from wxpy import *

bot = Bot()

# 获取好友

my_friend = bot.friends().search('被单')[0]

# 搜索信息

messages = bot.messages.search(keywords='测试', sender=bot.self)

for message in messages:

print(message)

# 发送文本

my_friend.send('Hello, WeChat!')

# 发送图片

my_friend.send_image('my_picture.png')

# 发送视频

my_friend.send_video('my_video.mov')

# 发送文件

my_friend.send_file('my_file.zip')

# 以动态的方式发送图片

my_friend.send('@img@my_picture.png')

# 发送公众号

my_friend.send_raw_msg(

# 名片的原始消息类型

raw_type=42,

# 注意 `username` 在这里应为微信 ID,且被发送的名片必须为自己的好友

raw_content=''

)

# 消息接收监听器

@bot.register()

def print_others(msg):

# 输出监听到的消息

print(msg)

# 回复消息

msg.reply("hello world")

embed()

1.4 wxpy 图灵机器人

wxpy 接入图灵机器人相当方便,我们首先需要到图灵近期人官网进行注册,哆啦A梦的任意门。

通过注册Tuling 对象,当我们接收到消息的时候,可以直接使用tuling机器人来帮我们进行答复。其他的业务需求各位可以根据自己的需求来完成相应的逻辑。

from wxpy import *

bot = Bot()

# 获取好友

dear = bot.friends().search('被单')[0]

# 注册获得个人的图灵机器人key 填入

tuling = Tuling(api_key='******')

# 使用图灵机器人自动与指定好友聊天

@bot.register(dear)

def reply_my_friend(msg):

print(msg)

tuling.do_reply(msg)

embed()

1.5 wechat_sender

在熟悉了wxpy 的相关操作后,我们接下来介绍一下一个主要使用到的工具。由于wxpy 的设计,导致了一些业务操作并不好进行实现。因此我们在这里引入一个工具类:wechat_sender 。

首先我们需要像往常一样进行微信登陆,然后使用 listen()进行对我们的 bot() 对象进行监听。

在这里我们可以看到了和上面代码的区别,这里使用的是listen(),上面是使用embed()进行监听。 我们再这里使用listen 进行监听对象后,可以设置相应的配置。监听默认设置的接收对象为self.file_helper,通过设置receivers 可以配置消息的接收者。

# login.py

from wxpy import *

from wechat_sender import *

bot = Bot()

friend = bot.friends().search('被单')[0]

listen(bot, token='test', receivers=[friend])

# sender.py coding: utf-8

from wechat_sender import Sender

sender = Sender(token='test')

sender.send('hello world!')

在别的python 文件中,我们只需要创建一个Sender() 对象,然后调用Sender.send()方法,即可对我们设定好的消息接收者发送消息。

Sender()在创建的时候可以通过特定的参数设定,比如这里使用了 token 用于避免多个listen 导致sender 混淆。还可以在sender中设置receiver 从listen 中选取需要接收消息的对象。

1.6 wxpy 在监控模块的代码实现

微信登陆模块:

from wechat_sender import *

from wxpy import *

bot = Bot(qr_path="qr.png")

group = bot.groups().search('监控报警')[0]

print("微信登陆成功!进行监控报警功能!")

print(group)

#

listen(bot, token='test', receivers=[group])

业务处理模块:

import redis

from wechat_sender import *

sender = Sender(token='test', receivers='监控报警')

while true:

# do anything

sender.send(message=data)

# do anything

p.unsubscribe('cardniu-monitor')

print('取消订阅')

2、Python-Redis

这一模块我们将简单描述一下python 对于Redis 的支持,首先我们需要安装python-redis相关模块:

2.1 Python-redis安装解压进入 Redis 目录

命令行执行: python setup.py install

2.2 Python 简单操作Redis

由于Python 操作Redis 并不是我们这里的主要内容,所以这里简单的过一下Python 对Redis 的支持。

import redis

r = redis.Redis(host='ip', port=6379, db=15, password='****')

r.set('name', 'Jaycekon')

value = r.get('name')

print(value)

2.3 Redis的发布订阅模式

在为大家讲解Redis 的发布订阅模式前,先为大家科普一下生产者消费者模式:

大家来领略一下我的灵魂画图,生产者消费者的核心思想是通过一个冰箱来进行解耦,就是我们的厨师不需要出厨房,顾客也不需要去厨房拿饭吃。通过一个冰箱来进行中间的解耦合。

下面是我们通过python 实现的一个生产者消费者模式,厨师不停的做饭,顾客不停的吃。。大家相互不影响。

from threading import Thread

queues = queue.Queue(10)

class Producer(Thread):

def run(self):

while True:

elem = random.randrange(9)

queues.put(elem)

print("厨师 {} 做了 {} 饭 --- 还剩 {} 饭没卖完".format(self.name, elem, queues.qsize()))

time.sleep(random.random())

class Consumer(Thread):

def run(self):

while True:

elem = queues.get()

print("吃货{} 吃了 {} 饭 --- 还有 {} 饭可以吃".format(self.name, elem, queues.qsize()))

time.sleep(random.random())

def main():

for i in range(3):

p = Producer()

p.start()

for i in range(2):

c = Consumer()

c.start()

if __name__ == '__main__':

main()

基于python的视频监控系统_Python实现微信监控报警系统相关推荐

  1. 基于python的网上书店系统_Python开发技术大全

    前言 第1篇 Python编程基础 第1章 Python语言基础2 1.1 Python语言介绍2 1.2 Python版本介绍3 1.2.1 Python语言的版本3 1.2.2 Python的实现 ...

  2. 基于python的网上书店系统_python实现基于CGI的Web应用

    Welcome to My Book Store. please choose your favorite book, clickhere. Enjoy!

  3. python毕业设计开题报告-基于Python的教学互动系统的设计与实现开题报告

    基于Python的教学互动系统的设计与实现开题报告 背景: 在各种信息技术与课堂的不断探索中,我们一直在寻找一个能提高教学效率的方式,同时可以发现要提高教学效率,在课堂教学中必不可少的就是师生间的互动 ...

  4. 基于Python的飞机票销售系统的设计和实现

    <基于Python的飞机票销售系统的设计和实现>该项目采用技术Python的django框架.mysql数据库 ,项目含有源码.论文.PPT.配套开发软件.软件安装教程.项目发布教程.核心 ...

  5. 基于内容的视频信息检索系统

    基于内容的视频信息检索系统 汪志强 (江西财经大学信息管理学院 09信息管理与信息系统2班) 摘 要: 本文从基于内容的视频信息检索技术的发展历史出发,对基于内容的视频检索系统的技术要点及主要的功能模 ...

  6. python商城系统_基于python的海鲜商城系统

    20006 基于python的海鲜商城系统 运行视频.代码等: 链接:https://pan.baidu.com/s/1tw4Qvtcuwt7ys36M7HvLSg 提取码:1589 复制这段内容后打 ...

  7. 基于Python的在线办公系统的设计和实现

    <基于Python的在线办公系统的设计和实现>该项目采用技术Python的django框架.mysql数据库,项目含有源码.论文.PPT.配套开发软件.软件安装教程.项目发布教程.核心代码 ...

  8. 基于Python的人工智能美颜系统

    基于Python的人工智能美颜系统使用PyQt5模块搭建可视化界面,使用Dlib模型(shape_predictor_68_face_landmarks.dat)实现人脸关键点检测和定位,人脸美颜(美 ...

  9. 基于python的分布式扫描器_基于python的服务器监测系统的设计

    基于 python 的服务器监测系统的设计 高正 ; 徐浩 ; 余曼 [期刊名称] <电脑知识与技术> [年 ( 卷 ), 期] 2017(013)002 [摘要] 本文介绍了一种基于 P ...

最新文章

  1. 记录一次简单、高效、无错误的linux上安装pytorch的过程
  2. iOS UICollectionView的实现
  3. 点钞机语音怎么打开_抖音内测语音直播!支持8人在线聊天,一文教你如何玩?...
  4. centos查看当前目录下文件大小_centos Linux 统计某个文件夹占用空间大小
  5. h700通话糊 索尼wi_专业的事还是要交给专业的人,盘点索尼千元以下的好耳机...
  6. adapter 适配器
  7. mongodb和mysql中自动增长id_MongoDB 自动增长
  8. Java运行时数据区及对象的分配
  9. uip UDP 服务器广播模式(客户端可以任意端口,并且主动向客户端发送数据) (转)...
  10. Java HTTPS客户端如何处理证书
  11. MSN Messenger 协议
  12. ImageOptim使用教程之图片压缩的方法
  13. Notepad++文本比较
  14. PLC模拟量数据的处理
  15. 玩转git之webhook应用初探
  16. 自动登录QQ空间 --- Selenium打开带有xpath-helper的chrom
  17. Python基础_Day_01_作业
  18. error: ‘integer_sequence’ is not a member of ‘std’
  19. 欧科云链亮相央视《新闻直播间》,书写科技助警新篇章
  20. 检查数组是否包含某个值

热门文章

  1. 《软件需求分析(第二版)》第 12 章——需求确认 重点部分总结
  2. mysql 先删后增 更新_MySQL 高级操作——新增数据、更新数据、删除数据、查询数据...
  3. 超大规模集成电路_纳米级超大规模集成电路芯片低功耗物理设计分析(二)
  4. oracle如何设置权限,ORACLE的权限设置
  5. php times33,PHP Hash算法:Times33算法代码实例
  6. mysql 升级 openssl_【1分钟教程】LNMP架构应用实战 Openssl升级操作
  7. 计算机缺少fixos.dll,fix_toolbox.dll
  8. [分布式训练] 单机多卡的正确打开方式:理论基础
  9. 浏览器是指在用户计算机上,自考《网页设计与制作》测试题及答案
  10. 安装oracle不动了,windows2008安装ORACLE到2%不动的问题 | 信春哥,系统稳,闭眼上线不回滚!...