登录
  • 人们都希望被别人需要 却往往事与愿违
  • (相对C而言)在C++里, 想搬起石头砸自己的脚更为困难了。不过一旦你真这么做了, 整条腿都得报销!@Bjarne Stroustrup (C++之父)

一个简单强大的Python天气预报库pyweathercn

编程 Benny小土豆 9461次浏览 2489字 6个评论
文章目录[显示]
这篇文章在 2019年01月23日17:04:22 更新了哦~

今天向大家介绍一款可以用来查询国内绝大部分城市天气预报的Python库pyweathercn,网上搜到的基本都不能用啦……

pyweathercn的作者正是大名鼎鼎的本人。

好吧,其实这个库我早在5月份的时候就写好了,但是由于太忙一直忘了这回事……

demo: https://weather.bennythink.com

特色

用法简洁

支持开启REST API风格的服务器,一库多用,异步非阻塞支持高并发,支持https

为啥要开发这个

因为我需要啊!上网搜罗了一波,各种天气预报API基本上都得注册,可能还得要钱,或者限制访问频率,这就让我非常不开心了。那么既然没人写过,那咱就只好自己写一个了啊。

不过需要注意的是,这个原理是爬虫并解析www.weather.com.cn,所以如果某天不好用了,很有可能就是人家网站改版了……

安装

需要注意的是,这个库并不支持Python 2,所以请使用Python 3

pip install pyweathercn

如果需要请自行替换为pip3

另外,如果你使用国内的PyPi源,可能现在还没更新到1.0.3呢……

其实这个库本应该是支持Python 2的,因为也没用什么Python 3才有的特性和语法用了一些的,但是我就是不想支持Python 2,不爽你来打我啊。不过非得想支持Python 2 的话,你可以下载tar包解压缩到site-packages啊

使用方法

普通模式

非常简单,支持chain call和实例模式,来几个例子:

>>> import pyweathercn

>>> pyweathercn.Weather('重庆').temp()

'重庆:20'

>>> w = pyweathercn.Weather('北京')

>>> w.data

{'data': {'city': '北京', 'aqi': '159', 'tip': '紫外线指数很强涂擦SPF20以上,PA++护肤品,避强光。穿衣指数热适合穿T恤、短薄外套等夏季服装。', 'temp': '20', 'forecast': [{'date': '23日(今天)', 'type': '晴', 'temp': '15℃', 'wind': '西南风 3-4级'}, {'date': '24日(明天)', 'type': '晴', 'temp': '31℃/17℃', 'wind': '南风 3-4级'}, {'date': '25日(后天)', 'type': '晴转多云', 'temp': '31℃/19℃', 'wind': '西南风 <3级'}, {'date': '26日(周六)', 'type': '阴转多云', 'temp': '30℃/16℃', 'wind': '西风 <3级'}, {'date': '27日(周日)', 'type': '多云', 'temp': '29℃/15℃', 'wind': '南风 <3级'}, {'date': '28日(周一)', 'type': '多云', 'temp': '25℃/15℃', 'wind': '东北风 <3级'}, {'date': '29日(周二)', 'type': '晴', 'temp': '29℃/15℃', 'wind': '西南风 <3级'}]}, 'status': 0, 'message': 'success'}

>>> w.today()

'北京:23日(今天)晴15℃西南风 3-4级'

>>> w.tomorrow(True)

{'date': '24日(明天)', 'type': '晴', 'temp': '31℃/17℃', 'wind': '南风 3-4级'}

>>> w.tip()

'北京温馨提示:紫外线指数很强涂擦SPF20以上,PA++护肤品,避强光。穿衣指数热适合穿T恤、短薄外套等夏季服装。'

>>> w.forecast(False,5)

'北京:28日(周一)多云25℃/15℃东北风 <3级'

其中tomorrow 等类方法的参数如果传布尔真值的话,将会显示原始json响应,不传或者传布尔假值会显示易于阅读的字符串。

其他的一些类方法,咱的IDE都有提示,我注释写的还算简单易懂,这里就不细说了

服务器模式

import pyweather
# running on http://127.0.0.1:8888
pyweathercn.server(host='127.0.0.1')
# running on http://0.0.0.0:3333
pyweathercn.server(3333)
# support ssl: https://www.example.com:8888
pyweathercn.server('8888', 'www.example.com', ssl_options={
"certfile": "fullchain.pem",
"keyfile": "privkey.pem"})

哪位好心人我啊可以开放一个公开的API给大家用,哈哈。

在服务器模式下的调用方法,需要请求/weather路由,必须参数为city,可选参数为day,使用get方法的url参数或者post方法的url-encode form,目前还不支持post json。

 

Nginx 反向代理

服务器用systemd等运行一个监听127.0.0.1的服务器模式python脚本,server块如下配置:

server {
listen 80;
server_name www.siteone.com; # 你的域名
location / {
proxy_pass http://127.0.0.1:8888;
}

如果需要https支持,可以参考这个配置文件

例子1 GET:呃请原谅我的pangu把url搞成了带空格的……

http://127.0.0.1:8888/weather?city=上海

一个简单强大的Python天气预报库pyweathercn

例子2 GET:

http://127.0.0.1:8888/weather?city=上海&day=3

一个简单强大的Python天气预报库pyweathercn

例子3 POST:

一个简单强大的Python天气预报库pyweathercn

PyPi仓库地址

https://pypi.org/project/pyweathercn/

GitHub源代码

开源地址
欢迎star、fork、PR


文章版权归原作者所有丨本站默认采用CC-BY-NC-SA 4.0协议进行授权|
转载必须包含本声明,并以超链接形式注明原作者和本文原始地址:
https://dmesg.app/pyweathercn.html
喜欢 (15)
分享:-)
关于作者:
If you have any further questions, feel free to contact me in English or Chinese.
发表我的评论
取消评论

                     

去你妹的实名制!

  • 昵称 (必填)
  • 邮箱 (必填,不要邮件提醒可以随便写)
  • 网址 (选填)
(6)个小伙伴在吐槽
  1. 求如何搞成tg机器人?
    hjh2019-03-23 21:26 回复
    • 这里 https://dmesg.app/tgbot0.html
      Benny小土豆2019-03-25 09:58 回复
  2. pangu是什么??
    nels0n2018-08-22 14:46 回复
    • https://github.com/vinta/pangu.js 这么个东西
      Benny小土豆2018-08-22 19:23 回复
      • 不能手动改掉吗?
        布偶君2018-09-30 20:19 回复
        • 懒~
          Benny小土豆2018-10-03 17:15