国际惯例,先上效果图

前天,突然想到,怎么直接在命令行查询天气呢?好的,那就写一个吧。然后就开始找城市、天气的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来完善它,谢谢。

 

基于nodejs的终端天气查询的更多相关文章

  1. H5天气查询demo(二)

    最近刚好有空,学长帮忙让做个毕设,于是我提到了那个基于H5地理位置实现天气查询的方法,学长听了也觉得不错,于是就这个主题,扩展了一下,做了一个航班管理查询系统,为上次博客中提到的利用H5 api中的经 ...

  2. [转] 基于NodeJS的前后端分离的思考与实践(五)多终端适配

    前言 近年来各站点基于 Web 的多终端适配进行得如火如荼,行业间也发展出依赖各种技术的解决方案.有如基于浏览器原生 CSS3 Media Query 的响应式设计.基于云端智能重排的「云适配」方案等 ...

  3. 基于node的cmd迷你天气查询工具

    1.前几天网上看到的,于是自己小改了一下,更换了天气查询的接口,当作练习一下node. 2.收获挺大的,捣鼓了一天,终于学会了发布npm包. 3.接下来,就介绍一下这个 mini-tianqi 的主要 ...

  4. 基于NodeJS的全栈式开发

    前言 为了解决传统Web开发模式带来的各种问题,我们进行了许多尝试,但由于前/后端的物理鸿沟,尝试的方案都大同小异.痛定思痛,今天我们重新思考了“前后端”的定义,引入前端同学都熟悉的 NodeJS,试 ...

  5. (转)也谈基于NodeJS的全栈式开发(基于NodeJS的前后端分离)

    原文链接:http://ued.taobao.org/blog/2014/04/full-stack-development-with-nodejs/ 随着不同终端(pad/mobile/pc)的兴起 ...

  6. node-odata: 基于 NodeJS 的 REST 框架

    该开源项目目前已被 OData 官网 (odata.org)收录 关于 node-odata node-odata 可以让你轻松创建 REST API, 并能使用 OData 协议的格式进行数据的查询 ...

  7. 也谈基于NodeJS的全栈式开发(基于NodeJS的前后端分离)

    前言 为了解决传统Web开发模式带来的各种问题,我们进行了许多尝试,但由于前/后端的物理鸿沟,尝试的方案都大同小异.痛定思痛,今天我们重新思考了“前后端”的定义,引入前端同学都熟悉的NodeJS,试图 ...

  8. 一个基于NodeJS开发的APP管理CMS系统

    花了大概3周独立开发了一个基于NodeJS的CMS系统,用于公司APP的内容管理( **公司APP?广告放在最后 ^_^ ** ,管理员请理解~~~ )晚上看了部电影还不想睡,闲着也是闲着就作下小小总 ...

  9. NodeBB,一个基于nodejs的响应式论坛

    喜欢方便的同学请绕道去discuz,好吧我是nodejs的重视患者,首先你要有自己的vps或则云空间,比如9cloud,我今天用的是阿里云的VPS. 进入阿里云Ubuntu主机 .... 输入密码进入 ...

随机推荐

  1. JDK7学习笔记之基础类型

    printf()的基础用法: 变量的基础用法: 字符的输出:

  2. 安装了SQL2005再安装SQL 2008R2,提示此计算机上安装了 Microsoft Visual Studio 2008 的早期版本和检查是否安装了 SQL Server 2005 Express 工具的解决方案

    工作电脑上安装了SQL 2005, 但是客户电脑上安装的是SQL 2008R2,有时候连接他们的库调试没法连接,很不方便.然后又安装了个SQL2008 R2,期间遇到这两个问题,网上搜索了一下收到了解 ...

  3. 使用 xtrabackup 进行MySQL数据库物理备份

    0. xtrabackup的功能 能实现的功能: 非阻塞备份innodb等事务引擎数据库. 备份myisam表会阻塞(需要锁). 支持全备.增量备份.压缩备份. 快速增量备份(xtradb,原理类似于 ...

  4. Kafka三款监控工具比较(转)

    在之前的博客中,介绍了Kafka Web Console这 个监控工具,在生产环境中使用,运行一段时间后,发现该工具会和Kafka生产者.消费者.ZooKeeper建立大量连接,从而导致网络阻塞.并且 ...

  5. js判断游览器是移动端还是PC端

    js判断网页游览器是移动端还是PC端 <script type="text/javascript"> function browserRedirect() { var ...

  6. 基于.net开发chrome核心浏览器【六】

    写在前面: 距离发这个系列的上一篇文章已经过去两个多月了 因为工作上不涉及这一部分的内容,兼且琐事缠身,一直无力动笔写这个系列的第六篇文章 然而,有很多朋友都关注这个系列,希望我能再写写. 写文章有人 ...

  7. 【原】css实现两端对齐的3种方法

    说到两端对齐,大家并不陌生,在word.powerpoint.outlook等界面导航处,其实都有一个两端对齐(分散对齐)的按钮,平时使用的也不多,我们更习惯与左对齐.居中对齐.右对齐的方式来对齐页面 ...

  8. 【一周读书】All life is problem solving

    书籍:<开放的智力> 采铜是我在知乎关注最早的大V之一,那时我脑里有一大堆疑惑和问题,是他的答案帮助我理清了思绪.我从他身上学习到对书籍的爱好,对思维方法的关注,对智慧的向往.读这本小集子 ...

  9. Caffe fine-tuning 微调网络

    转载请注明出处,楼燚(yì)航的blog,http://www.cnblogs.com/louyihang-loves-baiyan/ 目前呢,caffe,theano,torch是当下比较流行的De ...

  10. HDU 2516 取石子游戏

    Problem Description 1堆石子有n个,两人轮流取.先取者第1次可以取任意多个,但不能全部取完.以后每次取的石子数不能超过上次取子数的2倍.取完者胜.先取者负输出"Secon ...