Controlador de navegador web conveniente¶
Código-fonte: Lib/webbrowser.py
O módulo webbrowser
fornece uma interface de alto nível para permitir a exibição de documentos baseados na web para os usuários. Na maioria das circunstâncias, simplesmente chamar a função open()
deste módulo fará a coisa certa.
No Unix, navegadores gráficos são preferidos no X11, mas navegadores em modo texto serão usados se navegadores gráficos não estiverem disponíveis ou um display X11 não estiver disponível. Se navegadores em modo texto forem usados, o processo de chamada será bloqueado até que o usuário saia do navegador.
Se a variável de ambiente BROWSER
existir, ela será interpretada como a lista separada por os.pathsep
de navegadores a serem tentados antes dos padrões da plataforma. Quando o valor de uma parte da lista contém a string %s
, então ela é interpretada como uma linha de comando literal do navegador a ser usada com o argumento URL substituído por %s
; se a parte não contiver %s
, ela será simplesmente interpretada como o nome do navegador a ser iniciado. [1]
Para plataformas não-Unix, ou quando um navegador remoto estiver disponível no Unix, o processo de controle não esperará que o usuário termine de usar o navegador, mas permitirá que o navegador remoto mantenha suas próprias janelas na tela. Se os navegadores remotos não estiverem disponíveis no Unix, o processo de controle iniciará um novo navegador e aguardará.
No iOS, a variável de ambiente BROWSER
, bem como quaisquer argumentos que controlem direitos autorais, preferência do navegador e criação de nova aba/janela serão ignorados. As páginas web sempre serão abertas no navegador preferido do usuário, em uma nova aba, com o navegador sendo trazido para o primeiro plano. O uso do módulo webbrowser
no iOS requer o módulo ctypes
. Se ctypes
não estiver disponível, as chamadas para open()
falharão.
O script webbrowser pode ser usado como uma interface de linha de comando para o módulo. Ele aceita uma URL como argumento. Ele aceita os seguintes parâmetros opcionais:
-n
/--new-window
abre a URL em uma nova janela do navegador, se possível.-t
/--new-tab
abre a URL em uma nova página do navegador (“aba” ou “guia”).
As opções são, naturalmente, mutuamente exclusivas. Exemplo de uso:
python -m webbrowser -t "https://www.python.org"
Availability: not WASI, not Android.
A seguinte exceção é definida:
- exception webbrowser.Error¶
Exceção levantada quando ocorre um erro de controle do navegador.
As seguintes funções estão definidas:
- webbrowser.open(url, new=0, autoraise=True)¶
Exibe url usando o navegador padrão. Se new for 0, o url será aberto na mesma janela do navegador, se possível. Se new for 1, uma nova janela do navegador será aberta, se possível. Se new for 2, uma nova página do navegador (“aba” ou “guia”) será aberta, se possível. Se autoraise for
True
, a janela será levantada, se possível (observe que, em muitos gerenciadores de janelas, isso ocorrerá independentemente da configuração dessa variável).Retorna
True
se um navegador foi iniciado com sucesso,False
caso contrário.Note que em algumas plataformas, tentar abrir um nome de arquivo usando esta função pode funcionar e iniciar o programa associado do sistema operacional. No entanto, isso não é suportado nem portátil.
Levanta um evento de auditoria
webbrowser.open
com o argumentourl
.
- webbrowser.open_new(url)¶
Abre url em uma nova janela do navegador padrão, se possível; caso contrário, abre url na única janela do navegador.
Retorna
True
se um navegador foi iniciado com sucesso,False
caso contrário.
- webbrowser.open_new_tab(url)¶
Abre url em uma nova página (“aba” ou “guia”) do navegador padrão, se possível, caso contrário, equivalente a
open_new()
.Retorna
True
se um navegador foi iniciado com sucesso,False
caso contrário.
- webbrowser.get(using=None)¶
Retorna um objeto controlador para o tipo de navegador using. Se using for
None
, retorna um controlador para um navegador padrão apropriado para o ambiente do chamador.
- webbrowser.register(name, constructor, instance=None, *, preferred=False)¶
Registra o tipo de navegador name. Uma vez que um tipo de navegador é registrado, a função
get()
pode retornar um controlador para esse tipo de navegador. Se instance não for fornecido, ou forNone
, constructor será chamado sem parâmetros para criar uma instância quando necessário. Se instance for fornecido, constructor nunca será chamado, e pode serNone
.Definir preferred como
True
torna este navegador um resultado preferencial para uma chamadaget()
sem argumento. Caso contrário, este ponto de entrada só é útil se você planeja definir a variávelBROWSER
ou chamarget()
com um argumento não vazio que corresponda ao nome de um manipulador que você declarar.Alterado na versão 3.7: Parâmetro somente-nomeado preferred foi adicionado.
Vários tipos de navegadores são predefinidos. Esta tabela fornece os nomes de tipos que podem ser passados para a função get()
e as instanciações correspondentes para as classes do controlador, todas definidas neste módulo.
Nome do tipo |
Nome da classe |
Notas |
---|---|---|
|
|
|
|
|
|
|
|
|
|
|
(1) |
|
|
(1) |
|
|
(1) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
(2) |
|
|
(3) |
|
|
(3) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
(4) |
Notas:
“Konqueror” é o gerenciador de arquivos para o ambiente de desktop KDE para Unix, e só faz sentido usar se estiver no KDE. Alguma maneira de detectar o KDE de forma confiável seria legal; a variável
KDEDIR
não é suficiente. Note também que o nome “kfm” é usado mesmo ao usar o comando konqueror com o KDE 2 — a implementação seleciona a melhor estratégia para executar o Konqueror.Somente em plataformas Windows.
Somente no macOS.
Somente no iOS.
Adicionado na versão 3.2: Uma nova classe MacOSXOSAScript
foi adicionada e é usada no Mac em vez da classe anterior MacOSX
. Isso adiciona suporte para abrir navegadores que não estão definidos como padrão do sistema opercional no momento.
Adicionado na versão 3.3: Foi adicionado suporte para Chrome/Chromium.
Alterado na versão 3.12: O suporte para vários navegadores obsoletos foi removido. Os navegadores removidos incluem Grail, Mosaic, Netscape, Galeon, Skipstone, Iceape e Firefox versões 35 e abaixo.
Alterado na versão 3.13: Foi adicionado suporte para iOS.
Aqui estão alguns exemplos simples:
url = 'https://docs.python.org/'
# Abre a URL em uma nova aba, se uma janela do navegador já estiver aberta.
webbrowser.open_new_tab(url)
# Abre a URL em uma nova janela, aumentando a janela se possível.
webbrowser.open_new(url)
Objetos controladores de navegador¶
Os controladores de navegador fornecem esses métodos que são paralelos a três das funções de conveniência em nível de módulo:
- controller.name¶
Nome dependente do sistema para o navegador.
- controller.open(url, new=0, autoraise=True)¶
Exibe url usando o navegador manipulado por este controlador. Se new for 1, uma nova janela do navegador será aberta, se possível. Se new for 2, uma nova página do navegador (“aba” ou “guia”) será aberta, se possível.
- controller.open_new(url)¶
Abre url em uma nova janela do navegador manipulado por este controlador, se possível, caso contrário, abra url na única janela do navegador. Apelido para
open_new()
.
- controller.open_new_tab(url)¶
Abre url em uma nova página (“aba” ou “guia”) do navegador manipulado por este controlador, se possível, caso contrário, equivalente a
open_new()
.
Notas de rodapé