Previsão do tempo - Py3K

Publicado por Fernando (última atualização em 13/12/2013)

[ Hits: 8.001 ]

Homepage: https://github.com/phoemur/

Download weather.py




Este pequeno script obtém dados em XML do CPTEC/INPE (Centro de Previsão de Tempo e Estudos Climáticos do Instituto Nacional de Pesquisas Espaciais)
para as cidades brasileiras e imprime o resultado no terminal.

Modo de uso:

$ ./weather.py "CIDADE[1]" "CIDADE[2]" ... "CIDADE[N]"

Não digite o nome do estado, apenas o nome da cidade.

  



Esconder código-fonte

#!/bin/env python3
# -*- coding: utf-8 -*-
#
# Copyright (c) 2013 - Fernando B. Giannasi
# This work is free. You can redistribute it and/or modify it under the
# terms of the Do What The Fuck You Want To Public License, Version 2,
# as published by Sam Hocevar.
#
# Este pequeno script obtem dados em XML do CPTEC/INPE (Centro de Previsão
# de Tempo e Estudos Climáticos do Instituto Nacional de Pesquisas Espaciais)
# para as cidades brasileiras e imprime o resultado no terminal.

import urllib.request
import xml.etree.ElementTree
import sys
import unicodedata
import datetime

TEMPO = {'ec':'Encoberto com Chuvas Isoladas',
         'ci':'Chuvas Isoladas',
         'c':'Chuva',
         'in':'Instável',
         'pp':'Possibilidade de Pancadas de Chuva',
         'cm':'Chuva pela Manhã',
         'cn':'Chuva à Noite',
         'pt':'Pancadas de Chuva à Tarde',
         'pm':'Pancadas de Chuva pela Manhã',
         'np':'Nublado e Pancadas de Chuva',
         'pc':'Pancadas de Chuva',
         'pn':'Parcialmente Nublado',
         'cv':'Chuvisco',
         'ch':'Chuvoso',
         't':'Tempestade',
         'ps':'Predomínio de Sol',
         'e':'Encoberto',
         'n':'Nublado',
         'cl':'Céu Claro',
         'nv':'Nevoeiro',
         'g':'Geada',
         'ne':'Neve',
         'nd':'Não Definido',
         'pnt':'Pancadas de Chuva à Noite',
         'psc':'Possibilidade de Chuva',
         'pcm':'Possibilidade de Chuva pela Manhã',
         'pct':'Possibilidade de Chuva à Tarde',
         'pcn':'Possibilidade de Chuva à Noite',
         'npt':'Nublado com Pancadas à Tarde',
         'npn':'Nublado com Pancadas à Noite',
         'ncn':'Nublado com Possibilidade de Chuva à Noite',
         'nct':'Nublado com Possibilidade de Chuva à Tarde',
         'ncm':'Nublado com Possibilidade de Chuva pela Manhã',
         'npm':'Nublado com Pancadas de Chuva pela Manhã',
         'npp':'Nublado com Possibilidade de Chuva',
         'vn':'Variação de Nebulosidade',
         'ct':'Chuva à Tarde',
         'ppn':'Possibilidade de Pancadas de Chuva à Noite',
         'ppt':'Possibilidade de Pancadas de Chuva à Tarde',
         'ppm':'Possibilidade de Pancadas de Chuva pela Manhã'}

def getxmlcodes(args):
    # Busca do código das cidades
    codigos = []
    for query in args:
        with urllib.request.urlopen('http://servicos.cptec.inpe.br/XML/listaCidades?city={0}'.format(query)) as url:
            content = url.read().decode('iso-8859-1')

        root = xml.etree.ElementTree.fromstring(content)
        codigos.extend([ elem.text for elem in root.findall('./cidade/id') ])

    if len(codigos) == 0:
        raise ValueError("A busca não retornou nenhuma cidade")

    return codigos

def main():
    if len(sys.argv) == 1 or sys.argv[1] in {'-h', '--help'}:
        print('Modo de uso: {0} "CIDADE[1]" "CIDADE[2]" ... "CIDADE[N]"\nO uso de aspas (") é obrigatório'\
               .format(sys.argv[0]))
        print('Exemplo: {0} "São Paulo"'.format(sys.argv[0]))
        print('Não digite o nome do estado')
        sys.exit(1)

    # Formatar entrada, remover acentos e substituir espaço por %20
    args = [ unicodedata.normalize('NFKD', elem).encode('ascii', 'ignore').decode('ascii').lower().replace(' ', '%20')
             for elem in sys.argv[1:] ]

    # Obter XML das cidades
    for codes in getxmlcodes(args):
        with urllib.request.urlopen('http://servicos.cptec.inpe.br/XML/cidade/{0}/previsao.xml'.format(codes)) as url:
            content = url.read().decode('iso-8859-1')

        # Filtrar os dados
        root = xml.etree.ElementTree.fromstring(content)
        dias = [ elem.text for elem in root.findall('previsao/dia') ]
        dias = [ datetime.datetime.strptime(elem, '%Y-%m-%d').strftime('%d/%m/%Y') for elem in dias ]
        clima = [elem.text for elem in root.findall('previsao/tempo') ]
        temperaturas = [ (ma, mi) for ma, mi in zip([elem.text for elem in root.findall('previsao/maxima') ],
                                                       [elem.text for elem in root.findall('previsao/minima') ]) ]

        iuv = [ elem.text for elem in root.findall('previsao/iuv') ]

        # Imprimir resultado
        print('\n\nPrevisão do tempo para {0} - {1}:'.format(root[0].text, root[1].text))
        print('(Atualizado em {0})\n'.format(datetime.datetime.strptime(root[2].text, '%Y-%m-%d').strftime('%d/%m/%Y')))

        for i in range(len(dias)):
            print('Dia {0}:'.format(dias[i]))
            print('Clima: {0}'.format(TEMPO[clima[i]]))
            print('Temperatura máxima: {0} °C'.format(temperaturas[i][0]))
            print('Temperatura mínima: {0} °C'.format(temperaturas[i][1]))
            print('Índice UV: {0}'.format(iuv[i]))
            print()



if __name__ == '__main__':
    main()

Scripts recomendados

Verificar se um número é primo

Amarok + XChat

Tabuadas

Teclado Virtual

Afinador de Violão/guitarra em python e gtk.


  

Comentários
[1] Comentário enviado por phoemur em 14/12/2013 - 13:18h

Se for usar cidades com espaço no nome é necessário usar aspas, por exemplo:
./weather.py "São Paulo"

Se o nome for simples não precisa. Exemplo:
./weather.py Guarulhos

Pode-se usar várias cidades ao mesmo tempo,exemplo:
./weather.py "São Paulo" Guarulhos Osasco


Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner
Linux banner
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts