Nota: A função, método, objeto ou propriedade descrita neste tópico está desativada se o Serviço Microsoft Jet Expression estiver em execução no modo sandbox, o que impede a avaliação de expressões potencialmente inseguras. Para obter mais informações sobre o modo sandbox, procure "modo sandbox" na Ajuda.
Executa um programa executável e devolve uma Variante (Duplo) que representa o ID da tarefa do programa, caso contrário, devolve zero.
Sintaxe
Shell( pathname [, windowstyle ] )
A sintaxe da função Shell tem estes argumentos:
Argumento |
Descrição |
pathname |
Obrigatório. Variante (Cadeia). Nome do programa a executar e quaisquer argumentos necessários ou linha de comandos comutadores; pode incluir diretório ou pasta e unidade. No Macintosh, pode utilizar a função MacID para especificar a assinatura de uma aplicação em vez do respetivo nome. O exemplo seguinte utiliza a assinatura do Microsoft Word: Shell MacID("MSWD") |
estilo de janela |
Opcional. Variante (Número Inteiro) correspondente ao estilo da janela em que o programa vai ser executado. Se o estilo de janela for omitido, o programa é iniciado minimizado com o foco. No Macintosh (Sistema 7.0 ou posterior), o estilo de janela só determina se a aplicação obtém ou não o foco quando é executada. |
O estilo de janela com o nome argumento tem estes valores:
Constante |
Valor |
Descrição |
vbHide |
0 |
A janela está oculta e o foco é transmitido para a janela oculta. A constante vbHide não é aplicável nas plataformas Macintosh. |
vbNormalFocus |
1 |
A janela tem o foco e é restaurada para o tamanho e posição originais. |
vbMinimizedFocus |
2 |
A janela é apresentada como um ícone com foco. |
vbMaximizedFocus |
3 |
A janela é maximizada com o foco. |
vbNormalNoFocus |
4 |
A janela é restaurada para o tamanho e posição mais recentes. A janela atualmente ativa permanece ativa. |
vbMinimizedNoFocus |
6 |
A janela é apresentada como um ícone. A janela atualmente ativa permanece ativa. |
Observações
Se a função Shell executar com êxito o ficheiro com nome, devolve o ID da tarefa do programa iniciado. O ID da tarefa é um número exclusivo que identifica o programa em execução. Se a função Shell não conseguir iniciar o programa com nome, ocorrerá um erro.
No Macintosh, vbNormalFocus, vbMinimizedFocus e vbMaximizedFocus colocam a aplicação em primeiro plano; vbHide, vbNoFocus, vbMinimizeFocus colocam a aplicação em segundo plano.
Nota: Por predefinição, a função Shell executa outros programas de forma assíncrona. Isto significa que um programa iniciado com a Shell pode não terminar a execução antes de as instruções que se seguem à função Shell serem executadas.
Exemplo
Nota: Os exemplos seguintes demonstram a utilização desta função no módulo VBA (Visual Basic for Applications). Para obter mais informações sobre como trabalhar com o VBA, selecione Referência para Programadores na lista pendente junto a Procurar e introduza um ou mais termos na caixa de pesquisa.
Este exemplo utiliza a função Shell para executar uma aplicação especificada pelo utilizador. No MacIntosh, o nome da unidade predefinida é "HD" e as partes do nome do caminho são separadas por dois pontos em vez de barras invertidas. Da mesma forma, especificaria pastas macintosh em vez de \Windows.
' Specifying 1 as the second argument
' opens the application in normal size and ' gives it the focus. Dim RetVal ' Run Calculator. RetVal = Shell("C:\WINDOWS\CALC.EXE", 1)