Previsão do Tempo
Weather
Dados meteorológicos atualizados e precisos.
O HG Weather é uma API que fornece dados de previsão do tempo e condições climáticas atuais para uma cidade. É possível obter a cidade desejada de várias formas diferentes, como geolocalização, IP do usuário, busca por nome ou código.
Os dados meteorológicos são atualizados em intervalos de até 1 hora.
É possível indicar o idioma de retorno da API através do parâmetro
locale. Estão disponíveis: pt (português, por padrão) e en (inglês).Requisição
Todas as requisições tem como base o seguinte endpoint:
GEThttps://api.hgbrasil.com/weather?key=suachave
curl -X GET "https://api.hgbrasil.com/weather?key=suachave"
const url = new URL("/weather", "https://api.hgbrasil.com")
url.searchParams.set("key", "suachave")
const response = await fetch(url.href)
const data = await response.json()
$url = 'https://api.hgbrasil.com/weather';
$queryString = http_build_query([
'key' => 'suachave'
]);
$response = file_get_contents($url . '?' . $queryString);
$data = json_decode($response, true);
import requests
url = 'https://api.hgbrasil.com/weather'
params = {
'key': 'suachave'
}
response = requests.get(url, params=params)
data = response.json()
require 'net/http'
require 'uri'
require 'json'
uri = URI('https://api.hgbrasil.com/weather')
uri.query = URI.encode_www_form({
key: 'suachave'
})
response = Net::HTTP.get(uri)
data = JSON.parse(response, symbolize_names: true)
import java.net.URI;
import java.net.http.*;
var url = "https://api.hgbrasil.com/weather?key=suachave";
var client = HttpClient.newHttpClient();
var request = HttpRequest.newBuilder()
.uri(URI.create(url))
.GET()
.build();
var response = client.send(request, HttpResponse.BodyHandlers.ofString());
var data = response.body();
using System.Net.Http;
using System.Text.Json;
using System.Web;
var client = new HttpClient();
var baseUrl = "https://api.hgbrasil.com/weather";
var queryParams = HttpUtility.ParseQueryString(string.Empty);
queryParams["key"] = "suachave";
var url = $"{baseUrl}?{queryParams}";
var response = await client.GetStringAsync(url);
var data = JsonSerializer.Deserialize<dynamic>(response);
Veja como é fácil obter dados de previsão do tempo para uma cidade ou região específica. Você pode fazer isso de várias maneiras, como:
- Obter pelo nome da cidade;
- Obter pelo código WOEID da cidade;
- Obter por coordenadas de latitude e longitude;
- Obter por geolocalização IP.
Resposta
Exemplo de resposta no formato JSON.
{
"by": "default",
"valid_key": true,
"results": {
"temp": 18,
"date": "08/06/2026",
"time": "09:01",
"condition_code": "28",
"description": "Tempo nublado",
"currently": "dia",
"woeid": 455827,
"city": "São Paulo, SP",
"img_id": "28",
"humidity": 65,
"cloudiness": 63,
"rain": 0,
"wind_speedy": "0.89 km/h",
"wind_direction": 351,
"wind_cardinal": "N",
"sunrise": "06:44 am",
"sunset": "05:27 pm",
"moon_phase": "last_quarter",
"condition_slug": "cloud",
"city_name": "São Paulo",
"timezone": "-03:00",
"forecast": [
{
"date": "08/06",
"full_date": "08/06/2026",
"weekday": "Seg",
"max": 24,
"min": 10,
"humidity": 29,
"cloudiness": 0,
"rain": 0,
"rain_probability": 0,
"wind_speedy": "4.39 km/h",
"sunrise": "06:44 am",
"sunset": "05:27 pm",
"moon_phase": "last_quarter",
"description": "Tempo limpo",
"condition": "clear_day"
},
{
"date": "09/06",
"full_date": "09/06/2026",
"weekday": "Ter",
"max": 23,
"min": 13,
"humidity": 32,
"cloudiness": 100,
"rain": 0,
"rain_probability": 0,
"wind_speedy": "5.31 km/h",
"sunrise": "06:44 am",
"sunset": "05:27 pm",
"moon_phase": "last_quarter",
"description": "Tempo nublado",
"condition": "cloud"
},
{
"date": "10/06",
"full_date": "10/06/2026",
"weekday": "Qua",
"max": 20,
"min": 15,
"humidity": 42,
"cloudiness": 95,
"rain": 7.16,
"rain_probability": 100,
"wind_speedy": "2.62 km/h",
"sunrise": "06:44 am",
"sunset": "05:27 pm",
"moon_phase": "last_quarter",
"description": "Chuva",
"condition": "rain"
},
{
"date": "11/06",
"full_date": "11/06/2026",
"weekday": "Qui",
"max": 20,
"min": 14,
"humidity": 72,
"cloudiness": 94,
"rain": 4.65,
"rain_probability": 100,
"wind_speedy": "3.3 km/h",
"sunrise": "06:45 am",
"sunset": "05:27 pm",
"moon_phase": "waning_crescent",
"description": "Chuvas esparsas",
"condition": "rain"
},
{
"date": "12/06",
"full_date": "12/06/2026",
"weekday": "Sex",
"max": 20,
"min": 15,
"humidity": 66,
"cloudiness": 100,
"rain": 5.59,
"rain_probability": 100,
"wind_speedy": "7.16 km/h",
"sunrise": "06:45 am",
"sunset": "05:27 pm",
"moon_phase": "waning_crescent",
"description": "Chuva",
"condition": "rain"
},
{
"date": "13/06",
"full_date": "13/06/2026",
"weekday": "Sáb",
"max": 18,
"min": 14,
"humidity": 60,
"cloudiness": 49,
"rain": 10.74,
"rain_probability": 100,
"wind_speedy": "8.44 km/h",
"sunrise": "06:45 am",
"sunset": "05:27 pm",
"moon_phase": "waning_crescent",
"description": "Chuva",
"condition": "rain"
},
{
"date": "14/06",
"full_date": "14/06/2026",
"weekday": "Dom",
"max": 19,
"min": 11,
"humidity": 53,
"cloudiness": 0,
"rain": 0,
"rain_probability": 0,
"wind_speedy": "4.6 km/h",
"sunrise": "06:46 am",
"sunset": "05:27 pm",
"moon_phase": "waning_crescent",
"description": "Tempo limpo",
"condition": "clear_day"
},
{
"date": "15/06",
"full_date": "15/06/2026",
"weekday": "Seg",
"max": 20,
"min": 12,
"humidity": 51,
"cloudiness": 0,
"rain": 0,
"rain_probability": 0,
"wind_speedy": "1.65 km/h",
"sunrise": "06:46 am",
"sunset": "05:27 pm",
"moon_phase": "new",
"description": "Tempo limpo",
"condition": "clear_day"
},
{
"date": "16/06",
"full_date": "16/06/2026",
"weekday": "Ter",
"max": 19,
"min": 12,
"humidity": 53,
"cloudiness": 76,
"rain": 0,
"rain_probability": 0,
"wind_speedy": "4.34 km/h",
"sunrise": "06:46 am",
"sunset": "05:27 pm",
"moon_phase": "waxing_crescent",
"description": "Tempo nublado",
"condition": "cloud"
},
{
"date": "17/06",
"full_date": "17/06/2026",
"weekday": "Qua",
"max": 21,
"min": 14,
"humidity": 58,
"cloudiness": 8,
"rain": 0,
"rain_probability": 0,
"wind_speedy": "3.44 km/h",
"sunrise": "06:46 am",
"sunset": "05:28 pm",
"moon_phase": "waxing_crescent",
"description": "Tempo limpo",
"condition": "clear_day"
},
{
"date": "18/06",
"full_date": "18/06/2026",
"weekday": "Qui",
"max": 25,
"min": 15,
"humidity": 56,
"cloudiness": 56,
"rain": 1.77,
"rain_probability": 100,
"wind_speedy": "2.52 km/h",
"sunrise": "06:47 am",
"sunset": "05:28 pm",
"moon_phase": "waxing_crescent",
"description": "Chuvas esparsas",
"condition": "rain"
},
{
"date": "19/06",
"full_date": "19/06/2026",
"weekday": "Sex",
"max": 21,
"min": 15,
"humidity": 85,
"cloudiness": 90,
"rain": 2.43,
"rain_probability": 100,
"wind_speedy": "8.24 km/h",
"sunrise": "06:47 am",
"sunset": "05:28 pm",
"moon_phase": "waxing_crescent",
"description": "Chuvas esparsas",
"condition": "rain"
},
{
"date": "20/06",
"full_date": "20/06/2026",
"weekday": "Sáb",
"max": 15,
"min": 12,
"humidity": 42,
"cloudiness": 84,
"rain": 0.21,
"rain_probability": 31,
"wind_speedy": "7.63 km/h",
"sunrise": "06:47 am",
"sunset": "05:28 pm",
"moon_phase": "waxing_crescent",
"description": "Chuvas esparsas",
"condition": "rain"
},
{
"date": "21/06",
"full_date": "21/06/2026",
"weekday": "Dom",
"max": 21,
"min": 9,
"humidity": 31,
"cloudiness": 0,
"rain": 0,
"rain_probability": 0,
"wind_speedy": "2.46 km/h",
"sunrise": "06:47 am",
"sunset": "05:28 pm",
"moon_phase": "waxing_crescent",
"description": "Tempo limpo",
"condition": "clear_day"
},
{
"date": "22/06",
"full_date": "22/06/2026",
"weekday": "Seg",
"max": 18,
"min": 12,
"humidity": 67,
"cloudiness": 100,
"rain": 21.93,
"rain_probability": 100,
"wind_speedy": "5.42 km/h",
"sunrise": "06:48 am",
"sunset": "05:28 pm",
"moon_phase": "first_quarter",
"description": "Chuva",
"condition": "rain"
}
],
"cref": "e2867c",
"latitude": -23.5329,
"longitude": -46.6395
},
"execution_time": 0,
"from_cache": true
}
Campos
Os dados referentes à consulta chegam no parâmetro results, você também pode conferir a autenticação de sua chave no parâmetro de retorno valid_key.