Awesome-omni-skill weather-forecaster

Use this skill whenever the user asks about weather forecasts, weather conditions, or weekly weather outlooks for any location. Triggers include: any mention of '天气', 'weather', '预报', 'forecast', '下雨', '温度', '穿什么', or planning outdoor activities. Also use when the user asks 'should I bring an umbrella', 'what to wear', or any travel weather planning. This skill uses the free Open-Meteo API to provide 7-day weather forecasts with temperature, precipitation, wind, and UV index data, and generates a beautiful visual weather report.

install
source · Clone the upstream repo
git clone https://github.com/diegosouzapw/awesome-omni-skill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/diegosouzapw/awesome-omni-skill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/development/weather-forecaster" ~/.claude/skills/diegosouzapw-awesome-omni-skill-weather-forecaster && rm -rf "$T"
manifest: skills/development/weather-forecaster/SKILL.md
source content

Weather Forecaster Skill 🌤️

Overview

This skill provides 7-day weather forecasts for any location worldwide using free APIs (no API key required):

  • Open-Meteo Geocoding API — Convert location names to coordinates
  • Open-Meteo Forecast API — Get detailed 7-day weather forecasts

Workflow

Step 1: Identify the Location

Parse the user's request to extract the location name. Examples:

  • "北京未来一周天气" → location = "北京" (Beijing)
  • "What's the weather in Tokyo?" → location = "Tokyo"
  • "墨尔本下周会下雨吗" → location = "墨尔本" (Melbourne)

Step 2: Geocode the Location

Use the Open-Meteo Geocoding API to convert the location name to latitude/longitude:

https://geocoding-api.open-meteo.com/v1/search?name={location}&count=1&language=en

For Chinese location names, also try with

language=zh
:

https://geocoding-api.open-meteo.com/v1/search?name={location}&count=1&language=zh

Step 3: Fetch 7-Day Forecast

Use the Open-Meteo Forecast API:

https://api.open-meteo.com/v1/forecast?latitude={lat}&longitude={lon}&daily=weather_code,temperature_2m_max,temperature_2m_min,apparent_temperature_max,apparent_temperature_min,precipitation_sum,precipitation_probability_max,wind_speed_10m_max,wind_direction_10m_dominant,uv_index_max,sunrise,sunset&timezone=auto&forecast_days=7

Step 4: Run the Python Script

Execute the script at

scripts/weather_report.py
to fetch and format the data:

python3 scripts/weather_report.py "location_name"

The script will:

  1. Geocode the location
  2. Fetch 7-day forecast data
  3. Output a formatted JSON report

Step 5: Generate Visual Report

After getting the data, create a React (.jsx) artifact that displays a beautiful weather dashboard with:

  • Location name and coordinates
  • 7-day forecast cards showing:
    • Date and day of week
    • Weather icon/emoji based on weather code
    • High/Low temperatures
    • Precipitation probability and amount
    • Wind speed and direction
    • UV index
  • Color coding for temperature (blue=cold, green=comfortable, orange=warm, red=hot)
  • Precipitation warnings highlighted
  • A summary paragraph with clothing/umbrella recommendations

Weather Code Reference

CodeDescriptionEmoji
0Clear sky☀️
1Mainly clear🌤️
2Partly cloudy
3Overcast☁️
45, 48Fog🌫️
51, 53, 55Drizzle🌦️
61, 63, 65Rain🌧️
66, 67Freezing rain🌧️❄️
71, 73, 75Snowfall🌨️
77Snow grains🌨️
80, 81, 82Rain showers🌧️
85, 86Snow showers🌨️
95Thunderstorm⛈️
96, 99Thunderstorm with hail⛈️🧊

Response Style

  • Use Chinese if the user writes in Chinese, English if the user writes in English
  • Provide practical advice: 穿衣建议、是否带伞、出行建议
  • Highlight extreme weather warnings
  • Be friendly and conversational, like a TV weather presenter

Error Handling

  • If location not found: Ask user to provide a more specific location name or try English/Chinese alternative
  • If API fails: Inform user that the weather service is temporarily unavailable
  • If network is disabled: Let user know this skill requires network access to fetch weather data