본문 바로가기
#4 VBA/#4.1 환경설정 및 기본개념

매크로 실행 방법 총정리

by 이세계의엑셀 2024. 12. 29.
반응형

매크로 실행 방법 총정리를 제대로 이해하면, 엑셀 자동화와 VBA 코드 활용을 더욱 효율적으로 진행할 수 있다. 다양한 실행 경로와 설정 방법을 폭넓게 살펴보고, 실무에서 자주 쓰이는 구체적 예시를 통해 매크로 실행 방법을 꼼꼼히 정리해보자.

매크로 실행 방법 총정리를 알고 있으면, 엑셀(Excel)에서 반복 업무를 자동화하는 과정을 훨씬 수월하게 진행할 수 있다. 매크로를 구동하는 데에는 여러 가지 경로가 있으며, 선택 방식에 따라 단축키 적용부터 버튼 삽입, 폼 이벤트, 통합 문서 열기 시점 자동 실행까지 폭넓게 활용 가능하다. 매번 VBA 에디터를 열어 코드를 실행하는 대신, 본인이 익숙한 방식으로 편리하게 매크로를 동작시킬 수 있다는 점이 매크로 자동화의 큰 장점이다.

반응형

매크로 목록에서 직접 실행하기

기본 메뉴 활용

  • 매크로 실행 방법 중 가장 직관적인 방식은 [개발 도구] 탭(또는 [보기] 탭) → [매크로] 메뉴를 사용하는 것이다.
  • 매크로 창이 열리면, 현재 통합 문서 안에 있는 모든 매크로 목록이 표시된다.
  • 원하는 매크로를 선택한 뒤 [실행] 버튼을 누르면 된다.
  • 이 방식은 별도의 설정 없이도 기본적으로 제공되므로, 매크로 실행 방법 중 입문자가 가장 쉽게 접근할 수 있는 방법이다.

매크로 옵션 수정

  • 매크로 목록에서 [옵션] 버튼을 누르면, 매크로 이름이나 단축키(Ctrl + 어떤 키), 설명 등을 수정 가능하다.
  • 여러 매크로가 있을 경우, 매크로 실행 방법을 간소화하고자 자주 쓰는 매크로에 단축키를 지정하면 편리하다.
  • 하지만 Ctrl 조합 단축키가 엑셀 기본 단축키와 겹치지 않도록 유의한다.

단축키로 실행하기

매크로에 단축키 지정

  • 매크로 실행 방법 총정리에서 빠질 수 없는 것이 단축키 설정이다.
  • 이미 작성된 매크로가 있다면 [개발 도구] 탭 → [매크로] → [옵션]에서 Ctrl + Shift 등을 조합해 단축키를 지정할 수 있다.
  • 이를 활용하면 매번 매크로 목록을 열 필요 없이, 키보드만으로 즉시 매크로를 구동할 수 있다.

단축키 활용 시 주의점

  • 엑셀 자체 단축키(Ctrl + C, Ctrl + V 등)와 겹치면, 기존 기능이 동작하지 않고 매크로가 실행될 수 있다.
  • Ctrl + Shift를 섞어 쓰면 중복을 줄일 수 있지만, 사용자가 기억하기 복잡해질 수 있으므로 적절한 균형을 찾는 것이 중요하다.

 

버튼(Control)으로 실행하기

리본 메뉴의 양식 컨트롤 활용

  • 매크로 실행 방법 총정리를 할 때, 시트 위에 버튼(양식 컨트롤)을 삽입해 두면 시각적으로 편리하다.
  • [개발 도구] 탭 → [삽입] → [양식 컨트롤] 중 [단추(Button)]를 클릭한 뒤, 시트에 드래그해 원하는 크기로 만든다.
  • 버튼을 놓으면 “매크로 지정” 대화 상자가 자동으로 뜨고, 연결할 매크로를 선택하면 된다.
  • 이때 버튼에 표시될 텍스트(예: “보고서 생성”)도 사용자 편의에 맞게 바꿀 수 있다.

