设为首页 收藏本站
查看: 1147|回复: 0

[经验分享] 基于nodejs的终端天气查询

[复制链接]

尚未签到

发表于 2017-2-22 10:40:07 | 显示全部楼层 |阅读模式
国际惯例,先上效果图
DSC0000.jpg






前天,突然想到,怎么直接在命令行查询天气呢?好的,那就写一个吧。然后就开始找城市、天气的api接口,最终做出来这么一个东西。
安装方法:$ npm install tianqi -g
源码 : https://github.com/smallyard/tianqi



一、 天气接口


  网上搜了一个,最开始准备使用中国天气网的数据接口,但是需要注册,也行,注册就注册吧。
  注册好了,又提示信息不完整,好吧,填写姓名、身份证...
  最后,还要上传身份证信息,看到这我不想用它了,紧接着发现,还要填写使用该接口的服务器ip。
  顿时,心中十万个那个啥呼啸而过...
  这时想起百度的产品里有个API store,搜索了下,果然找到了合适的接口。
  城市接口
  http://apistore.baidu.com/microservice/cityinfo?cityname=城市名



{"errNum":0,"retMsg":"success","retData":{"cityName":"\u5317\u4eac","provinceName":"\u5317\u4eac","cityCode":"101010100","zipCode":"100000","telAreaCode":"010"}}

  天气接口
  http://apis.baidu.com/apistore/weatherservice/recentweathers?cityid=城市编码

  该请求需要在header中添加apikey字段,该值可以在百度天气接口中获取。




二、 代码编写
  1. bin/tianqi 天气入口代码



#!/usr/bin/env node
require("colorful").toxic();
var package = require("../package")
if (!process.argv[2]) {
console.log('tianqi ~ ' + package.version.green);
console.log(package.description.grey);
console.log("  $ ".cyan + "tianqi 北京");
console.log("  $ ".cyan + "tianqi 上海");
return;
}
console.log();
var tianqi = require('..');
tianqi(process.argv.slice(2).join(' '));


  第一行,设置该文件将被node来执行。
  如果没有参数,则输出tianqi的版本信息和使用示例。
  如果有参数,则调用index.js的函数。
  2.index.js 主函数



var request = require("request");
var config = require("./lib/config");
var print = require("./lib/print");
module.exports = function (word) {
word = encodeURIComponent(word);
request.get(config.city + word, function (error, response, body) {
if (!error && response.statusCode == 200) {
var cityResult = JSON.parse(body);
if (cityResult.errNum == 0) {
var options = {
url: config.weather + cityResult.retData.cityCode,
headers: {
"apikey": config.apikey
}
};
request.get(options, function (error, response, body) {
if (!error && response.statusCode == 200) {
print.print(JSON.parse(body));
}
});
} else {
console.log(cityResult.retMsg.red);
}
}
});
};


  首先,请求城市接口,获取用户输入城市的编码。
  然后请求天气接口,获取天气数据。
  最后调用print.js,输出天气信息。
  3.print.js 输出信息



exports.print = function (data) {
if (data.errNum == 0) {
var today = data.retData.today;
var todayStr = " 今天天气 " + today.type.magenta;
todayStr += "  当前温度 " + today.curTemp.green;
todayStr += "  最低温度 " + today.lowtemp.blue;
todayStr += "  最高温度 " + today.hightemp.red;
todayStr += "  风力 " + today.fengli.yellow;
console.log(todayStr);
console.log();
var forecast = data.retData.forecast;
console.log(" 未来四天预报~".cyan);
console.log();
forecast.forEach(function (data) {
var str = " " + data.date + " " + data.type.magenta;
str += " 最低温度 " + data.lowtemp.blue;
str += "  最高温度 " + data.hightemp.red;
str += "  风力 " + data.fengli.yellow;
console.log(str);
console.log();
});
} else {
console.log(data.errMsg.red);
}
};


  这个比较简单,就不解释了。

三、 总结


  这个tianqi查询软件,算是自己对nodejs的一次简单的实践吧。
  所用到的知识点包括http请求、JSON的解析、npm包的发布
  总的说起来,还是比较简单的,分享给大家。
  源码发布在github:https://github.com/smallyard/tianqi
  随时欢迎大家提issue,或发起pull request来完善它,谢谢。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-345605-1-1.html 上篇帖子: 使用nodejs爬取拉勾苏州和上海的.NET职位信息 下篇帖子: ASP.NET Core 性能对比评测(ASP.NET,Python,Java,NodeJS)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表