매크로 함수 이해 (Microsoft Excel)
매크로에서 서브 루틴을 사용할 수 있다는 것을 이미 알고 있습니다. VBA를 사용하면 매크로에서 사용할 수있는 함수를 정의 할 수도 있습니다. 함수와 서브 루틴의 차이점은 함수는 값을 반환 할 수있는 반면 서브 루틴은 반환 할 수 없다는 것입니다. 다음 매크로를 고려하십시오.
Sub Macro1() TooMany = TestFunc If TooMany Then MsgBox "Too many columns selected" End Sub
Function TestFunc() TestFunc = False If Selection.Columns.Count > 10 Then TestFunc = True End If End Function
매크로 (Macro1)는 TestFunc 함수를 호출합니다. 이 함수는 수행하는 테스트에 따라 False 또는 True 값을 반환합니다. 그런 다음 Macro1은 반환 된 값에 따라 작동합니다. 함수 이름은 등호 오른쪽에 나타날 수 있습니다. 이것은 기능을 매우 강력하고 모든 프로그램의 중요한 부분으로 만듭니다. 함수 내에서 결과는 함수 자체의 이름 인 TestFunc에 할당됩니다. 이것은 함수가 반환하는 값입니다.
서브 루틴과 마찬가지로 매개 변수를 함수에 전달할 수도 있습니다.
이것은 다음 매크로에 설명되어 있습니다.
Sub Macro1() A = 12.3456 MsgBox A & vbCrLf & RoundIt(A) End Sub
Function RoundIt(X) As Integer RoundIt = Int(X + 0.5) End Function
이 간단한 매크로 (Macro1)는 숫자를 정의한 다음 메시지 상자를 사용하여 숫자와 숫자를 RoundIt 함수에 전달한 결과를 표시합니다. 출력은 12.3456 및 12입니다. 매개 변수는 괄호 안에 함수에 전달되어야합니다. 또한 함수는 전달 된 것과 동일한 변수 이름을 사용하지 않습니다. 이는 VBA가 X 값 (함수에 필요한 것)을 다시 할당하여 A 값 (프로그램이 함수에 전달하는 것)과 일치하기 때문입니다.
매개 변수를 함수에 전달할 때 기억해야 할 중요한 점은 프로그램이 함수가 예상하는 것과 동일한 수의 매개 변수를 전달해야하며 매개 변수는 유형과 순서가 일치해야한다는 것입니다.
_ 참고 : _
이 페이지 (또는 ExcelTips 사이트의 다른 페이지)에 설명 된 매크로를 사용하는 방법을 알고 싶다면 유용한 정보가 포함 된 특별 페이지를 준비했습니다.
link : / excelribbon-ExcelTipsMacros [새 브라우저 탭에서 특별 페이지를 열려면 여기를 클릭하세요]
.
_ExcelTips_는 비용 효율적인 Microsoft Excel 교육을위한 소스입니다.
이 팁 (2259)은 Microsoft Excel 97, 2000, 2002 및 2003에 적용됩니다. 여기에서 Excel (Excel 2007 이상)의 리본 인터페이스에 대한이 팁 버전을 찾을 수 있습니다.
link : / excelribbon-Understanding_Functions_in_Macros [매크로 함수 이해]
.