ActiveX 컨트롤 활용

  • 양식 컨트롤이 아닌 ActiveX 컨트롤 버튼을 쓰면, 속성 창이나 이벤트 프로시저를 통해 더 풍부한 동작을 구현할 수 있다.
  • ActiveX 버튼을 삽입한 후, 해당 버튼을 더블 클릭하면 VBA 코드 창이 열리는데, 버튼의 Click 이벤트에 매크로 실행 로직을 연결하면 된다.
Private Sub CommandButton1_Click()
    Call 보고서생성매크로
End Sub
  • 이런 식으로 코드를 작성해두면, 버튼을 누르는 즉시 매크로가 동작한다.

그림, 도형, 아이콘 등에 연결해 실행하기

도형에 매크로 연결하기

  • 엑셀에서 [삽입] 탭 → [도형]을 클릭해 원하는 그림이나 도형을 그린 다음, 오른쪽 클릭 → [매크로 지정]을 선택할 수 있다.
  • 이를 통해 도형 자체가 매크로를 실행하는 트리거 역할을 하게 만들 수 있다.
  • 예를 들어, 보고서가 완성된 형태의 아이콘 모양을 시트에 그려두고, 클릭하면 해당 매크로가 실행되도록 설정한다면 직관적이다.

그림 또는 클립아트에 매크로 연결

  • 회사 로고나 특정 이미지를 시트에 삽입한 뒤, 같은 방식으로 [매크로 지정]을 통해 실행할 수도 있다.
  • 시각적으로 강조된 아이콘을 이용해 매크로를 실행하면, 매크로 사용을 잘 모르는 사람도 쉽게 인지하고 활용할 수 있다.

 

빠른 실행 도구 모음(Quick Access Toolbar) 활용

빠른 실행 도구 모음에 매크로 추가

  • 엑셀 윈도우 상단(파일 메뉴 위)에 있는 빠른 실행 도구 모음에 자주 쓰는 기능들을 추가할 수 있다.
  • [빠른 실행 도구 모음 사용자 지정] → [기타 명령]으로 들어가면, 명령 선택 항목을 “매크로”로 바꿔서 등록하고자 하는 매크로를 추가 가능하다.
  • 이 방법을 쓰면 엑셀 어디서든 상단의 아이콘을 클릭해 매크로를 즉시 실행할 수 있다.

아이콘 변경

  • 빠른 실행 도구 모음에 등록된 매크로는 기본 아이콘이 톱니바퀴 모양처럼 나타난다.
  • [수정] 버튼을 눌러 다른 모양의 아이콘으로 바꿀 수 있으며, 표시 이름 역시 원하는대로 구성 가능하다.
  • 아이콘 색상이나 형태를 활용해 매크로별로 시각적 구분을 해두면, 여러 개의 매크로 아이콘을 관리하기가 한결 수월해진다.

통합 문서 열 때 자동 실행하기

Workbook_Open 이벤트

  • VBA 편집기(VBE)에서 ThisWorkbook 객체를 더블 클릭한 뒤, 코드 창 상단 드롭다운을 “Workbook”으로, 우측 드롭다운을 “Open”으로 선택하면 Workbook_Open() 이벤트 프로시저가 생성된다.
  • 엑셀 파일이 열리는 순간 자동으로 실행되어야 할 매크로가 있다면, 여기에 코드를 넣으면 된다.
Private Sub Workbook_Open()
    Call 초기세팅매크로
End Sub
  • 이렇게 설정하면, 통합 문서를 여는 즉시 초기세팅매크로가 동작하여 특정 시트를 자동으로 숨기거나, 변수 초기화, 보안 설정 등을 수행하도록 만들 수 있다.

