1、前几天网上看到的,于是自己小改了一下,更换了天气查询的接口,当作练习一下node。

2、收获挺大的,捣鼓了一天,终于学会了发布npm包。

3、接下来,就介绍一下这个 mini-tianqi 的主要代码及实现。

安装方法:

$ npm install mini-tianqi -g

使用方法:

$ mini-tianqi shanghai // 中文和中文拼音都可以

源代码:https://github.com/tangxu2424/mini-tianqi

希望大家star一下,算是对我的鼓励哈


1、天气接口

我们使用心知天气的逐日天气预报接口:

https://api.seniverse.com/v3/weather/daily.json?key=your_api_key&start=0&days=3&location=

location参数: 可以允许很多种类型:

1、城市中文名,

2、城市拼音/英文,

3、ip地址 等等

start和days参数: 代表起始时间和需要从起始时间返回的天数

返回结果及具体参数,参考:https://www.seniverse.com/doc#now

2、核心代码

mini-tianqi

#!/usr/bin/env node

var colorful = require("colorful");
colorful.toxic(); //Let's posion the string object, just like colors does:'hello'.red
var package = require("../package.json");
//node mini-tianqi -h
//node mini-tianqi abcd mdzz
var param = process.argv[2];
if(process.argv.length > 3 || (param && param.toUpperCase() == "-H")){
console.log('tianqi ~ ' + package.version.green);
console.log(package.description.grey);
console.log(" $ ".cyan + "mini-tianqi 上海");
console.log(" $ ".cyan + "mini-tianqi shanghai");
return;
}
//如果有城市名这个参数,或者没有城市名这个参数则调用index.js的函数
//node mini-tianqi shanghai
//node mini-tianqi
var tianqi = require("../src/index");
tianqi(param);

1、第一行代码很关键,就是让此文件用node命令来执行,install以后可直接用mini-tianqi命令。

2、图片中命令行的字体颜色就是用了colorful这个包

3、根据参数数量来显示提示语或调用主函数显示天气

index.js

var request = require("request");
var config = require("../config");
var print = require("./print"); module.exports = function (word) {
if (word) {
getDataByCityName(word);
} else {//没有输入城市名则默认根据读取当前城市的天气
request.get(config.ip.url, function (error, response, body) {
var ipResult = JSON.parse(body);
getDataByCityName(ipResult.ip);
});
}
}; function getDataByCityName(word) {
word = encodeURIComponent(word);//可把字符串作为 URI 组件进行编码
var options = {
url: config.weather.url + word,
};
request.get(options.url, function (error, response, body) {
//console.log(body);
if (!error && response.statusCode == 200) {
print.print(JSON.parse(body));
}
});
}

这两段代码其实很简单,就是用request做请求,

第一段是获取你当前所在城市的ip,http://whois.pconline.com.cn/ipJson.jsp?json=true

第二段是根据城市ip或者名称获取天气json

其实可以不用请求获取当前所在城市的ip地址:

“ip”两个字母 自动识别请求IP地址,例如:location=ip

print.js

exports.print = function (data) {
if (data) {
//console.log(data.results[0].location);
printToday(data.results[0].location, data.results[0].daily[0]);
printForecast(data.results[0].daily);
} else {
console.log(data.errMsg.red);
}
};
function printToday(city,today) {
console.log("\n " + city.name.cyan.bold+"今日天气".cyan.bold)
var todayStr = "\n "+today.date.bold + "白天 ".bold + today.text_day.green + " 晚上 ".bold + today.text_night.green;
todayStr += " 最低温度 " + today.low.cyan;
todayStr += " 最高温度 " + today.high.red;
todayStr += " 风力 " + today.wind_scale.yellow;
todayStr += "\n";
console.log(todayStr);
}
function printForecast(forecast) {
console.log( "\n"+" 未来两天预报~".cyan.bold);
forecast.forEach(function (data,index) {
if(index<1){return false};
var str = "\n " + data.date.bold + "白天 ".bold + data.text_day.green + " 晚上 ".bold + data.text_night.green;
str += " 最低温度 " + data.low.cyan;
str += " 最高温度 " + data.high.red;
str += " 风力 " + data.wind_scale.yellow;
str += "\n";
console.log(str);
});
}

这段代码很简单,就是打印内容的排版,对返回天气json的解析拼接

3、总结一下

这个迷你天气算是我这个node菜鸟的小练习,不算是完全原创,有模仿之嫌。

主要的收获是学会了怎么发布npm包,还涉及到了Travis-cipackage.json的配置

下个目标:做一个vue的插件,然后发布到npm,fighting~

