使用nodejs的wxmnode模块,开发一个微信自动监控提醒功能,做个天气预报。
2022/6/20 1:22:09
本文主要是介绍使用nodejs的wxmnode模块,开发一个微信自动监控提醒功能,做个天气预报。,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
这个模块是一个公众号的模块,名字叫“帮你看着”。
原本这个公众号是做股票监控提醒的,我也没炒股。因为接口支持写入任何内容,所以可以有其他的用处。比如做成天气预报定时提醒。
我们去npmjs中看下这个模块的详情。
可以看出,在使用之前,需要先关注一下一个用于接收提醒的公众号,
扫码,然后获得生成的账号和密码,就能使用这个模块了。
直接安装即可,而且使用方式也很简单:
const wxm = require('wxmnode'); let name = "80010120";//公众号生成的账号 let pwd ="888889";//公众号生成的密码 let content ="a";//内容 let type ="b";//类型 let desc ="c";//描述 let result = await wxm.sendMsgToUser(name, pwd, content, type, desc);//一次性方式 //或者 wxm.init(name, pwd ); let result = await wxm.sendMsg( content, type, desc);//绑定后发送
效果如下:
可以看出,要提醒的内容都被发送到了微信中了。
好了,发送到微信的功能找好了,我们在去找找获取天气情况的网站,然后把需要的内容抓取过来实时发送就可以了。
直接百度搜“天气”,这个网站就不错,而且看了下里面的数据量很全。
而且,url中可以直接看所填地区的天气。然后它的数据内容可以直接在源代码的json数据中能找到,这样就更方便解析了。
源代码:
nodejs中引入jquery和jsdom,和loadPage。
const { loadPage } = require("../../utils/utils"); const jQuery = require("jquery"); const jsdom = require("jsdom"); const { JSDOM } = jsdom; /** * 获取百度天气信息 */ module.exports = async (area = "西湖区") => { const content = await loadPage( `${"https://"}weathernew.pae.baidu.com/weathernew/pc?query=${encodeURIComponent( area + "天气" )}&srcid=4982` ); const { document } = new JSDOM(content).window; const window = document.defaultView; const $ = jQuery(window); const dataStr = $("script") .eq(0) .text() .replace("window.tplData =", "") .replace(";", ""); return JSON.parse(dataStr) || {}; };
loadPage为获取外部网页的html源码的,可以直接使用http模块来获取。
获取后使用jquery的 $("script").eq(0).text().replace("window.tplData =", "").replace(";", ""); 来拿到需要的部分。
所以,谁说现在没有jquery的使用需求呢,抓取数据不就是它的应用之一吗。只是需求不会很多罢了。
使用JSON.parse(dataStr) 把数据转换成json格式。
之后,导入node-schedule 和 wxmnode,
把需要发送提醒的用户账号密码和地区发送放在数组中。当然灵活一点可以使用数据库进行存放。
遍历每个用户,data为当前用户所在地区的天气预报数据,然后使用await wxm.sendMsg(content, type, desc) 即可发送内容到微信中。微信中就可以收到信息了。
另外可以使用schedule.scheduleJob 设置指定时间来触发发送到微信。把程序跑在云服务器里就可以了。
//定时获取百度天气信息 const scheduleBaiduWeather = async () => { //天气信息发送到微信 async function weatherToWX() { //每个用户都发送一次 for (let item of userList) { const data = await getBaiduWeather(item.area); const { weather = {} } = data; const day15 = data["15_day_forecast"].info || []; //未来15天天气 let content = `${item.area}天气:\n\n${weather.weather},${weather.temperature}℃,${weather.wind_direction}${weather.wind_power}\n\n${weather.bodytemp_info},${weather.precipitation_type}`; let type = "小海提醒"; let desc = `今天全天:白天(${day15[0].weather_day}),晚上(${day15[0].weather_night}),${day15[0].temperature_night}℃ - ${day15[0].temperature_day}℃\n` + `明天全天:白天(${day15[1].weather_day}),晚上(${day15[1].weather_night}),${day15[1].temperature_night}℃ - ${day15[1].temperature_day}℃\n` + `后天全天:白天(${day15[2].weather_day}),晚上(${day15[2].weather_night}),${day15[2].temperature_night}℃ - ${day15[2].temperature_day}℃\n`; wxm.init(item.name, item.pwd); //初始化用户 let ret = await wxm.sendMsg(content, type, desc); if (ret.code !== "0000") { console.log("发送天气失败", ret); } } } //每天6点触发 schedule.scheduleJob("0 0 6 * * *", async () => { weatherToWX(); }); }; scheduleBaiduWeather()
这篇关于使用nodejs的wxmnode模块,开发一个微信自动监控提醒功能,做个天气预报。的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-16Vue3资料:新手入门必读教程
- 2024-11-16Vue3资料:新手入门全面指南
- 2024-11-16Vue资料:新手入门完全指南
- 2024-11-16Vue项目实战:新手入门指南
- 2024-11-16React Hooks之useEffect案例详解
- 2024-11-16useRef案例详解:React中的useRef使用教程
- 2024-11-16React Hooks之useState案例详解
- 2024-11-16Vue入门指南:从零开始搭建第一个Vue项目
- 2024-11-16Vue3学习:新手入门教程与实践指南
- 2024-11-16Vue3学习:从入门到初级实战教程