자동 실행 시 주의사항

  • 외부 사용자나 사내 규정이 엄격한 환경에서는, 파일 열기 시 매크로 경고가 뜨며 차단될 수 있다.
  • 이때는 신뢰할 수 있는 위치(Trusted Locations)에 파일을 보관하거나, 서명된 매크로를 사용해 경고를 최소화해야 한다.
  • 통합 문서를 열자마자 긴 매크로가 실행될 경우, 사용자가 작업을 시작하기 전 한참 기다려야 할 수도 있으므로, 수행 시간도 고려해야 한다.

 

이벤트를 통한 실행

시트 이벤트 예시

  • 특정 시트가 활성화될 때, 셀 내용이 변경될 때 등 다양한 이벤트에도 매크로를 연결할 수 있다.
  • 예를 들어 시트 탭을 더블 클릭하고, 코드 창 상단의 (General)을 “Worksheet”로 바꾼 뒤, 우측 드롭다운에서 “Change” 이벤트를 선택하면, 셀 값이 바뀔 때마다 코드가 실행된다.
Private Sub Worksheet_Change(ByVal Target As Range)
    If Not Intersect(Target, Range("A1")) Is Nothing Then
        MsgBox "A1 셀이 변경되었습니다. 매크로 실행!"
    End If
End Sub
  • 이런 식으로 특정 범위가 바뀔 때 자동으로 매크로를 동작시킬 수 있다.

다른 이벤트 활용

  • Worksheet_Activate, Worksheet_BeforeDoubleClick, Workbook_BeforeClose 등 다양한 이벤트가 있으니, 원하는 상황에 맞춰 매크로 실행 방법을 설정해두면 된다.
  • 자동 이벤트 매크로는 강력하지만, 예상치 못한 타이밍에도 실행될 수 있으므로 테스트가 중요하다.

사용자 폼(UserForm)에서 실행

폼 내부 버튼

  • UserForm을 생성해 내부에 CommandButton을 배치한 뒤, Click 이벤트에 매크로를 연결하면 된다.
  • 이 경우 매크로 실행 전 폼을 표시해야 하므로, 다음처럼 다른 모듈에서 UserForm을 띄운다.
Sub ShowMyForm()
    UserForm1.Show
End Sub
  • 사용자 폼이 로드된 상태에서 버튼을 누르면, 폼 코드의 CommandButton_Click 이벤트가 트리거되어 매크로가 동작한다.

복잡한 입력 로직 처리

  • 사용자 폼은 텍스트 박스, 콤보 박스 등 다양한 UI 요소를 담을 수 있기 때문에, 매크로 실행 방법을 사용자 입력과 연동하려는 경우에 유용하다.
  • 예: 원하는 날짜, 제품명을 폼에서 입력받은 다음, 그 정보를 바탕으로 매크로를 실행해 시트에 데이터를 필터링·삽입하는 로직이 가능하다.

VBA 코드 예시: 간단한 매크로 실행 총정리

아래 코드는 여러 방식으로 매크로를 실행해볼 수 있도록 예시를 구성한 것이다. 실제 업무 상황에 맞춰 자유롭게 변경 가능하다.

' 모듈(Module) 내에 작성된 예시 코드

Sub 기본동작매크로()
    MsgBox "매크로 실행 방법 총정리 예시: 이 창이 뜨면 매크로가 정상 실행된 것입니다."
End Sub

Sub 보고서생성매크로()
    Sheets("보고서").Activate
    Range("A1").Value = "보고서 생성 완료"
    MsgBox "보고서생성매크로가 실행되었습니다."
End Sub

Sub 초기세팅매크로()
    Sheets("설정").Visible = xlSheetHidden
    MsgBox "설정 시트 숨김 완료"
End Sub

' 통합 문서 열 때 자동 실행
Private Sub Workbook_Open()
    Call 초기세팅매크로
End Sub