基于node的cmd迷你天气查询工具的更多相关文章

  1. 认识Web前端、Web后端、桌面app和移动app新开发模式 - 基于Node.js环境和VS Code工具

    认识Web.桌面和移动app新开发模式 - 基于Node.js环境和VS Code工具 一.开发环境的搭建(基于win10) 1.安装node.js和npm 到node.js官网下载安装包(包含npm ...

  2. 基于node和npm的命令行工具——tive-cli

    前端开发过程中经常会用到各种各样的脚手架工具.npm全局工具包等命令行工具,如:Vue脚手架@vue/cli.React脚手架create-react-app.node进程守卫工具pm2.本地静态服务 ...

  3. 基于node实现一个简单的脚手架工具(node控制台交互项目)

    实现控制台输入输出 实现文件读写操作 全原生实现一个简单的脚手架工具 实现vue-cli2源码 一.实现控制台输入输出 关于控制台的输入输出依然是基于node进程管理对象process,在proces ...

  4. TDSQL“相似查询工具MSQL+”入选VLDB论文

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯云数据库 TencentDB发表于云+社区专栏 作者介绍:王晓宇,腾讯数据库TDSQL团队成员,目前参与TDSQL数据库内核研发工 ...

  5. 【转】根据中国气象局提供的API接口实现天气查询

    本文转载自 老三 的 三叶草 中国气象局提供了三个天气查询的API接口: [1]http://www.weather.com.cn/data/sk/101190101.html [2]http://w ...

  6. C# Winform实现手机号码归属地查询工具

    摘要:本文介绍使用C#开发基于Winform的手机号码归属地查询工具,并提供详细的示例代码供参考. 一.需求描述 输入正确的手机号码,查询该号码的归属地和其他相关信息. 二.需求分析 1.实现手机号码 ...

  7. 基于nodejs的DNS查询工具

    开始这个实例之前,我们简单谈一下Node.js吧,Node.js是一个由JavaScript书写而成的强大Web开发框架,它让开发强壮的.伸缩性良好的服务器端Web应用变得更加简单.容易.这种技术诞生 ...

  8. 给Clouderamanager集群里安装基于Hive的大数据实时分析查询引擎工具Impala步骤(图文详解)

    这个很简单,在集群机器里,选择就是了,本来自带就有Impala的. 扩展博客 给Ambari集群里安装基于Hive的大数据实时分析查询引擎工具Impala步骤(图文详解)

  9. 给Ambari集群里安装基于Hive的大数据实时分析查询引擎工具Impala步骤(图文详解)

    不多说,直接上干货! Impala和Hive的关系(详解) 扩展博客 给Clouderamanager集群里安装基于Hive的大数据实时分析查询引擎工具Impala步骤(图文详解) 参考 horton ...

随机推荐

  1. css3 媒体查询的学习。

    1.什么是媒体查询 媒体查询可以让我们根据设备显示器的特性(如视口宽度.屏幕比例.设备方向:横向或纵向)为其设定CSS样式,媒体查询由媒体类型和一个或多个检测媒体特性的条件表达式组成.媒体查询中可用于 ...

  2. (转)为什么国外 MMORPG 中不采用自动寻路等功能?

    不只是自动寻路,现在网游中的教学引导系统,辅助系统的功能强大程度,友好程度都可以说到了变态的程度,开发这些功能投入的资源甚至要超过游戏内容本身.究其原因,还是竞争越来越激烈,人心越来越浮躁,游戏商家为 ...

  3. request中的那些方法到底是干什么的?

    最近做Java Web项目,在.jsp页面和servlet之间request和response还是有些混淆,查阅了一些资料,总结如下,方便以后使用: 首先,servlet接口是最基本的,提供的五个方法 ...

  4. python -- sftp的方式下载终端文件

    可以通过paramiko模块进行远程连接,然后指定文件夹,进行下载. sf = paramiko.Transport((host, port)   #创建链接对象,需要终端ip以及sftp使用的端口号 ...

  5. python web框架的介绍

    随着互联网的兴起,web开发变得愈发的重要.Python作为当前火热的语言, 其中的web开发框架可以说是百花齐放,下面聊一聊这些框架. 一: 基于Python的代表性Web框架 Django Dja ...

  6. HDU 6274 二分+预处理(CCPC K题

    #include"bits/stdc++.h" #define db double #define ll long long #define vec vector<ll> ...

  7. ELK之Elasticsearch

    安装并运行Elasetisearch cd elasticsearch-<version> ./bin/elasticsearch 如果你想把 Elasticsearch 作为一个守护进程 ...

  8. Java线程和多线程(七)——ThreadLocal

    Java中的ThreadLocal是用来创建线程本地变量用的.我们都知道,访问某个对象的所有线程都是能够共享对象的状态的,所以这个对象状态就不是线程安全的.开发者可以通过使用同步来保证线程安全,但是如 ...

  9. MyBatis---缓存策略cache的使用

    一般在查询时使用 使用步骤 1.配置config.xml,开启缓存 <setting name=”cacheEnabled” value=”true” /> 2.在Mapper文件头指定使 ...

  10. Start with PJSIP on windows

    To overcome the project of HD video conferencing systerm,I should learn to use the PJSIP. I should m ...