##############################################################################
# Parte do livro Introdução à Programação com Python
# Autor: Nilo Ney Coutinho Menezes
# Editora Novatec (c) 2010-2017
# Primeira edição - Novembro/2010 - ISBN 978-85-7522-250-8
# Primeira reimpressão - Outubro/2011
# Segunda reimpressão - Novembro/2012
# Terceira reimpressão - Agosto/2013
# Segunda edição - Junho/2014 - ISBN 978-85-7522-408-3
# Primeira reimpressão - Segunda edição - Maio/2015
# Segunda reimpressão - Segunda edição - Janeiro/2016
# Terceira reimpressão - Segunda edição - Junho/2016
# Quarta reimpressão - Segunda edição - Março/2017
# Terceira Edição - Janeiro/2019
#
# Site: http://python.nilo.pro.br/
#
# Arquivo: listagem\capitulo 11\11.22 - Funções de agregação com order by.py
##############################################################################
import sqlite3
print("Região Estados População Mínima Máxima Média Total (soma)")
print("====== ======= ========= ========== ========== ============")
with sqlite3.connect("brasil.db") as conexão:
for região in conexão.execute("""
select região, count(*), min(população),
max(população), avg(população), sum(população) as tpop
from estados
group by região
order by tpop desc"""):
print("{0:6} {1:7} {2:18,} {3:10,} {4:10,.0f} {5:13,}".format(*região))
print(
"\nBrasil: {0:6} {1:18,} {2:10,} {3:10,.0f} {4:13,}".format(
*conexão.execute("""
select count(*), min(população), max(população),
avg(população), sum(população) from estados""").fetchone()
)
)