' 시트 변경 이벤트 예시
Private Sub Worksheet_Change(ByVal Target As Range)
    If Not Intersect(Target, Range("B1")) Is Nothing Then
        MsgBox "B1 셀이 변경되어 자동 매크로가 실행되었습니다."
    End If
End Sub
  • 기본동작매크로보고서생성매크로는 [매크로 목록]에서 실행하거나, 단축키 지정, 시트 버튼 연결 등 다양한 방법으로 호출할 수 있다.
  • 초기세팅매크로Workbook_Open 이벤트와 결합해, 통합 문서를 열자마자 자동 실행된다.
  • Worksheet_Change 이벤트로 특정 셀이 변경될 때마다 메시지 박스를 띄워 확인할 수 있다.

매크로 실행 전·후 체크사항

매크로 보안 설정

  • 매크로 실행 방법 총정리를 해도, 엑셀 보안 설정이 ‘모든 매크로 차단’ 상태면 실행 자체가 불가능하다.
  • 업무 환경에 따라 보안 경고가 뜰 수 있으니, 신뢰할 수 있는 위치를 등록하거나, 디지털 서명된 매크로를 사용하는 것이 바람직하다.

파일 확장자

  • 매크로를 포함하는 통합 문서는 .xlsm, .xlsb 등의 확장자를 사용해야 한다.
  • .xlsx 확장자로 저장하면 매크로가 사라지거나, 아예 실행 불가능할 수 있으므로 주의한다.

참조(References) 설정

  • 고급 VBA 코드를 쓸 때, 예를 들어 Outlook 객체 라이브러리 등을 참조해야 하는 경우가 있다.
  • Tools → References에서 해당 라이브러리를 체크해두지 않으면, 매크로 실행 시 컴파일 오류가 발생할 수 있다.

충돌 가능성

  • 이벤트를 통해 자동 실행되는 매크로가 동시에 여러 개 작동하면 엑셀 응답이 느려지거나, 충돌이 생길 수 있다.
  • 매크로 실행 방법을 다양하게 설정할수록, 중복 실행 문제가 없는지 확인해야 한다.

실무에서 매크로 실행 방법 효율화하기

반복 업무 자동화 포인트

  • 업무 프로세스 중 매일·매주 동일한 절차가 필요한 곳에 우선 매크로를 적용한다.
  • 예컨대 자료 불러오기 → 특정 위치로 복사 → 서식 적용 → 결과 보고서 시트로 이동 → PDF 저장 등의 흐름을 매크로로 묶으면 큰 효율 향상을 얻는다.

사용자 접근 편의성

  • 대규모 조직에서 공용 파일을 배포할 때, 매크로 실행 방법이 직관적이어야 한다.
  • 도형이나 버튼, 빠른 실행 도구 모음 같은 시각적 요소로 접근성을 높이거나, UserForm으로 안내 메시지를 제공하면 혼란을 줄일 수 있다.

예외 상황 처리

  • 매크로 실행 중 오류가 발생하면, 런타임 에러 메시지와 함께 코드가 중단될 수 있다.
  • On Error 구문을 통한 에러 처리 로직을 추가해 두면, 예기치 못한 상황에서도 매크로가 안정적으로 종료되거나 안내 메시지를 표시한다.

매크로 실행 방법 총정리 다시 한번 강조

매크로 실행 방법은 다양하다. 매크로 목록에서 직접 클릭 실행, 단축키, 시트 버튼, 그림/도형 연결, 빠른 실행 도구 모음, 통합 문서 열기 시 자동 실행, 워크시트 이벤트, 사용자 폼 이벤트 등 각 상황에 맞는 방식을 선택하면 된다. 매크로 실행 방법 총정리를 잘 숙지해두면, 엑셀 자동화를 더욱 자유롭게 활용할 수 있다. 이처럼 매크로 실행 방법을 다채롭게 구성하면, 반복 업무를 손쉽게 처리하면서도 사용자 편의성을 극대화할 수 있다.

반응형