Baixe o app para aproveitar ainda mais
Prévia do material em texto
Introdução Python é uma dessas raras linguagens em que se pode alegar ser ao mesmo tempo simples e poderosa. Você vai se surpreender ao descobrir o quanto é fácil se concentrar na solução para o problema em vez da sintaxe e estrutura da linguagem que você está programando. A introdução oficial para Python é: Python é uma poderosa linguagem de programação fácil de aprender. Possui eficientes estruturas de dados de alto-nível e uma simples e efetiva abordagem para programação orientada a objetos. A elegante sintaxe e a tipagem dinâmica de Python, aliada a sua natureza interpretada, faz dela uma linguagem ideal para criar scripts e desenvolver aplicações de modo ágil em diversas áreas e na maioria das plataformas. Vou detalhar a maioria dessas características na próxima seção. Nota Guido van Rossum, criador da linguagem Python, cujo nome foi baseado na série "Monty Python's Flying Circus" da BBC. Ele, particularmente, não gosta de cobras que para se alimentar, esmagam outros animais usando seu extenso corpo. Características de Python Simples Python é uma linguagem simples e minimalista. Ler um bom programa em Python é quase como ler em inglês, ainda que seja um inglês bem restrito. Este caráter de pseudo-código do Python é um de seus maiores pontos fortes. Ele permite que você se concentre na solução do problema e não na linguagem em si. Fácil de Aprender Como você verá, é extremamente fácil iniciar-se em Python. A linguagem possui uma sintaxe extraordinariamente simples, como já mencionado. Livre e de Código Aberto Python é um exemplo de FLOSS (Free/Libre and Open Source Software. Traduzindo, você pode distribuir livremente cópias deste software, ler seu código-fonte, modificá-lo, usar trechos em novos programas livres e tudo o que você quiser fazer. FLOSS é baseado no conceito de uma comunidade que compartilha conhecimento. Este é um dos motivos pelos quais Python é tão bom - ele vem sendo criado e constantemente melhorado por uma comunidade que simplesmente quer ver a Python cada vez melhor. Linguagem de Alto Nível Quando você escreve programas em Python, não há necessidade de se preocupar com detalhes de baixo nível tais como manipular a memória utilizada pelo programa, etc. Portável Por ser uma linguagem de código aberto, Python foi portada (ou seja, modificada para funcionar) em muitas plataformas. Todos os seus programas em Python podem rodar em qualquer uma destas plataformas sem precisar de mudanças, desde que você seja cuidadoso o suficiente para evitar usar características que dependam do sistema. Você pode usar Python em Linux, Windows, FreeBSD, Macintosh, Solaris, OS/2, Amiga, AROS, AS/$)), BeOS, OS/390, z/OS, Palm OS, QNX, VMS, Psion, Acorn RISC OS, VxWorks, PlayStation, Sharp Zaurus, Windows CE e até mesmo no PocketPC! Interpretada Isto requer uma pequena explicação Um programa escrito em uma linguagem compilada como C ou C++ é convertido da linguagem de origem (C ou C++) para a linguagem que é falada por seu computador (código binário, ou seja, 0s e 1s) usando um compilador com vários flags e opções. Quando você roda o programa, o software linkeditor/carregador copia o programa do disco rígido para a memória e começa a executá-lo. Python, por sua vez, não necessita de compilação para código binário. Você simplemente executa o programa diretamente do código-fonte. Internamente, Python converte o código- fonte em um formato intermediário chamado bytecode, o traduz para a linguagem nativa do seu computador e então o executa. Tudo isso, na verdade, torna Python muito mais fácil, uma vez que você não precisa se preocupar com a compilação do programa, certificar-se que as bibliotecas necessárias estão todas linkeditadas e carregadas etc, etc. Isto também torna seus programas em Python muito mais portáveis, já que você pode simplesmente copiar seu programa em Python em outro computador e executá-lo! Orientada a Objetos Python suporta tanto programação procedural (estruturada) quanto orientada a objetos. Em linguagens procedurais, o programa é construído com base em procedimentos e funções, que nada mais são que trechos reutilizáveis de programas. Em linguagens orientadas a objeto, com base em objetos que combinam dados e funcionalidade. Python tem uma maneira simples mas poderosa de implementar programação orientada a objetos, especialmente quando comparada a linguagens como C++ ou Java. Extensível Se você precisa que um trecho crítico de código seja executado com muita rapidez ou quer que parte de algum algoritmo não seja aberta, você pode codificá-los em C ou C++ e então usá-los a partir de seu programa Python. Embarcável Você pode embarcar Pyhton em seus programas C/C++ para fornecer funcionalidades de scripting aos usuários dos programas. Bibliotecas Extensivas A Biblioteca Padrão do Python (Python Standard Library) é de fato enorme. Ela pode ajudá-lo a fazer várias coisas envolvendo expressões regulares, geração de documentação, testes unitários, threading, acesso a bancos de dados, browsers web, CGi, FTP, e-mail, XML, XML-RPC, HTML, arquivos WAV, criptografia, GUI (Interfaces Gráficas com o Usuário), Tk e outras coisas dependentes do sistema. Lembre-se de que tudo isto está disponível onde quer que Python esteja instalado. Esta é a chamada filosofia das "Pilhas Incluídas" do Python. Além da biblioteca padrão, existem várias outras bibliotecas de alta qualidade, tais comos wxPython , Twisted, Python Imaging Library e muitas outras. Python é, de fato, uma linguagem poderosa e empolgante. Ela possui a combinação exata de desempenho e características que fazem escrever programas em Python uma tarefa fácil e divertida. Por que não Perl? Se você ainda não conhece, Perl é outra linguagem de programação interpretada e de código aberto extremamente popular. Se você alguma vez tentou escrever um programa grande em Perl, você poderia ter respondido essa pergunta sozinho! Em outras palavras, programas em Perl são fáceis quando eles são pequenos e são excelentes para pequenos "hacks" e scripts "pra fazer o serviço". No entanto, eles se tornam rapidamente difíceis de manter à medida em que se tornam maiores. E estou falando isso com base na minha experiência no Yahoo! escrevendo programas grandes em Perl. Quando comparados a Perl, os programas em Python são definitivamente mais simples, claros, fáceis de escrever e, consequentemente, mais legíveis e fáceis de manter. Eu admiro Perl e uso diariamente para várias tarefas, mas toda vez que escrevo um programa, começo a pensar em termos de Python, porque se tornou natural para mim. Perl passou por tantos hacks e mudanças que parece que a linguagem toda é um grande (mas ótimo) hack. Infelizmente, o futuro Perl 6 não parece trazer nenhuma melhoria quanto a isso. A única e bastante significativa vantagem do Perl, na minha opinião, é sua enorme biblioteca CPAN (Comprehensive Perl Archive Network). Como o nome sugere, é uma imensa coleção de módulos Perl e é simplesmente inacreditável, por causa de seu tamanho e profundidade - você pode fazer praticamente qualquer coisa que seja possível de se fazer com um computador usando estes módulos. Uma das razões pelas quais Perl tem mais bibliotecas que Python é o fato de existir há muito mais tempo. No entanto, isto parece estar mudando com o crescimento do Python Package Index. Por que não Ruby? Se você ainda não sabia, Ruby é uma outra popular linguagem de programação de código aberto. Se você já gosta e usa Ruby, então eu definitivamente recomendo que continue a usá-la. Para as outras pessoas que ainda não a usaram e estão tentando escolher entre aprender Python ou aprender Ruby, então eu recomendaria Python, unicamente pela perspectiva de facilidade de aprendizado. Pessoalmente, achei difícil compreender a linguagem Ruby, mas todas as pessoas que conseguemaprovam a beleza da linguagem. Infelizmente não tive tanta sorte. O Que Os Programadores Dizem É interessante ler o que grandes hackers como ESR têm a dizer sobre Python: •Eric S. Raymond é o autor de 'A Catedral e o Bazar' e também é o indivíduo que cunhou o termo 'Open Source'. Ele diz que Python se tornou sua linguagem de programação favorita. Este artigo foi a real inspiração para meu primeiro contato com Python. •Bruce Eckel é o autor dos famosos livros 'Thinking in Java' e 'Thinking in C++'. Ele diz que nenhuma outra linguagem o deixou tão produtivo quanto Python. Diz ainda que Python é talvez a única linguagem que se concentra em tornar as coisas mais fáceis para o programador. Leia a entrevista completa para mais detalhes. •Peter Norvig é o conhecido autor do Lisp e Diretor de Qualidade de Busca no google (obrigado a Guido van Rossum por avisar). Ele diz que Python sempre foi parte integrante do Google. Esta afirmação pode ser comprovada verificando a página do Google Jobs que lista conhecimento em Python como requisito para os engenheiros de software. Sobre Python 3.0 Python 3.0 é a nova versão da linguagem que será lançada em breve. Também é conhecida como Python 3000 ou Py3k. A motivação principal para uma nova versão de Python é remover todos os pequenos problemas e detalhes que foram se acumulando no decorrer dos anos e tornar a linguagem ainda mais limpa. Se você já tem muito código Python 2.x, então existe um utilitário para ajudar na conversão de código 2.x para 3.x. Mais detalhes em: •Introdução por Guido van Rossum •O que há de novo no Python 2.6 (recursos significativamente diferentes das versões anteriores de Python 2.x e que provavelmente serão incluídos no Python 3.0) •O que há de novo no Python 3.0 •Cronograma de lançamento do Python 2.6 e 3.0 •Python 3000 (a lista oficial de mudanças propostas) •Planos diversos para Python 3.0 •Novidades do Python (lista detalhada das mudanças) Python pt-br:Instalacao Se você já tem o Python 2.x instalado, não é preciso removê-lo para instalar o Python 3.0. Você pode manter ambos instalados ao mesmo tempo. Para usuários Linux e BSD Se você está usando uma distribuição Linux como Ubuntu, Fedora, OpenSUSE ou {coloque sua escolha aquí}, ou um sistema BSD tal como FreeBSD, então é provável que você já tenha o Python instalado em seu sistema. Para testar se o Python já está instalado em seu Linux, abra um shell (comokonsole ou gnome-terminal) e então entre com o comando python -V como mostrado abaixo: $ python -V Python 3.0b1 Nota $ é o prompt do shell. Ele será diferente para você dependendo das configurações do seu sistema operacional, portanto eu indicarei o prompt apenas pelo símbolo $. Se você vê alguma informação sobre a versão, como mostrado acima, então o Python já está instalado. Contudo, se você obter uma mensagem como esta: $ python -V bash: Python: command not found Então o Python não está instalado. Isto é altamente improvável, mas é possível. Neste caso, você tem dois meios para instalar o Python em seu sistema: • Você pode compilar o código fonte do Python e então instalá-lo. As instruções para a compilação são informadas no website do Python. • Instalar os pacotes binários usando um gerenciador de pacotes que vem com o seu sistema operacional, tal como apt-get no Ubuntu/Debian e outros Linux baseados em Debian, yum no Fedora, pkg_add no FreeBSD, etc. Você precisará de uma conexão com a internet para usar este método. Uma alternativa é baixar os binários de algum outro lugar e então copiá-los e instalá-los em seu PC. [Esta opção estará disponível após o lançamento final do Python 3.0] Para usuários Windows Visite o site http://www.python.org/download/releases/3.0/ e baixe a última versão, que era a versão 3.0 beta 1, quando este livro foi escrito. Ele tem apenas 12.8 MB, o que é bem compacto quando comparado com a maioria das outras linguagens ou programas. Cuidado Quando for dada a opção para você desmarcar componentes opcionais, não desmaque nenhum! Alguns destes componentes podem ser úteis para você, especialmente IDLE. Um fato interessante é que usuários Windows são os que mais baixam os arquivos do Python. É claro que isso não fornece uma visão geral, uma vez que quase todos os usuários Linux já têm o Python instalado por padrão em seus sistema. Prompt do DOS Se você quer ser capaz de usar o Python da linha de comando do Windows, i.e. o prompt do DOS, então você precisa configurar a variável PATH corretamente. Pra usuários Windows 2000, XP ou 2003, clique em Painel de Controle ->Sistema -> Avançado - > Variáveis de ambiente. Clique na variável chamadaPATH na seção 'Variáveis de Sistema', então selecione Editar e adicione ;C:\Python30 no fim do que já estiver lá. É claro que você deve usar o diretório correto onde você instalou o Python. Para versões antigas do Windows, adicione as seguintes linhas no arquivoC:\AUTOEXEC.BAT : 'PATH= %PATH%;C:\Python30' (sem as aspas) e reinicie o sistema. Em Windows NT use o arquivo AUTOEXEC.NT. Para usuários MAC OS X Usuários Mac OS X já encontrarão o Python instalado em seu sistema. Abra oTerminal.app e rode python - V, e siga os conselhos da seção para usuários Linux. Sumário Em um sistema Linux, é provável que você já tenha o Python instalado. Caso contrário, você pode instalá- lo usando o gerenciador de pacotes que vem com sua distribuição. Em um sistema Windows, instalar o Python é tão fácil como baixar o instalador e clicar duas vezes sobre ele. Daqui para frente nós assumiremos que você já está com o Python instalado em seu sistema. A seguir nós escreveremos nosso primeiro programa em Python. Python pt-br:Primeiros Passos Introdução Nós veremos agora como rodar o tradicional programa 'Olá Mundo' em Python. Isto ensinará a você como escrever, salvar e rodar programas no Python. Há duas formas de usar o Python para rodar um programa - usando o prompt do interpretador interativo ou usando um arquivo fonte. Nós veremos como usar os dois métodos. Usando o Prompt do Interpretador Inicie o interpretador na linha de comando digitando python prompt do shell. Em sistemas Windows, você pode rodar o interpretador na linha de comando se a variável PATH estiver corretamente configurada. Se você está usando o IDLE, clique em Iniciar → Programas → Python 3.0 →IDLE (Python GUI). Agora digite print('Olá Mundo') e em seguida pressione a tecla Enter. Você verá as palavras Olá Mundo como saída. $ python Python 3.0b2 (r30b2:65106, Jul 18 2008, 18:44:17) [MSC v.1500 32 bit (Intel)] on win32 Type "help", "copyright", "credits" or "license" for more information. >>> print('Olá Mundo') Olá Mundo >>> Perceba que o Python mostra a saída da linha imediatamente! O que você acabou de digitar é uma simples instrução. Nós usamos print para imprimir qualquer valor que você forneça. Aqui, nós estamos fornecendo o texto Olá Mundo e este é imediatamente impresso na tela. Como Sair do Interpretador Para sair do prompt, pressione ctrl-d se você está usando o IDLE ou o shell do Linux/BSD. No caso do prompt de comando do Windows, pressione ctrl-zseguido da tecla enter. Escolhendo um Editor Antes de começarmos a escrever programas em arquivos fonte, nós precisamos de um editor para escrever estes arquivos. A escolha de um editor é crucial. Você deve escolher o editor como se você fosse escolher um carro novo. Um bom editor o ajudará a escrever programas para Python facilmente, fazendo sua jornada mais confortável e te ajudando a chegar em seu destino (atingindo seu objetivo) de uma forma fácil e segura. Uma das necessidades mais básicas é o destaque de sintaxe que torna colorida todas as diferentes partes de seu programa, de forma que você possa ver seu programa e visualizar seu funcionamento. Se você está usandoo Windows, eu sugiro que você use o IDLE. O IDLE destaca a sintaxe e permite que você rode seus programas dentro dele mesmo, além de fazer outras coisas. Uma observação especial: Não use o Notepad - é uma má escolha pois ele não destaca a sintaxe e também não tem suporte a indentação do texto, que é muito importante no nosso caso, como veremos adiante. Bons editores tais como o IDLE (e também o VIM) automaticamente o ajudarão a fazer isso. Se você está usando Linux/FreeBSD, então você tem diversas escolhas para um editor. Se você é um programador experiente, então você já deve estar usandoVim ou Emacs. É desnecessário dizer que estes são dois dos mais poderosos editores e que você será beneficiado por usá-los para escrever seus programas em Python. Eu pessoalmente uso Vim para a maioria de meus programas. Se você é um programador iniciante, você pode usar o Kate, que é um dos meus favoritos. No caso de você ter tempo para aprender Vim ou Emacs, então eu realmente recomendo que você aprenda a usar um deles, pois será de grande utilidade para você em sua longa jornada. Neste livro, nós usaremos o IDLE, nosso IDE (Integrated Development Environment - Ambiente Integrado de Desenvolvimento) como editor. O IDLE é instalado por padrão com os instaladores Python para Windows e Mac OS X. Ele também está disponível para instalação em Linux e BSDs nos seus respectivos repositórios. Nós exploraremos como usar o IDLE na próxima seção. Para mais detalhes, por favor veja a documentação do IDLE. Se você ainda deseja explorar outras escolhas para um editor, veja a ampla lista de editores para Python e faça sua escolha. Você também pode escolher um IDE para Python. Veja a ampla lista de IDEs que suportam Python para mais detalhes. Uma vez que você passe a escrever grandes programas em Python, IDEs podem ser muito úteis. Eu repito novamente, por favor escolha um editor apropriado - ele pode fazer a elaboração de programas em Python mais fácil e divertida. Para usuários do Vim Há uma boa introdução sobre como tornar o Vim um poderoso IDE para Python por John M Anderson. Para usuários do Emacs Há uma boa introdução sobre como tornar o Emacs um poderoso IDE para Python por Ryan McGuire. Usando um Arquivo Fonte Agora vamos voltar a programação. Há uma tradição de que quando você aprende uma nova linguagem de programação, o primeiro programa que você escreve e roda é o 'Olá Mundo' - tudo que ele faz é apenas dizer 'Olá Mundo' quando você o roda. Como Simon Cozens [1] diz, ele é uma 'tradicional invocação para os deuses da programação ajudarem você a aprender melhor a linguagem' :) . Inicie o editor escolhido, digite o seguinte programa e salve-o como olamundo.py Se você está usando o IDLE, clique sobre File → New Window e então entre com o seguinte programa. Então clique sobre File → Save. #!/usr/bin/python #Filename: olamundo.py print('Olá Mundo') Rode este programa abrindo o shell (terminal Linux ou prompt do DOS) e entre com o comando python olamundo.py. Se você está usando o IDLE, use o menu Run → Run Module ou o atalho F5. A saída é semelhante a seguinte: $ python olamundo.py Olá Mundo Se você obter uma saída como acima, parabéns! - você rodou com sucesso seu primeiro programa para Python. No caso de um erro, pro favor digite o programa acima exatamente como mostrado e rode o programa novamente. Note que Python é case-sensitive i.e.print não é o mesmo que Print - note o p minúsculo na primeira instrução e o Pmaiúsculo na segunda. Além disso, assegure-se que não haja espaços ou tabulações antes do primeiro carácter de cada linha - nós veremos por que isso é importante mais tarde. Como ele Funciona Vamos considerar as duas primeiras linhas do programa. Elas são chamadas decomentários - qualquer coisa a direita do símbolo # é um comentário e é usado principalmente como notas para o leitor do programa. Python não usa os comentário, exceto para o caso especial da primeira linha. Ela é chamada de linha de organização - sempre que os dois primeiros caracteres do arquivo fonte são #! seguidos pela localização de um programa, isto diz para seu sistema Linux/Unix que este programa deve ser rodado com este interpretador quando você executar o programa. Isto é explicado em detalhes na próxima seção. Note que você sempre pode rodar o programa em qualquer plataforma especificando o interpretador diretamente na linha de comando, como o comandopython olamundo.py . Importante Use comentário em seu programa de forma sensata, para explicar algum detalhe importante de seu programa - isto é útil para que os leitores de seu programa possam entender facilmente o que ele está fazendo. Lembre-se, está pessoa pode ser você mesmo depois de seis meses! Os comentário são seguidos por uma instrução de Python. Aqui nós chamamos afunção print que apenas imprime o texto 'Olá Mundo'. Nós aprenderemos sobre funções em um capítulo posterior, o que você deve entender agora é que o que você colocar nos parênteses será impresso na tela. Neste caso, nós fornecemos'Olá Mundo' que se refere a uma string - não se preocupe, nós vamos explorar essas terminologias em detalhes mais tarde. Programas Executáveis em Python Isto funciona apenas para usuários Linux/Unix, mas usuários do Windows podem estar curiosos sobre a primeira linha do programa. Inicialmente, devemos dar ao programa a permissão para executar usando o comando chmod e então rodar o programa fonte. $ chmod a+x olamundo.py $ ./olamundo.py Olá Mundo O comando chmod é usado aqui para mudar ('ch'ange) o modo ('mod'e) do arquivo dando permissão para todos ('a'll) os usuário do sistema o executar (e'x'ecute). Então, nós executamos o programa diretamente especificando a localização do arquivo fonte. Nós usamos o ./ para indicar que o programa está no diretório atual. Para tornar as coisas mais divertidas, você pode renomear o arquivo paraolamundo e rodá-lo com ./olamundo e ele ainda funcionará, uma vez que o sistema sabe que ele tem de rodar o programa usando o interpretador cuja localização é especificada na primeira linha do arquivo fonte. Agora você é capaz de rodar o programa desde que você conheça o caminho exato para o arquivo fonte - mas e se você desejar rodar o arquivo de qualquer lugar? Você pode fazer isso armazenando o programa em um dos diretórios listados na variável de ambiente PATH. Sempre que você roda qualquer programa, o sistema procura por aquele programa em cada diretório listado na variável de ambiente PATHe então roda aquele programa. Nós podemos tornar este programa disponível em qualquer lugar simplesmente copiando este arquivo fonte para um dos diretórios listados no PATH. $ echo $PATH /usr/local/bin:/usr/bin:/bin:/usr/X11R6/bin:/home/swaroop/bin $ cp olamundo.py /home/swaroop/bin/olamundo $ olamundo Olá Mundo Nós podemos mostrar a variável PATH usando o comando echo e incluindo o prefixo $ para indicar para o shell que nós precisamos do valor desta variável. Nós vemos que /home/swaroop/bin é um dos diretórios na variável PATH ondeswaroop é o nome de usuário que eu estou usando em meu sistema. Provavelmente existe um diretório similar para seu nome de usuário para seu sistema. Alternativamente, você pode adicionar um diretório de sua escolha para a variável PATH - isto pode ser feito rodando PATH=$PATH:/home/swaroop/mydironde '/home/swaroop/mydir' é o diretório que eu desejo adicionar na variávelPATH. Este método é muito útil se você deseja escrever scripts úteis que você queira rodar de qualquer lugar, a qualquer hora. É como criar seu próprio comando, semelhante ao cd ou qualquer outro comando que você use no terminal linux ou no prompt do DOS. Cuidado Em Python, um programa ou um script significam a mesma coisa. Obtendo Ajuda Se você precisar de informação sobre alguma função ou instrução em Python, entãovocê pode usar a função embutida help. Isto é muito útil especialmente quando estiver usando o prompt do interpretador. Por exemplo, rodehelp(print) - isto mostra a ajuda para a função print que é usada para imprimir coisas na tela. Nota Pressione q para sair da ajuda. De forma similar, você pode obter informação sobre quase qualquer coisa em Python. Use help() para aprender mais usando o próprio help! No caso de você precisar de ajuda para operadores como return, então você deve colocá-los dentro de aspas como em help('return') dessa forma Python não se confunde com o que nós queremos fazer. Sumário Agora você é capaz ou de escrever,salvar e rodar programas em Python facilmente. Agora que você é um usuário Python, vamos aprender alguns conceitos de Python. Python pt-br:Fundamentos Imprimir 'Olá mundo' não é suficiente, ou é? Você quer fazer mais que isso - você quer inserir dados, manipulá-los e obter alguma resposta a partir deles. Nós podemos conseguir isso em Python usando constantes e variáveis. Constantes Literais Um exemplo de uma constante literal é um número como 5, 1.23, 9.25e-3 ou uma string (sequência de caracteres) como 'Esta é uma string' ou "É uma string!". Ela é denominada literal porque é literal - você usa seu valor literalmente. O número 2 sempre representa a si mesmo e nada além disso - ele é umaconstante pois seu valor não pode ser mudado. Logo, todos esses valores referem-se a constantes literais. Números Os números em Python são são de três tipos - inteiros, ponto flutuante e complexos. • 2 é um exemplo de inteiro, os inteiros são os números redondos. • 3.23 e 52.3E-4 são exemplos de números de ponto flutuante (ou floats, para abreviar). A notação E indica as potências de 10. Neste caso, 52.3E-4 significa52.3 * 10-4. • (-5+4j) e (2.3 - 4.6j) são exemplos de números complexos. Nota para programadores experientes Não há o tipo 'long int' (inteiro longo) em separado. O tipo inteiro padrão pode assumir qualquer valor grande. Strings Uma string é uma sequência de caracteres. As strings são basicamente um amontoado de palavras. As palavras podem estar em inglês ou em qualquer língua que seja suportada pelo padrão Unicode, que atende a quase todas as línguas do mundo. Nota para programadores experientes Não há strings "somente em ASCII" porque o padrão Unicode engloba o ASCII. Por convenção, todas as stringas estão em UTF-8. Eu posso garantir que você usará strings em quase todos os programas que escrever em Python, portanto preste atenção à próxima parte sobre como usar strings em Python. Aspas Unitárias Você pode especificar as strings usando aspas unitárias (ou apóstrofes) tais como 'Use aspas unitárias em mim'. Todos os espaços em branco, isto é, espaços e tabulações são preservados no estado em que se encontram. Aspas Duplas As strings em aspas duplas trabalham exatamente da mesma maneira que as strings em aspas unitárias. Eis um exemplo: "Qual é o seu nome?" Aspas Triplas Você pode especificar strings que ocupam várias linhas usando aspas triplas - (""" ou '''). Você pode usar aspas unitárias e aspas duplas livremente para formar as aspas triplas. Eis um exemplo: '''Esta é uma string multi-linha. Esta é a primeira linha. Esta é a segunda linha. "Qual é o seu nome?", eu perguntei. Ele disse "Bond, James Bond." ''' Seqüências de Escape Suponha que você queira obter uma string que contenha um apóstrofe ('), como você escreverá essa string? Por exemplo, a string é What's your name?. Você não pode escrever 'What's your name?' porque o Python ficará confuso sobre onde a string começa e onde termina. Logo, você terá que especificar que este apóstrofe não indica o fim da string. Isso pode ser feito com a ajuda do que é denominada uma sequência de escape. Você especifica o apóstrofe como \' - note a barra invertida. Agora, você pode escrever a string como 'What\'s your name?'. Uma outra maneira de escrever essa string específica seria "What's your name?", isto é, usando aspas duplas. Da mesma maneira, você pode usar uma sequência de escape para inserir aspas duplas em uma string limitada por aspas duplas. Você também pode inserir a própria barra invertida usando a seqüência de escape \\. O que fazer se você quer escrever uma string de duas linhas? Uma solução é usar uma string limitada por aspas triplas conforme foi ensinado previamente ou você pode utilizar uma seqüência de escape para o caracter de nova linha - \npara indicar o início da nova linha. Eis um exemplo, Essa é a primeira linha\nEssa é a segunda linha. Uma outra seqüência de escape útil a ser conhecida é a tabulação - \t. Há muitas outras seqüências de escape, mas eu mencionei aqui somente as mais úteis. É importante observar que numa string, uma única barra invertida no fim da linha indica que a string continua na próxima linha, mas nenhuma linha nova é adicionada. Por exemplo: "Essa é a primeira frase.\ Essa é a segunda frase." equivale a "Essa é a primeira frase. Essa é a segunda frase.". Strings Brutas Se você precisa escrever algumas strings onde nenhum processamento especial tais como as seqüências de escape são manipuladas, então o que você precisa é escrever uma string bruta prefixando um r ou um R à string . Eis um exemplo,r"Novas linhas são indicadas por \n". Strings São Imutáveis Isso significa que uma vez que você tenha criado uma string, você não pode mudá-la. Embora isso pareça como algo ruim, não é realmente. Nós veremos porque isso não é uma limitação nos diversos programas que nós analisaremos mais adiante. Concatenação de Literais do Tipo String Se você colocar duas strings literais lado a lado, elas são automaticamente concatenadas pelo Python. Por exemplo, 'Qual é ' 'o seu nome?' é automaticamente convertido em "Qual é o seu nome?". Nota para programadores C/C++ Não há tipo de dado char (caracter) separado em Python. Não existe nenhum motivo real para isto e eu tenho certeza que você não esquecerá isto. Nota para programadores Perl/PHP Lembre-se que strings com aspas simples e duplas são a mesma coisa - elas não diferem entre si Nota para Usuários de Expressão Regular Sempre use strings brutas quando estiver manipulando expressões regulares. Do contrário, será necessário muito uso de caracteres de escape. Por exemplo, referências a barras invertidas podem ser feitas como '\\1' our'\1'. O método 'format' As vezes nós iremos querer construir strings de uma outra informação. Isto é onde o método format() é útil #!/usr/bin/python # Filename: str_format.py age = 25 name = 'Swaroop' print('{0} is {1} years old'.format(name, age)) print('Why is {0} playing with that python?'.format(name)) Saída: $ python str_format.py Swaroop is 25 years old Why is Swaroop playing with that python? Como isto funciona: Uma string pode utilizar certas especificações e sub consequentemente, o método format pode ser chamado de um substituto para estas especificações correspondendo os argumentos ao método format. Observe que está é a primeira vez que usamos {0} e isto corresponde á váriavelname que é o primeiro argumento ao método 'format'. Similarmente, a segunda especificação é {1} que corresponde á age que é o segundo argumento ao método 'format'. O que o Python faz aqui é substituir cada valor do argumento no lugar da especificação. Que pode ter especificações mais detalhadas como: >>> '{0:.3}'.format(1/3) # decimal (.) precision of 3 for float '0.333' >>> '{0:_^11}'.format('hello') # fill with underscores (_) with the text centered (^) to 11 width '___hello___' >>> '{name} wrote {book}'.format(name='Swaroop', book='A Byte of Python') # keyword-based 'Swaroop wrote A Byte of Python' Detalhes desta especificação de formatação são explicados na Python Enhancement Proposal No. 3101. File:Example.jpg Variáveis Usar apenas constantes literaispode se tornar algo chato - nós precisamos de alguma maneira de armazenar qualquer informação, bem como manipulá-la. É aí onde as variáveis entram na jogada. Variáveis são exatamento o que seu nome significa - seu valor pode variar, isto é, vôce pode armazenar qualquer coisa usando uma variável. Variáveis são apenas partes da memória do seu computador nas quais você armazena alguma informação. Diferentemente das constantes literais, você precisa de alguma maneira de acessar estas variáveis e, portanto, você dá nomes a elas. Nomenclatura de Identificadores Variáveis são exemplos de identificadores. Identificadores são nomes dados de maneira a identificar algo. Existem algumas regras que você terá que seguir para dar nome aos identificadores: • O primeiro caracter do identificador precisa ser uma letra do alfabeto (maiúsculo ASCII ou minúsculo ASCII ou caracter Unicode) ou um underscore('_'). • O restante do nome do identificador pode consistir de letras (maiúsculo ASCII ou minúsculo ASCII ou caracter Unicode), underscores ('_') ou dígitos (0-9). • Nomes de idenficadores são case-sensitive. Por exemplo, myname e myName nãosão o mesmo. Note o minúsculo n no primeiro e o maiúsculo N no segundo. • Exemplos de nomes de identificadores válidos são i, __my_name, name_23,a1b2_c3 and resumÃÆà ¢â‚¬â„¢ÃƒÆ’‚©_count. • Exemplos de nomes de idenficadores inválidos são 2things, este contém espaços e my-name. Tipos de Dados Variáveis podem manter valores de diferentes tipos, chamados de tipos de dados. Os tipos básicos são números e strings, que nós já discutimos. Nos próximos capítulos, veremos como criar seus próprios tipos usando classes. Objetos Lembre-se de que Python se refere a qualquer coisa usada em um programa como um objeto, em sentido geral. Ao invés de dizer 'o alguma coisa', nós de dizemos 'o objeto'. Nota para os usuários de Programação Orientada a Objetos Python é fortemente orientada a objetos, no sentido que tudo é um objeto, incluindo números, strings e funções. Agora veremos como usar variáveis juntamento com constantes literais. Salve o exemplo a seguir e execute o programa. Como escrever programas em Python Daqui em diante, o procedimento padrão para salvar e executar um programa Python é a seguinte: 1. Abra o seu editor favorito. 2. Digite o código do programa dado no exemplo. 3. Salve-o como um arquivo com o nome mencionado no comentário. Eu sigo a convenção de ter todos os programas em Python salvos com a extensão .py. 4. Execute o interpretador com o comando python program.py ou use o IDLE para executar os programas. Você também pode usar o método executável como explicado anteriormente. Exemplo: Utilizando variáveis e constantes literais # Filename : var.py i = 5 print(i) i = i + 1 print(i) s = '''Esta é uma string de múltiplas linhas. Esta é a segunda linha.''' print(s) Output: $ python var.py 5 6 Esta é uma string de múltiplas linhas. Esta é a segunda linha. Como funciona: Como funciona: Veja como este programa funciona. Primeiro, vamos atribuir o valor constante literal 5 à variável i com o operador de atribuição (=). Esta linha é chamada de instrução, pois indica que algo deve ser feito e neste caso, nós estamos conectando o nome da variável i ao valor 5. Em seguida, imprimimos o valor de icom o comando print, que, obviamente, apenas imprime o valor da variável na tela. Então somamos 1 ao valor armazenado em i e armazenmos de volta. Em seguida, imprimimos e, como esperado, obtemos o valor tt>6</tt>. Da mesma forma, atribuímos a string literal para a variável s e depois a imprimimos. Nota para programadores de linguagens estáticas As variáveis são usadas simplesmente atribuindo-lhes um valor. Nenhuma declaração ou definição de tipo de dados é necessária ou utilizada. Linhas Lógicas e Físicas Uma linha física aquela que você vê quando escreve o programa. Uma linha lógica é que o Python vê como uma única instrução. Python implicitamente assume que cada linha física corresponde a uma linha lógica. Um exemplo de uma linha lógica é uma instrução como print('Hello World') - se este estava em uma linha por si só (como você vê no editor), então isso também corresponde a uma linha física. Implicitamente, Python incentiva o uso de uma única instrução por linha, o que torna o código mais legível. Se você quiser especificar mais de uma linha lógica em uma única linha física, então você tem que especificar explicitamente usando um ponto-e-vírgula (;) que indica o fim de uma linha lógica ou instrução. Por exemplo, i = 5 print(i) é o mesmo que i = 5; print(i); e o mesmo pode ser escrito como i = 5; print(i); ou ainda i = 5; print(i) No entanto, eu recomendo fortemente que você se atenha a escrever somente uma única linha lógica para cada linha física. Use mais de uma linha física para uma única linha lógica apenas se a linha lógica for realmente comprida. A ideia é evitar o ponto-e-vírgula tanto quanto possível, uma vez que isso conduz a um código mais legível. De fato, eu nunca utilizei ou sequer vi um ponto-e-vírgula num programa Python. Segue um exemplo da escrita de uma linha lógica se estendendo por muitas linhas físicas. Nos referimos a isso com junção explícita de linhas s = 'Isto é uma string. \ Isto continua a string.' print(s) Isso nos dá a saída: Isto é uma string. Isto continua a string. Similarmente, print\ (i) é o mesmo que print(i) Em alguns casos não é necessário utilizar barra invertida. Nesses casos a linha lógica usa parênteses, colchetes ou chaves. Isto se chama junção implícita de linha. Você pode vê-la em ação quando escrevermos programas usando listasem capítulos posteriores. Indentação Espaços são importantes em Python. Na verdade, espaços no início da linha são importantes. Isto é chamado de indentação. Espaços (espaços e tabs) no início da linha lógica são usados para determinar o nível de indentação da linha lógica, o qual por sua vez é usado para determinar o agrupamento de instruções Isto significa que as instruções que vão juntas devem ter a mesma indentação. Cada conjunto dessas instruções é chamada de bloco. Veremos exemplos de como os blocos são importantes nos capítulos seguintes. Uma coisa que você deve lembrar é que indentação inadequada pode ocasionar erros. Por exemplo: i = 5 print('O valor é ', i) # Erro! Perceba um espaço no início da linha print('Eu repito, o valor é ', i) Quando você executa isso, obtém o seguinte erro: File "whitespace.py", line 4 print('O valor é ', i) # Erro! Perceba um espaço no início da linha ^ IndentationError: unexpected indent Perceba que há um espaço no início da segunda linha. O erro indicado pelo Python nos diz que a sintaxe do programa é inválida, isto é, o programa não foi escrito direito. O que isso quer dizer é que você não pode iniciar novos blocos de instruções arbitrariamente (exceto pelo bloco principal padrão que você vem usando o tempo todo, é claro). Casos nos quais você pode usar novos blocos serão detalhados em capítulos posteriores, tais como o capítulo sobre controle de fluxo. Como indentar Não use uma mistura de tabs e espaços para a indentação, pois isso não funciona adequadamente em diferentes plataformas. Eu recomendo fortemente que você use um único tab ou quatro espaços para cada nível de indentação. Escolha qualquer um desses dois estilos de indentação. Mais importante, escolha um e use consistentemente, isto é, use somente aquele estilo de indentação. Nota para programadores de linguagens estáticas Python sempre utiliza indentação para blocos e nunca utiliza chaves. Executefrom __future__ import braces para aprender mais. Resumo Agora que nós discutimos vários detalhes vitais, podemosseguir para coisas mais interessantes como declarações de controle de fluxo. Certifique-se de que você já está confortável com o que você leu nesse capítulo. Python pt-br:Operadores e Expressoes Introdução A maioria das instruções (linhas lógicas) que você escreverá irão conterexpressões. Um exemplo simples de expressão é 2 + 3. Uma expressão pode ser divida em operadores e operandos. Operadores definem que operação será realizada e podem ser representados por símbolos como + ou por palavras-chave especiais. Operadores requerem dados para funcionar e tais dados são chamados operandos. Neste caso, 2 e 3 são os operandos. Operadores Iremos dar uma breve olhada nos operadores e sua utilização: Perceba que você pode testar as espressões dadas nos exemplos usando o interpretador interativo. Por exemplo, para testar a expressão 2 + 3, use o interpretador interativo do Python: >>> 2 + 3 5 >>> 3 * 5 15 >>> Operadores e sua utilização Operador Nome Explicação Exemplos + Adição Soma dois objetos 3 + 5 retorna 8. 'a' + 'b'retorna 'ab'. - Subtração Torna um número negativo ou a subtração de um número por outro -5.2 retorna um número negativo. 50 - 24 retorna 26. * Multiplicação Retorna o produto de dois números ou uma string repetida uma certa quantidade de vezes. 2 * 3 retorna 6. 'la' * 3 retorna'lalala'. ** Potência Retorna x elevado à potência de y 3 ** 4 retorna 81 (i.e. 3 * 3 * 3 * 3) / Divisão Divide x por y 4 / 3 retorna1.3333333333333333. // Divisão Inteira Retorna a parte inteira do quociente 4 // 3 retorna 1. % Modulo Retorna o resto da divisão 8 % 3 retorna 2. -25.5 % 2.25retorna 1.5. << Deslocamento de bits à esquerda Desloca os bits do número para a esquerda pelo número de bits especificado. (Cada número é representado na memória por bits ou digitos binários i.e. 0 2 << 2 retorna 8. 2 é representado por 10 em bits. Deslocando os bits do número à esquerda por 2 bits retorna 1000, que representa o número decimal 8. and 1) >> Deslocamento de bits à direita Desloca os bits do número para a direita pelo número de bits especificado. 11 >> 1 retorna 5. 11 é representado em bits por 1011que quando os bits são deslocados para a direita por 1 bit retorna 101, que é o número decimal 5. & Operador bit a bit AND Bits configurados nos dois operadores são configurados no resultado 5 & 3 retorna 1. | Operador bit a bit OR Bits configurados em um ou outro operador são configurados no resultado 5 | 3 retorna 7 ^ Operador bit a bit XOR Bits configurados em um ou outro operador, mas não em ambos, são configurados no resultado 5 ^ 3 retorna 6 ~ Operador bit a bit NOT Bits configurados no operador não são configurados no resultado e vice-versa. ~5 retorna -6. < Menor que Retorna se x é menor que y. Todos os operadores de comparção retornamTrue(verdadei ro) ou False(falso). Note a capitalização dos nomes. 5 < 3 retorna False e 3 < 5retorna True. Comparações podem ser encadeadas arbitrariamente: 3 < 5 < 7 retorna True. > Maior que Retorna se x é maior que y 5 > 3 retorna True. Se os dois operadores forem números, eles são antes convertidos a um tipo comum. De outra maneira, será sempre retornado False. <= Menor ou igual a Retorna se x é menor ou igual a y x = 3; y = 6; x <= y retornaTrue. >= Maior ou igual a Retorna se x é maior ou igual a y x = 4; y = 3; x >= 3 retornaTrue. == Igual a Compara se os objetos são iguais x = 2; y = 2; x == y retornaTrue. x = 'str'; y = 'stR'; x == yretorna False. x = 'str'; y = 'str'; x == yretorna True. != Diferente de Compara se os objetos são diferentes x = 2; y = 3; x != y retornaTrue. not Operador booleano NOT Se x é True, ele retorna False. Se x é False, ele x = True; not y retorna False. retorna True. and Operador booleano AND x and y retornaFalse se x éFalse, senão ele retorna a avaliação de y x = False; y = True; x and yretorna False desde que x seja False. Neste caso, Python não irá avaliar y desde que ele saiba que o lado esquerdo da espressão 'and' é False o que implica que toda a espressão será False independente do outro valor. isso é chamado short-circuit evaluation. or Operador booleano OR Se x é True, ele retorna True, senão ele retorna a avaliação de y x = True; y = False; x or yretorna True. A Short-circuit evaluation se aplica aqui também. Precendência de Operadores Se você tem uma expressão como 2 + 3 * 4, será realizada primeiro a adição ou a multiplicação? A matemática do nosso ensino médio nos diz que a multiplicação deve ser realizada primeiro. Isso significa que o operador de multiplicação possui maior precedência que o operador de adição. A tabela a seguir nos dá a ordem de precedência de operadores para o Python, do de menor precedência (least binding) ao de maior precedência (most binding). Isto significa que em uma dada expressão, Python irá primeiramente avaliar os operadores listados na base da tabela antes dos operadores listados ao topo. A tabela a seguir (tirada de Manual de referência Python) é proporcionada visando maior entendimento. É muito melhor usar parênteses para agrupar operadores e operandos apropriadamente de maneira que fique clara a precedência. Isso torna o programa mais legível. Veja #Ordem de Avaliaçãoabaixo para detalhes. Precedência de Operadores Operador Descrição lambda Expressão Lambda or Operador Booleano OR and Operador Booleano AND not x Operador Booleano NOT in, not in Testes de membros/existência is, is not Testes de identidade <, <=, >, >=, !=, == Comparações | Operador bit-a-bit OR ^ Operador bit-a-bit XOR & Operador bit-a-bit AND <<, >> Deslocamentos de bits +, - Adição e subtração *, /, //, % Multiplicação, Divisão, Divisão inteira e Resto +x, -x Positivo, Negativo ~x Operador bit-a-bit NOT ** Exponenciação x.atributo Referencia a atributo x[índice] Subscrição x[índice1:índice2] Repartição f(argumentos ...) Chamada de função (expressões, ...) Uniao ou exibição de tupla [expressões, ...] Exibição de listas {chave:dado, ...} Exibição de dicionário Os operadores que ainda não vimos serão explicados em capítulos posteriores. Operadores com a mesma precedência são listados na mesma linha na tabela acima. Por exemplo, + e - possuem a mesma precedência. Ordem de avaliação Por padrão, a tabela de precedência dos operadores decide que operadores são avaliados primeiro. Para tornar uma expressão mais legível podemos usar parênteses. Por exemplo,2 + (3 * 4) é, definitivamente, mais fácil de entender que 2 + 3 * 4 que requer conhecimento da ordem de precedência dos operadores. Assim como todo o resto, parênteses devem ser usados conscientemente (não sobrecarregue) e não devem ser redundantes (como em 2 + (3 + 4)). Se você quer mudar a ordem em que eles são avaliados, você pode, novamente, usar parênteses. Por exemplo, se você quer que a adição seja realizada antes da multiplicação em uma expressão, então você pode escrever algo como (2 + 3) * 4. Associatividade Operadores são, geralmente, associados da esquerda para a direita, isto é, operadores com a mesma procedência são avaliados da esquerda para a direita. Por exemplo, 2 + 3 + 4 é avaliado como (2 + 3) + 4. Alguns operadores, como os de atribuição, possuem a associatividade da direira para a esquerda, isto é, a = b = c é tratado como a = (b = c). Expressões Usando Expressões Exemplo: #!/usr/bin/python # Nome do Arquivo: expressao.py length = 5 breadth = 2 area = length * breadth print('Área é', area) print('Perímetro é', 2 * (length + breadth)) Saída: $ python expressao.py Área é 10 Perimetro é 14 Como Funciona: O tamanho e amplitude do retângulo são armazenados nas variáveislength e breadth. Nós os utilizamos para calcular a área e o perímetro do retângulo com a ajuda de expressões. Armazenamos o resultado da expressão length * breadthna variável area e então o imprimimos usando a função print. No segundo caso, usamos o valor da expressão 2 * (length + breadth) diretamente na função print. Perceba, também, como o Python faz a 'impressão elegante' (pretty-print) da saída. Mesmo que não tenhamos especificao um espaço entre 'Área é' e a variável area, Python coloca-o para nós de uma maneira que tenhamos uma saída limpa e bonita, e o programa é muito mais legível dessa maneira (desde que não tenhamos que nos preocupar com espaçamento na string que utilizamos para a saída). Isto é um exemplo de como o Python torna mais fácil a vida do programador. Sumário Vimos como utilizar operadores, operandos e expressões - estes são os blocos de construção básicos de qualquer programa. A seguir, veremos como fazer uso deles em nossos programas através de indicação. Python pt-br:Controle de Fluxo Introdução Nos programas que vimos até agora, houveram uma série de declarações e o Python executa-os na mesma ordem. E se você quisesse alterar o fluxo de seu funcionamento? Por exemplo, você quer que o programa tome algumas decisões e faça diferentes coisas dependendo das diferentes situações, como imprimir 'Bom Dia' ou 'Boa Tarde' dependendo da hora do dia? Como você deve ter pensando, isto é alcançado usando as instruções de controle de fluxo no Python - if, for e while. A instrução IF A instrução if é usada para verificar uma condição e se a condição é verdadeira, será executado um bloco de instruções (chamado de bloco-if(if-block)), senão será processado outro bloco de instruções (chamado de bloco-else(else-block)). A cláusula elseé opcional. Exemplo: #!/usr/bin/python # Nome do aquivo: if.py number = 23 guess = int(input('Entre com um número inteiro : ')) if guess == number: print('Parabéns, você advinhou.') # Novo bloco começa aqui print('(mas você não ganhou nenhum prêmio!)') # Novo bloco termina aqui elif guess < number: print('Não, era um pouco maior que isso') # Outro bloco # Você pode fazer o que quiser em um bloco ... else: print('Não, era um pouco menor que isso') # Você deve adivinhar > número a alcançar aqui print('Feito') # Esta última instrução é sempre executada, depois da instrução if ser executada Saída: $ python if.py Entre com um número inteiro : 50 Não, era um pouco menor que isso Feito $ python if.py Entre com um número inteiro : 22 Não, era um pouco maior que isso Feito $ python if.py Entre com um número inteiro : 23 Parabéns, você advinhou. (mas você não ganhou nenhum prêmio!) Feito Como Funciona: Neste programa, recebemos tentativas de advinhações do usuário e verificamos se este é igual ao número que temos. Setamos a variável number para qualquer inteiro que desejarmos, digamos 23. Então, pegamos a tentativa de advinhação do usuário usando a função input(). Funções são peças de programas reutilizáveis. Iremos ler mais sobre elas no próximo capítulo. Nós fornecemos uma string para função enbutida input que a imprime na tela e aguarda uma entrada do usuário. Uma vez que entramos com algum valor e apertamos a tecla enter, a função input() retorna o valor que entramos, como uma string. Nós, então, convetemos essa string para um inteiro usando int e depois armazenamos na variável guess. Na verdade, o int é uma classe, mas tudo o que voê precisa saber agora é que você pode usá-la para converter uma string em um número inteiro (assumindo que a string contém um número inteiro válido no texto). A seguir, comparamos a tentativa de adivinhação do usuário com o número que escolhemos. Se eles forem iguais, imprimimos uma mensagem de sucesso. Note que utilizamos níveis de indentaçãopara dizer ao Python que instruções pertencem a qual bloco. É pos isso que a indentação é tão importante no Python. Eu espero que você esteja mantendo a regra da "indentação consistente". Você está? Perceba que a instrução if contém 'dois pontos' no final - nós estamos indicando ao Python que a seguir há um bloco de instruções. Então, checamos se a tentativa de advinhação do usuário é menor que o número da variável number, e se for verdadeiro, informamos ao usuário para tentar com um número um pouco maior que o inserido. O que usamos aqui é a clausula elifque, na verdade, combina duas instruções if else-if else relacionadas em uma instrução if-elif-else combinada. Isso torna o programa mais fácil e reduz quantidade de indentações requeridas. As instruções elif else devem, também, possuir 'dois pontos' no final da linha lógica, seguido pelo seu bloco de instruções correspondente (com indentação apropriada, é claro). Você pode ter outra instrução if dentro de um bloco-if de uma instrução if if a assim por diante - isto é chamado de instrução if aninhada Lembre que as partes elif e else são opcionais. Uma instrução if mínima válida é: if True: print('Sim, é verdadeiro') Depois que python terminou de executar a instrução if completamente, junto com as cláusulas elif e else associadas, ele passa para a próxima instrução no bloco contendo a instrução if. Neste caso, é o bloco principal onde a execução do programa inicia e a próxima instrução é print('Feito'). Depois disso, Python vê o final do programa e simplesmente termina. Ainda que este seja um programa muito simples, eu estive apontando várias coisas que você deve notar em programas assim. Todas elas são bem avançadas (e surpreendentemente simples para todos vocês com conhecimento em C/C++) e requerem que você esteja inicialmente ciente de todas elas, mas depois disso, você irá se familiarizar e isso irá se tornar 'natural' para você. Nota para os programadores de C/C++ Não há a instrução switch no Python. Você pode usar uma instruçãoif..elif..else para fazer a mesma coisa (e em alguns casos, usar umdicionário para fazê-lo rapidamente) A instrução while A instrução while permite que você execute repetidamente um bloco de instruções enquanto uma condição for verdadeira. Uma instrução while é um exemplo do que é chamado de instrução de looping. Uma instrução while pode ter uma cláusula else opcional. Exemplo: #!/usr/bin/python # Nome do arquivo: while.py number = 23 running = True while running: guess = int(input('Entre com um número inteiro : ')) if guess == number: print('Parabéns, você advinhou.') running = False # Isto faz o loop while parar elif guess < number: print('Não, é um pouco maior que este.') else: print('Não, é um pouco menor que este.') else: print('O loop while terminou.') # Faça qualquer outra coisa que quiser aqui print('Fim') Saída: $ python while.py Entre com um número inteiro : 50 Não, é um pouco menor que este. Entre com um número inteiro : 22 Não, é um pouco maior que este. Enter an integer : 23 Parabéns, você advinhou. O loop while terminou. Fim Como funciona: Neste programa, nós ainda estamos jogando o jogo da advinhação, mas a vantagem é que o usuário pode continuar tentando advinhar até que ele acerte o número - não ha necessidade de rodar novamente o programa para cada tentativa de adivinhação, como fizemos na seção anterior. Isto demonstra o uso da instrução while. Nós movemos oinput e a instrução if para dentro do loop while e setamos a variável running para True antes do loop while. Primeiro, nós checamos se a variável running é True(verdadeiro) e então seguimos para executar executar o <emphasis>bloco while</emphasis> correspondente. Depois que o bloco é executado, a condição é novamente checada que neste caso é a variávelrunning. Se isso é verdade, nós executamos o bloco whilenovamente, senão continuamos para executar o bloco else optional e então seguir para a próxima instrução. O bloco else é executado quando a condição do loop while se torna False(falso) - esta pode até ser a primeira vez que a condição é verificada. Se há alguma cláusula else para um loop while, ele é sempre executado a menos que você tenha um loop while que se executado para sempre sem sair sequer uma vez! Os valores True(verdadeiro) e False(falso) são chamados tipos Booleanos e você pode considerá-los equivalentes aos valores 1 e 0 respectivamente. O bloco else é, na verdade, redundante a partir que você pode colocar estas instruções no mesmo bloco (como a instrução while) depois da instrução whilepara conseguir o mesmo efeito. Nota para programadores de C/C++ Lembre que você pode ter uma cláusula else else para o loop while. O loop for A instrução for..in é outra instrução de loop que itera sobre uma sequência de objetos, por exemplo, percorre cada item em uma sequência. Iremos ver mais sobre sequências em detalhes em capítlos posteriores. O que você precisa saber agora é que uma sequência é apenas uma coleção ordenada de itens. Exemplo: #!/usr/bin/python # Nome do arquivo: for.py for i in range(1, 5): print(i) else: print('O loop for terminou.') Saída: $ python for.py 1 2 3 4 O loop for terminou. Como funciona: Neste programa, estamos imprimindo uma sequência de números. Nós geramos esta sequência de números usando a função interna range. O que fazemos é fornecer dois números e range retorna uma sequência de números iniciando do primeiro número e segue até o segundo número. Por exemplo, range(1,5) nos dá a sequência [1, 2, 3, 4]. Por padrão, range dá um passo contando de 1 em 1. Se fornecer-mos um terceiro número para range, então ele se torna o tamanho do passo. Por exemplo, range(1,5,2) nos dá[1,3]. Lembre-se que range extende-se até o segundo número, ou seja, ele nãoinclui o segundo número. O loop for então itera sobre esta faixa - for i in range(1,5) é equivalente afor i in [1, 2, 3, 4] que é a mesma coisa que atribuir cada número (ou objeto) na sequência a i, um de cada vez, e então executar o bloco de instrições para cada valor de i. Neste caso, nós apenas imprimimos o valor no bloco de instruções. Lembre-se que a parte else é opcional. Quando incluída, ela será sempre executada uma vez após o loop for ter terminado, a não ser que uma instruçãobreak seja encontrada. Lembre-se que o loop for..in funciona para qualquer sequência. Aqui, temos uma lista de números gerados pela função interna range, mas, no geral, podemos usar qualquer tipo de sequência de qualquer tipo de objeto! Iremos explorar essa idéia em detalhes em capítulos posteriores. Nota para programadores de C/C++/Java/C# O loop for do Python é radicalmente diferente do loop for das linguagens C/C++. Programadores da linguagem C# irão notar que o loop for no Python é similar ao loop foreach em C#. Programadores da linguagem Java irão notar que o mesmo é similar a for (int i : IntArray) em Java 1.5 . Em C/C++, se você quer escrever for (int i = 0; i < 5; i++), então em Python você escreve apenas for i in range(0,5). Como você pode ver, o loop for é mais simples, mais expressivo e menos propenso a erros no Python. A instrução break A instrução break é usada para quebrar uma instrução de loop, ou seja, para a execução de uma instrução de loop, mesmo que a condição não tenha se tornado False ou a sequência de itens tenha sido iterada completamente. Uma informação importante é que se você quebra um loop for ou while, qualquer bloco else correspondente não é executado. Exemplo: #!/usr/bin/python # Nome do arquivo: break.py while True: s = input('Entre com alguma coisa: ') if s == 'sair': break print('Tamanho da string é ', len(s)) print('Feito') Saída: $ python break.py Entre com alguma coisa: Programar é divertido Tamanho da string é 21 Entre com alguma coisa: Quando o trabalho está feito Length of the string is 28 Entre com alguma coisa: se você quer tornar seu trabalho também divertido: Tamanho da string é 51 Entre com alguma coisa: use Python! Tamanho da string é 12 Entre com alguma coisa: sair Feito Como funciona: Neste programa, nós recebemos os dados de entrada do usuário repetidamente e imprimimos o tamanho de cada entrada toda vez. Estamos provendo uma condição especial para parar o programa verificando se a entrada do usuário é'sair'. Paramos o programa com <emphasis>break</emphasis>, fazendo com que saiamos do loop e alcancemos o fim do programa. O tamanho da entrada pode ser encontrado utilizando a função interna len. Lembre-se que a instrução break pode também ser usada com o loop for. Python Poético do Swaroop Os dados de entrada que utilizei aqui é um mini poema que escrevi chamadoPython Poético do Swaroop: Programar é divertido Quando o trabalho está feito se você quer tornar seu trabalho também divertido: use Python! A Instrução continue A instrução continue é usada para dizer ao Python que pule as intruções restantes do bloco de loop corrente e para continuar (continue) na iteração seguinte do loop. Exemplo: #!/usr/bin/python # Arquivo: continue.py while True: s = input('Entre com algo : ') if s == 'sair': break if len(s) < 3: print('Muito pequeno') continue print('A entrada é de tamanho suficiente') # Faça outros tipos de processo aqui... Saída: $ python continue.py Entre com algo : a Muito pequeno Entre com algo : 12 Muito pequeno Entre com algo : abc A entrada é de tamanho suficiente Entre com algo : sair Como funciona: Neste programa, aceitamos entradas do usuário, mas as processamos somente se ela possuírem pelo menos 3 caracteres. Então, utilizamos a função interna lenpara pegar o tamanho e se este for menor que 3, pulamos o resto das instruções no bloco utilizando a instrução continue. Senão, o resto das instruções no loop são executadas e poderemos fazer qualquer tipo de processamento que quiser-mos aqui. Note que a instrução continue funciona, também, com o loop for. Sumário Vimos como utilizar as três instruções de controle de fluxo - if, while and for, em conjunto com suas instruções break e continue associadas. Estas são algumas das partes mais utilizadas do Python e outras, tornar-se confortável com elas é essencial. Python pt-br:Funcoes Introdução Funções são pedaços reutilizáveis de programas. Elas permitem dar um nome para um bloco de código e rodá-lo usando seu nome em qualquer lugar do programa, quantas vezes forem necessárias. Isto é conhecido como chamar a função. Nós já usamos muitas funções internas como len e range. O conceito de função é provavelmente o bloco de construção mais importante de qualquer programa não- trivial (em qualquer linguagem de programação), portanto vamos explorar vários aspectos das funções neste capítulo. Funções são definidas usando a palavra-chave def. A mesma é seguida pelo seu nome identificador, um par de parênteses que podem conter ou não nomes de variáveis separados por vírgula, e por dois pontos ao final da linha. Em seguida o bloco de código que faz parte desta função. Um exemplo abaixo irá mostrar que isto é realmente muito simples: Exemplo: #!/usr/bin/python # Filename: funcao1.py def digaOla(): print('Olá Mundo!') # bloco pertencente à função # Fim da função digaOla() # chamando a função digaOla() # chamando a função denovo Output: $ python funcao.py Olá Mundo! Olá Mundo! Como isto funciona: Definimos a função chamada digaOla usando a sintaxe como explicado abaixo. Esta função não recebe parâmetros e conseqüentemente não há variáveis declaradas entre parênteses.Para as funções, parâmetros são somente uma entrada que podemos passar diferentes valores e receber resultados correspondentes. Repare que podemos chamar a mesma função duas vezes, o que significa que não temos que escrever o mesmo código de novo. Parâmetros da Função Uma função pode receber parâmetros, que são valores fornecidos à função para que a mesma possa fazer algo útil com os mesmos. Estes parâmetros são como variáveis, exceto que os valores destas variáveis são definidos quando chamamos a função e já estão atribuídos quando a função é executada. Parâmetros são especificados dentro do par de parênteses na definição da função, separados por vírgulas. Quando chamamos a função, passamos os valores da mesma maneira. Note a terminologia utilizada - os nomes dados na definição da função são chamados de parâmetros enquanto que os valores que fornecemos na chamada da função são chamados de argumentos. Exemplo: #!/usr/bin/python # Filename: func_param.py def printMax(a, b): if a > b: print(a, 'is maximum') else: print(b, 'is maximum') printMax(3, 4) # valores literais passados para a função x = 5 y = 7 printMax(x, y) # passando variáveis como argumentos Saída: $ python func_param.py 4 is maximum 7 is maximum Como funciona: Aqui definimos uma função chamada printMax que recebe dois parâmetros chamados a e b. Encontramos o maior número usando um simples comandoif..else e então imprimindo o maior número. No primeiro uso de printMax, nos passamos diretamente os números (argumentos). No segundo, chamamos a função usando variáveis. printMax(x, y) faz com que o valor do argumento x seja atribuído ao parâmetro a e o valor do argumento y atribuído ao parâmetro b. A função printMax funciona da mesma maneira em ambos os casos. Variáveis Locais Quando você declara variáveis dentro de uma definição de função, elas não estão relacionadas de forma alguma com outras variáveis com os mesmos nomes usados fora da função, ou seja, variáveis locais em relação à função. Isto é o que se chama de escopo da variável. Todas as variáveis têm o escopo do bloco no qual são declaradas, a partir do ponto da definição do seu nome. Exemplo: #!/usr/bin/python # Filename: func_local.py def func(x): print('x is', x) x = 2 print('Variável local x mudou para', x) x = 50 func(x) print('x continua', x) Saída: $ python func_local.py x is 50 Variável local x mudou para 2 x continua 50 Como funciona: Na função, a primeira vez que usamos o valor do nome x, o Python utiliza o valor do parâmetros declarado na função. Em seguida, atribuímos o valor 2 a x. O nome x é local à nossa função. Então, quando mudamos o valor de x na função, o x definido no bloco principal permanece inalterado. No último comando print, confirmamos que o valor de x no bloco principal está de fato inalterado. Usando o comando global Se você quer atribuit um valor a um nome definido no nível mais alto do programa, ou seja, fora de qualquer tipo de escopo tal como funções ou classes, então você tem que dizer ao Python que o nome não é local, mas sim global. Fazemos isso usando o comando global. É impossível atribuir um valor a uma variável definida fora de uma função sem utilizar o comando global. Você pode usar os valores dessas variáveis globais definidas fora da função, assumindo que não haja nenhuma variável com o mesmo nome dentro da função. No entanto, isso não é recomendado e deve ser evitado, uma vez que não fica claro para o leitor do programa onde está a definição da variável. Usar o comando global torna claro que a variável foi definida no block mais externo. Exemplo: #!/usr/bin/python # Filename: func_global.py def func(): global x print('x é', x) x = 2 print('Variável global x mudou para', x) x = 50 func() print('O valor de x é', x) Saída: $ python func_global.py x is 50 Variável global x mudou para 2 O valor de x é 2 Como funciona: O comando global é usado para declarar que x é uma variável global. Assim, quando vamos atribuir um valor a x dentro da função, essa mudança é refletida quando usamos o valor de x no bloco principal. Você pode especificar mais de uma variável global usando o mesmo comandoglobal. Por exemplo, global x, y, z. Usando o comando nonlocal Vimos acima como acessar variáveis nos escopos local e global. Existe outro tipo de escopo chamado "nonlocal", que é um meio termo entre esses dois tipos de escopo. Escopos nonlocal ocorrem quando se definem funções dentro de funções. Uma vez que tudo em Python é código executável, você pode definir funções em qualquer lugar. Vejamos um exemplo: #!/usr/bin/python # Filename: func_nonlocal.py def func_outer(): x = 2 print('x é', x) def func_inner(): nonlocal x x = 5 func_inner() print('O x local mudou para', x) func_outer() Saída: $ python func_nonlocal.py x é 2 O x local mudou para 5 Como funciona: Quando estamos dentro de func_inner, o 'x' definido na primeira linha defunc_outer não está, relativamente, nem no escopo local, nem no global. Declaramos que estamos usando esse x por meio de nonlocal x e assim temos acesso àquela variável. Tente trocar o nonlocal x para global x e também remover o comando e observar a diferença de comportamento nesses dois casos. Valores padrão de argumentos Para algumas funções, você pode querer que alguns dos seus parâmetros sejamopcionais e usar valores padrão pré-definidos se o usuário não quiser fornecer valores para esses parâmetros. Isto é feito com a ajuda de valores padrão de argumentos. Você pode especificar valores padrão de argumentos para parâmetros colocando o operador de atribuição (=) após o nome do parâmetro na definição da função, seguifo pelo valor padrão. Note que o valor do argumento padrão dever ser uma constante. Mais precisamente, o valor do argumento padrão deve ser imutável. Isso é explicado em detalhes nos capítulos seguintes. Por enquanto, basta lembrar disso. Exemplo: #!/usr/bin/python # Filename: func_default.py def say(message, times = 1): print(message * times) say('Olá') say('Mundo', 5) Saída: $ python func_default.py Olá MundoMundoMundoMundoMundo Como funciona: A função chamada say é usada para imprimir uma string quantas vezes forem necessárias. Se nós não fornecemos um valor, então, por padrão, a string é impressa apenas uma vez. Conseguimos isso especificando um valor de argumento padrão 1 para o parâmetro times. No primeiro uso de say, fornecemos apenas a string e ele a imprime uma vez. No segundo uso de say, fornecemos tanto a string quanto o argumento 5 5determinando que queremos dizer a mensagem 5 vezes. Importante Apenas os parâmetros que estiverem no final da lista de parâmetros podem receber valores padrão de argumento, ou seja, você não pode ter um parâmetro com valor de argumento padrão antes de um parâmetro sem um valor de argumento padrão na ordem dos parâmetros declarados na lista de parâmetros da função. O motivo é que os valores são atribuídos aos parâmetros por posição. Por exemplo, def func(a, b=5) é válido, mas def func(a=5, b) é não válido. Argumentos Nomeados Se você tem funções com muitos parâmetros e quer especificar apenas alguns deles, então você pode passar valores para esse parâmetros nomeando-os. Isto é o que chamamos de argumentos nomeados. Usamos o nome (palavra-chave) ao invés da posição (como viemos usando até agora) para especificar os argumentos para a função. Existem duas vantagens nessa abordagem: primeiro, é mais fácil usar a função, uma vez que não precisamos nos preocupar com a ordem dos argumentos. Segundo, podemos dar valores apenas para os parâmetros que quisermos, desde que os demais tenham valores padrão de argumento.Exemplo: #!/usr/bin/python # Filename: func_key.py def func(a, b=5, c=10): print('a é', a, 'e b é', b, 'e c é', c) func(3, 7) func(25, c=24) func(c=50, a=100) Saída: $ python func_key.py a é 3 e b é 7 e c é 10 a é 25 e b é 5 e c é 24 a é 100 e b é 5 e c é 50 Como funciona: A função chamada func tem um parâmetro sem valores padrão de argumento, seguida por dois parâmetros sem valores padrão de argumento. No primeiro uso, func(3, 7), o parâmetro a recebe o valor 3, o parametro brecebe o valor 5 e c recebe o valor padrão de 10. No segundo uso func(25, c=24), a variável a recebe o valor de 25 devido à posição do argumento. Então, o parâmetro c fica com o valor de 24 devido ao nome, ou seja, aos argumentos nomeados. A variável b fica com o valor padrão de 5. No terceiro uso func(c=50, a=100), utilizamos somente argumentos nomeados para especificar os valores. Note que estamos especificando o valor para o parâmetro c antes do valor do parâmetro a ainda que a tenha sido definido antes de c na definição da função. Parâmetros VarArgs TODO Devo escrever sobre este assunto num capítulo posterior, uma vez que ainda não falamos sobre listas e dicionários? Às vezes você pode querer definir uma função que possa receber qualquernúmero de parâmetros. Isso pode ser conseguido usando os asteriscos: #!/usr/bin/python # Filename: total.py def total(initial=5, *numbers, **keywords): count = initial for number in numbers: count += number for key in keywords: count += keywords[key] return count print(total(10, 1, 2, 3, vegetables=50, fruits=100)) Saída: $ python total.py 166 Como funciona: Quando declaramos um parâmetro prefixado com um asterisco, tal como *param, então todos os argumentos posicionais daquele ponto até o final são armazenados numa lista chamada 'param'. De maneira similiar, quando declaramos um parâmetro prefixado com dois asteriscos, tal como **param, então todos os argumentos nomeados, a partir daquele ponto até o final, serão armazenados em um dicionário chamado 'param'. Vamos explorar as listas e dicionários em um capítulo mais à frente. Parâmetros apenas por palavra-chave Se quisermos especificar que certos parâmetros por palavra-chave estejam disponíveis somente por palavra-chave e não como argumentos posicionais, estes pode ser declarados após um parâmetro marcado com asterisco: #!/usr/bin/python # Filename: keyword_only.py def total(initial=5, *numbers, vegetables): count = initial for number in numbers: count += number count += vegetables return count print(total(10, 1, 2, 3, vegetables=50)) print(total(10, 1, 2, 3)) # Levanta um erro, pois não fornecemos um valor de argumento padrão para 'vegetables' Saída: $ python keyword_only.py 66 Traceback (most recent call last): File "test.py", line 12, in <module> print(total(10, 1, 2, 3)) TypeError: total() needs keyword-only argument vegetables Como funciona: Declarar parâmetros após um parâmetro marcado com asterisco resulta em argumentos apenas por palavra-chave. Se estes argumentos não são fornecidos com um valor padrão, então chamadas à função levantarão um erro se o argumento por palavra-chave não é fornecido, como visto acima. Se você quer ter apenas parâmetros por palavra-chave mas não precisa de um parâmetro marcado com asterisco, então simplesmente use um asterisco sem qualquer nome, tal como def total(initial=5, *, vegetables). O comando return O comando return é usado para retornar da execução de uma função, isto é, sair da função. Podemos, opcionalmente, retornar um valor vindo da função. Exemplo: #!/usr/bin/python # Filename: func_return.py def maximum(x, y): if x > y: return x else: return y print(maximum(2, 3)) Saída: $ python func_return.py 3 Como funciona: A função maximum retornar o maior valor entre os parâmetros, neste caso, os números fornecidos para a função. Ela usa um simples comando if..else para encontrar o maior valor e retorna esse valor. Note que um comando return sem um valor é equivalente a return None. None é um tipo especial em Python que representa um valor nulo. Por exemplo, é usado para indicar que uma variável não possui nenhum valor quando tem o valor None. Cada função implicitamente contém um comando return None no final, a menos que você tenha escrito seu seu próprio comando return. Você pode confirmar isso executando a print someFunction() onde a função someFunction não usa o comando return, tal como: def someFunction(): pass O comando pass é usado em Python para indicar um bloco de comandos vazio. Nota Existe uma função embutida chamada max que já implementa a funcionalidade 'encontrar máximo'. Portanto, use esta função sempre que possível. DocStrings Python possui um recurso chamado strings de documentação, usualmente conhecidas pelo seu nome mais curto, docstrings. DocStrings são uma ferramenta importante da qual você deve fazer uso, uma vez que ela ajuda a documentar o programa e o torna mais fácil de entender. Python has a nifty feature calleddocumentation strings, usually referred to by its shorter name docstrings. DocStrings are an important tool that you should make use of since it helps to document the program better and makes it more easy to understand. Surpreendentemente, podemos até obter a docstring de, digamos, uma função, durante a execução do programa! Exemplo: #!/usr/bin/python # Filename: func_doc.py def printMax(x, y): '''Imprime o maior entre dois números. Os dois valores devem ser inteiros.''' x = int(x) # converte para inteiro, se possível y = int(y) if x > y: print(x, 'é o máximo') else: print(y, 'é o máximo') printMax(3, 5) print(printMax.__doc__) Saída: $ python func_doc.py 5 é o máximo Imprime o maior entre dois números. Os dois valores devem ser inteiros. Como funciona: Uma string na primeira linha lógica de uma função é o docstring para essa função. Note-se que docstrings também se aplicam a módulos e classes, que vamos aprender sobre nos respectivos capítulos. A convenção seguida para um docstring é uma string de múltiplas linhas onde a primeira linha começa com uma letra maiúscula e termina com um ponto. Em seguida, a segunda linha fica em branco, seguida de uma explicação detalhada a partir da terceira linha. É fortemente recomendado que você siga esta convenção para todos os seus docstrings em todas as suas funções não-triviais. Podemos acessar a docstring da função printMax usando o atributo (nome pertencente a) __doc__ (note o duplo sublinhado) da função. Lembre-se que Python trata tudo como um objeto e isso inclui funções. Vamos saber mais sobre os objetos no capítulo sobre classes. Se você já usou o help() em Python, então você já viu o uso de docstrings! O que ele faz é apenas buscar o atributo __doc__ dessa função e o exibir para você de uma forma elegante. Você pode experimentá-lo na função acima - basta incluirhelp(printMax) no seu programa. Lembre-se de pressionar a tecla q para sair dohelp(). Ferramentas automatizadas podem recuperar a documentação do seu programa desta maneira. Portanto, eu recomendo fortemente que você use docstrings para qualquer função não-trivial que você escreva. O comando pydoc que vem com sua distribuição Python funciona de forma semelhante a help() usando docstrings. Anotações Funções possuem outra funcionalidade avançada chamada anotações, que são um modo estiloso de anexar informação adicional para cada um dos parâmetros e também para o valor de retorno. Como o interpretador Python não interpreta estas anotações (tal funcionalidade é responsabilidade de bibliotecas de terceiros), pularemos esta funcionalidade desta discussão. Se você está interessado
Compartilhar