Previsão do tempo - Py3K
Publicado por Fernando (última atualização em 13/12/2013)
[ Hits: 10.315 ]
Homepage: https://github.com/phoemur/
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.
#!/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()
ISOsync_pt-BR.py - Um Baixador Automático de ISOs de Sabayon, escrito em Python
Programa para derivação de funções matemáticas polinomiais
Script para Away com varias funções para xchat.
Passkeys: A Evolução da Autenticação Digital
Instalação de distro Linux em computadores, netbooks, etc, em rede com o Clonezilla
Título: Descobrindo o IP externo da VPN no Linux
Armazenando a senha de sua carteira Bitcoin de forma segura no Linux
Enviar mensagem ao usuário trabalhando com as opções do php.ini
Instalando Brave Browser no Linux Mint 22
vídeo pra quem quer saber como funciona Proteção de Memória:
Encontre seus arquivos facilmente com o Drill
Mouse Logitech MX Ergo Advanced Wireless Trackball no Linux
Compartilhamento de Rede com samba em modo Público/Anônimo de forma simples, rápido e fácil
Remoção de propaganda com o programa Comskip[AJUDA] (4)
Instalação do drive do adaptador wiffi (5)
Linux Lite Demorando Muito Para Ligar (1)