forked from matryer/xbar-plugins
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request matryer#1440 from JAckZ97/master
Create weather.1h.py
- Loading branch information
Showing
1 changed file
with
100 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,100 @@ | ||
#!/usr/bin/env python | ||
# -*- coding: utf-8 -*- | ||
|
||
# <xbar.title>OWM_Weather</xbar.title> | ||
# <xbar.version>v1.0</xbar.version> | ||
# <xbar.author>Jack Zhang</xbar.author> | ||
# <xbar.author.github>JAckZ97</xbar.author.github> | ||
# <xbar.desc>Using weather information from openweathermap (OWM). Require signup for personal API key and your own locations id. Information detail inside the source code</xbar.desc> | ||
# <xbar.image>https://raw.githubusercontent.com/JAckZ97/Bitbar_weather_plugin/master/img/src_image.png</xbar.image> | ||
# <xbar.dependencies>python</xbar.dependencies> | ||
# <xbar.abouturl>https://github.com/JAckZ97/Bitbar_weather_plugin</xbar.abouturl> | ||
|
||
import json | ||
import urllib2 | ||
from random import randint | ||
|
||
# Search your own city id by: https://openweathermap.org/city | ||
location = '6077243' # Montreal City id | ||
api_key = '8b4824b451d5db1612156837df880f55' # OWM API key | ||
units = 'metric' # kelvin, metric, imperial | ||
lang = 'en' | ||
|
||
|
||
def get_wx(): | ||
|
||
if api_key == "": | ||
return False | ||
|
||
try: | ||
wx = json.load(urllib2.urlopen('http://api.openweathermap.org/data/2.5/weather?id=' + location + | ||
'&units=' + units + '&lang=' + lang + '&appid=' + api_key + "&v=" + str(randint(0, 100)))) | ||
|
||
except urllib2.URLError: | ||
return False | ||
|
||
if units == 'metric': | ||
unit = 'C' | ||
elif units == 'imperial': | ||
unit = 'F' | ||
else: | ||
unit = 'K' # Default is kelvin | ||
|
||
try: | ||
weather_data = { | ||
'temperature': str(int(round(wx['main']['temp']))), | ||
'feels_like': str(int(round(wx['main']['feels_like']))), | ||
'temp_min': str(int(round(wx['main']['temp_min']))), | ||
'temp_max': str(int(round(wx['main']['temp_max']))), | ||
'pressure': str(int(round(wx['main']['pressure']))), | ||
'humidity': str(int(round(wx['main']['humidity']))), | ||
'wind_speed': str(int(round(wx['wind']['speed']))), | ||
'wind_deg': str(int(round(wx['wind']['deg']))), | ||
'weather_icon': wx['weather'][0]['icon'], | ||
'weather_description': wx['weather'][0]['description'], | ||
'city': wx['name'], | ||
'unit': '°' + unit | ||
} | ||
except KeyError: | ||
return False | ||
|
||
return weather_data | ||
|
||
|
||
def render_wx(): | ||
weather_data = get_wx() | ||
|
||
tridash = '\n' + '---' + '\n' | ||
if weather_data is False: | ||
return 'Err' + tridash + 'Could not get weather; Maybe check API key or location?' | ||
|
||
weather_temp_with_unit = weather_data['temperature'] + weather_data['unit'] | ||
return weather_temp_with_unit | ||
|
||
|
||
def render_wx_detail_temp(): | ||
weather_data = get_wx() | ||
|
||
weather_temp_details = "Temp_min: " + \ | ||
weather_data['temp_min'] + weather_data['unit'] + "Temp_max: " + \ | ||
weather_data['temp_max'] + weather_data['unit']+"Feels like: " + \ | ||
weather_data['feels_like'] + weather_data['unit'] | ||
|
||
return weather_temp_details | ||
|
||
|
||
weather_data = get_wx() | ||
|
||
|
||
print("MTL temp: " + render_wx()+"☁️") | ||
print("---") | ||
print("Feels like: " + weather_data['feels_like'] + weather_data['unit']) | ||
print("Temp_min: " + weather_data['temp_min'] + weather_data['unit'] + | ||
" / " + "Temp_max: " + weather_data['temp_max'] + weather_data['unit']) | ||
print("---") | ||
print("Description: " + weather_data['weather_description']) | ||
print("Humidity: " + weather_data['humidity']+"%") | ||
print("Pressure: " + weather_data['pressure']+" hPa") | ||
print("Wind_speed: " + weather_data['wind_speed']) | ||
print("Wind_deg: " + weather_data['wind_deg']) | ||
|