associação pythonbrasil[11] django zope/plone planet Início Logado como (Entrar)

Diferenças para "TabCompleta"

Diferenças entre as versões de 3 e 10 (7 versões de distância)
Revisão 3e 2004-01-09 17:42:54
Tamanho: 1559
Editor: 5-173
Comentário:
Revisão 10e 2004-09-07 00:48:14
Tamanho: 2379
Editor: apollo
Comentário:
Deleções são marcadas assim. Adições são marcadas assim.
Linha 1: Linha 1:
Uma dica legal para quem gosta de xeretar no ambiente interativo do Python é fazer a tecla <TAB> complentar automagicamente nomes de funções, métodos e outros. #pragma section-numbers off
= Tab Completion =

Uma dica legal para quem gosta de xeretar no ambiente interativo do Python é fazer a tecla <TAB> completar automagicamente nomes de funções, métodos e outros.
Linha 5: Linha 8:
Ponha no seu ''$HOME/.bash_profile'' ou ''$HOME/.profile'' (conforme o caso): Ponha no seu {{{$HOME/.bash_profile}}} ou {{{$HOME/.profile}}} (conforme o caso):
Linha 7: Linha 11:
export PYTHONSTARTUP="$HOME/.pythonrc" PYTHONSTARTUP="$HOME/.pythonrc"
export PYTHONSTARTUP
Linha 10: Linha 15:
Agora edite o arquivo ''$HOME/.pythonrc'' e acrescente as seguintes linhas: Agora edite o arquivo {{{$HOME/.pythonrc}}} e acrescente as seguintes linhas:
Linha 12: Linha 18:
#!python
Linha 27: Linha 34:
Use então sys.ar<TAB> para complentar sys.argv, iqual ao comportamento do Bash ou de outros aplicativos que usam a biblioteca readline. Use então {{{sys.ar<TAB>}}} para completar sys.argv, igual ao comportamento do Bash ou de outros aplicativos que usam a biblioteca {{{readline}}}.
Linha 30: Linha 37:
  * A variável de ambiente ''$PYTHONSTARTUP'' deve conter o nome de um arquivo que o Python vai ler e interpretar antes de entrar no prompt interativo. Neste caso, escolhi o nome .pythonrc mas poderia ser qualquer outro.   * A variável de ambiente {{{$PYTHONSTARTUP}}} deve conter o nome de um arquivo que o Python vai ler e interpretar antes de entrar no prompt interativo. Neste caso, escolhi o nome {{{.pythonrc}}} mas poderia ser qualquer outro.
Linha 32: Linha 39:
  * Se não funcionar, veja se a variável $PYTHONSTARTUP está definida com ''echo $PYTHONSTARTUP''. Lembre-se que o .bash_profile (ou .profile) é lido só pelo shell de login, isso quer dizer que se você entrou no ambiente gráfico, editou o arquivo e abriu um novo shell para testar é bem provável que não funcione, saia do seu ambiente, entre novamente e teste.   * Se não funcionar, veja se a variável {{{$PYTHONSTARTUP}}} está definida com {{{echo $PYTHONSTARTUP}}}. Lembre-se que o {{{.bash_profile}}} (ou {{{.profile}}}) é lido só pelo shell de login, isso quer dizer que se você entrou no ambiente gráfico, editou o arquivo e abriu um novo shell para testar é bem provável que não funcione, saia do seu ambiente, entre novamente e teste.
Linha 34: Linha 41:
  * Rodando ''python -E'' a variável $PYTHONSTARTUP não é lida.   * Rodando {{{python -E}}} a variável {{{$PYTHONSTARTUP}}} não é lida.
Linha 36: Linha 43:
--[[BR]] ''Ao procurar mais detalhes sobre o rlcompleter (o módulo usado nesse exemplo acima, acabei encontrando o [http://codespeak.net/rlcompleter2/index.cgi?home rlcompleter2], que achei mais interessante por imprimir o __doc__ string da funcao explicando os parâmetros, por exemplo, funcao(<TAB> mostra informações sobre a funcao, como parâmetros, etc. Maiores detalhes na página sobre [http://codespeak.net/rlcompleter2/index.cgi?install instalação] -- SergioBruder''

''Tem tambem o [http://ipython.scipy.org/ IPython], que tem alem de tab completion e history ja configurados por padrao, tem um monte de outras funcionalidades, como colorizacao de tracebacks por exemplo -- SidneidaSilva''

----
Linha 38: Linha 50:

Tab Completion

Uma dica legal para quem gosta de xeretar no ambiente interativo do Python é fazer a tecla <TAB> completar automagicamente nomes de funções, métodos e outros.

Como se faz isso? É simples. Acompanhe.

Ponha no seu $HOME/.bash_profile ou $HOME/.profile (conforme o caso):

PYTHONSTARTUP="$HOME/.pythonrc"
export PYTHONSTARTUP

Agora edite o arquivo $HOME/.pythonrc e acrescente as seguintes linhas:

   1 import readline
   2 import rlcompleter
   3 readline.parse_and_bind('tab: complete')

Abra um novo shell, rode o Python e faça o seguinte teste:

>>> import sys
>>> sys.<TAB><TAB>
sys.__class__             sys.argv                  sys.maxint
sys.__delattr__           sys.builtin_module_names  sys.maxunicode
...

Use então sys.ar<TAB> para completar sys.argv, igual ao comportamento do Bash ou de outros aplicativos que usam a biblioteca readline.

NOTAS:

  • A variável de ambiente $PYTHONSTARTUP deve conter o nome de um arquivo que o Python vai ler e interpretar antes de entrar no prompt interativo. Neste caso, escolhi o nome .pythonrc mas poderia ser qualquer outro.

  • Se não funcionar, veja se a variável $PYTHONSTARTUP está definida com echo $PYTHONSTARTUP. Lembre-se que o .bash_profile (ou .profile) é lido só pelo shell de login, isso quer dizer que se você entrou no ambiente gráfico, editou o arquivo e abriu um novo shell para testar é bem provável que não funcione, saia do seu ambiente, entre novamente e teste.

  • Rodando python -E a variável $PYTHONSTARTUP não é lida.

Ao procurar mais detalhes sobre o rlcompleter (o módulo usado nesse exemplo acima, acabei encontrando o [http://codespeak.net/rlcompleter2/index.cgi?home rlcompleter2], que achei mais interessante por imprimir o doc string da funcao explicando os parâmetros, por exemplo, funcao(<TAB> mostra informações sobre a funcao, como parâmetros, etc. Maiores detalhes na página sobre [http://codespeak.net/rlcompleter2/index.cgi?install instalação] -- SergioBruder

Tem tambem o [http://ipython.scipy.org/ IPython], que tem alem de tab completion e history ja configurados por padrao, tem um monte de outras funcionalidades, como colorizacao de tracebacks por exemplo -- SidneidaSilva


RudaMoura