24.10.2014 Views

Tutorial 1 - Básico do VBA do Excel Este tutorial ... - Site Prof. Bertolo

Tutorial 1 - Básico do VBA do Excel Este tutorial ... - Site Prof. Bertolo

Tutorial 1 - Básico do VBA do Excel Este tutorial ... - Site Prof. Bertolo

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

Function somaNo(x, y)<br />

somaNo = x + y<br />

End Function<br />

O procedimento sub MostrarSoma chama a função somaNo e retorna um "8" numa caixa de mensagem.<br />

Se houverem procedimentos com nomes duplica<strong>do</strong>s em diferentes módulos, você deve precisar incluir um<br />

qualifica<strong>do</strong>r de módulo antes <strong>do</strong> nome <strong>do</strong> procedimento quan<strong>do</strong> chamar o procedimento.<br />

Por exemplo:<br />

Módulo1.MostrarSoma<br />

Passan<strong>do</strong> Argumento por Referência ou por Valor<br />

Se você passar um argumento por referência quan<strong>do</strong> chamar um procedimento, o procedimento acessa à<br />

variável atual na memória. Como resulta<strong>do</strong>, o valor da variável pode ser muda<strong>do</strong> pelo procedimento. Passar<br />

por referência é o default no <strong>VBA</strong>. Se você não especificar explicitamente em passar um argumento por<br />

valor, o <strong>VBA</strong> o passará por referência. As duas declarações seguintes conduzem ao mesmo resulta<strong>do</strong>.<br />

Sub AdicionaNo(ByRef x as integer)<br />

Sub AdicionaNo(x as integer)<br />

Aqui está um exemplo para mostrar o comportamento por referência. O procedimento sub, TestePassagem1<br />

chama AdicionaNo1 por referência e mostra "60" (50 + 10) na caixa de mensagem.<br />

Sub TestePassagem1()<br />

Dim y As Integer<br />

y = 50<br />

AdicionaNo1 y<br />

MsgBox y<br />

End Sub<br />

Sub AdicionaNo1(ByRef x As Integer)<br />

x = x + 10<br />

End Sub<br />

O exemplo seguinte mostra o comportamento por valor. O procedimento sub, TestePassagem2 chama<br />

AdicionaNo2 por valor e mostra "50" na caixa de mensagem.<br />

Sub TestePassagem2()<br />

Dim y As Integer<br />

y = 50<br />

AdicionaNo2 y<br />

MsgBox y<br />

End Sub<br />

Sub AdicionaNo2(ByVal x As Integer)<br />

x = x + 10<br />

End Sub

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!