Excel 매크로-사용자 양식
때때로 다른 사람으로부터 정보를 반복적으로 수집해야 할 수도 있습니다. Excel VBA는이 작업을 쉽게 처리 할 수있는 방법을 제공합니다.UserForm. 작성하는 다른 양식과 마찬가지로 UserForm을 사용하면 제공 할 정보를 쉽게 이해할 수 있습니다. UserForm은 제공된 컨트롤이 자체 설명이 가능하고 필요한 경우 추가 지침을 제공하므로 사용자 친화적입니다.
UserForm의 주요 장점은 정보를 채우는 데 소요되는 시간과 시간을 절약 할 수 있다는 것입니다.
사용자 양식 생성
UserForm을 생성하려면 다음과 같이 진행하십시오.
- 리본에서 개발자 탭을 클릭합니다.
- Visual Basic을 클릭합니다. 통합 문서에 대한 Visual Basic 창이 열립니다.
- 삽입을 클릭합니다.
- 드롭 다운 목록에서 사용자 양식을 선택합니다.
사용자 정의 양식이 창의 오른쪽에 나타납니다.
사용자 양식 이해
UserForm.xlsx – UserForm1 창을 최대화합니다.
이제 디자인 모드에 있습니다. UserForm에 컨트롤을 삽입하고 각 작업에 대한 코드를 작성할 수 있습니다. 도구 상자에서 컨트롤을 사용할 수 있습니다. 사용자 정의 폼의 속성은 속성 창에 있습니다. UserForm1 (UserForm의 캡션)은 프로젝트 탐색기의 양식 아래에 제공됩니다.
- 속성 창에서 UserForm의 캡션을 Project Report – Daily로 변경합니다.
- UserForm의 이름을 ProjectReport로 변경합니다.
변경 사항은 UserForm, 속성 및 프로젝트 탐색기에 반영됩니다.
도구 상자의 컨트롤
UserForm에는 다른 구성 요소가 있습니다. 구성 요소 중 하나를 클릭하면 정보가 제공되는 내용과 방법에 대한 지침이 제공되거나 선택할 수있는 옵션 (선택 사항)이 제공됩니다. 이 모든 것은 UserForm의 ToolBox에있는 ActiveX 컨트롤을 통해 제공됩니다.
Excel은 양식 컨트롤과 ActiveX 컨트롤의 두 가지 유형의 컨트롤을 제공합니다. 이 두 가지 유형의 컨트롤 간의 차이점을 이해해야합니다.
양식 컨트롤
양식 컨트롤은 Excel 버전 5.0부터 이전 버전의 Excel과 호환되는 Excel 원본 컨트롤입니다. 양식 컨트롤은 XLM 매크로 시트에서도 사용하도록 설계되었습니다.
양식 컨트롤을 사용하여 매크로를 실행할 수 있습니다. 컨트롤에 기존 매크로를 할당하거나 새 매크로를 쓰거나 기록 할 수 있습니다. 컨트롤을 클릭하면 매크로. 워크 시트의 양식 컨트롤에서 명령 단추를 삽입하여 매크로를 실행하는 방법을 이미 배웠습니다. 그러나 이러한 컨트롤은 UserForm에 추가 할 수 없습니다.
ActiveX 컨트롤
ActiveX 컨트롤은 VBA 사용자 양식에서 사용할 수 있습니다. ActiveX 컨트롤에는 모양, 동작, 글꼴 및 기타 특성을 사용자 지정하는 데 사용할 수있는 광범위한 속성이 있습니다.
UserForm ToolBox에 다음과 같은 ActiveX 컨트롤이 있습니다.
- Pointer
- Label
- TextBox
- ComboBox
- ListBox
- CheckBox
- OptionButton
- Frame
- ToggleButton
- CommandButton
- TabStrip
- MultiPage
- ScrollBar
- SpinButton
- Image
이러한 컨트롤 외에도 Visual Basic은 메시지를 표시하거나 사용자에게 작업을 요청하는 데 사용할 수있는 MsgBox 함수를 제공합니다.
다음 몇 섹션에서는 이러한 컨트롤과 MsgBox를 이해하게됩니다. 그런 다음 사용자 정의 폼을 디자인하는 데 필요한 컨트롤을 선택할 수 있습니다.
상표
제목, 캡션 및 / 또는 간단한 지침과 같은 설명 텍스트를 표시하여 식별 목적으로 레이블을 사용할 수 있습니다.
Example
TextBox
직사각형 상자 인 TextBox를 사용하여 텍스트를 입력,보기 또는 편집 할 수 있습니다. 읽기 전용 정보를 제공하는 정적 텍스트 필드로 TextBox를 사용할 수도 있습니다.
Example
리스트 박스
목록 상자를 사용하여 사용자가 선택할 수있는 하나 이상의 텍스트 항목 목록을 표시 할 수 있습니다. 목록 상자를 사용하여 수 또는 내용이 다른 많은 선택 항목을 표시합니다.
- UserForm에 ListBox를 삽입합니다.
- ListBox를 클릭하십시오.
- ListBox의 속성 창에서 이름에 ProjectCodes를 입력합니다.
세 가지 유형의 목록 상자가 있습니다-
Single-selection List box− 단일 선택 목록 상자는 하나의 선택 만 가능합니다. 이 경우 목록 상자는 많은 항목을보다 효율적으로 처리 할 수 있다는 점을 제외하면 옵션 단추 그룹과 비슷합니다.
Multiple selection List Box − 다중 선택 목록 상자는 하나의 선택 또는 연속 (인접) 선택을 가능하게합니다.
Extended-selection List Box − 확장 선택 목록 상자는 하나의 선택, 연속 선택 및 비 연속 (또는 분리 된) 선택을 가능하게합니다.
속성 창에서 이러한 유형의 목록 상자 중 하나를 선택할 수 있습니다.
- 사용자 양식을 마우스 오른쪽 버튼으로 클릭합니다.
- 드롭 다운 목록에서 코드보기를 선택합니다. UserForm의 코드 창이 열립니다.
- 코드 창의 오른쪽 상단 상자에서 초기화를 클릭합니다.
- Private Sub UserForm_Initialize () 아래에 다음을 입력합니다.
ProjectCodes.List = Array ("Proj2016-1", "Proj2016-2", "Proj2016-3", "Proj20164", "Proj2016-5")
- 리본에서 실행 탭을 클릭합니다.
- 드롭 다운 목록에서 Run Sub / UserForm을 선택합니다.
다음으로 목록에서 항목을 선택하는 작업에 대한 코드를 작성할 수 있습니다. 그렇지 않으면 선택한 텍스트 만 표시 할 수 있습니다. 이는 보고서에서 프로젝트 코드를 채우는 경우입니다.
콤보 박스
당신이 사용할 수있는 ComboBox드롭 다운 목록 상자를 만들기 위해 텍스트 상자와 목록 상자를 결합합니다. 콤보 상자는 목록 상자보다 더 작지만 사용자가 항목 목록을 표시하려면 아래쪽 화살표를 클릭해야합니다. 콤보 상자를 사용하여 목록에서 항목을 하나만 선택하십시오.
- UserForm에 ComboBox를 삽입합니다.
- ComboBox를 클릭합니다.
- ComboBox의 속성 창에서 이름으로 ProjectCodes2를 입력합니다.
- 사용자 양식을 마우스 오른쪽 버튼으로 클릭합니다.
- 드롭 다운 목록에서 코드보기를 선택합니다.
- UserForm의 코드 창이 열립니다.
아래와 같이 입력합니다.
ProjectCodes2.List = Array ("Proj2016-1", "Proj2016-2", "Proj2016-3", "Proj20164", "Proj2016-5")
- 리본에서 실행 탭을 클릭합니다.
- 드롭 다운 목록에서 Run Sub / UserForm을 선택합니다.
항목 목록을 표시하려면 아래쪽 화살표를 클릭합니다.
필요한 항목 (예 : Project2016-5)을 클릭합니다. 선택한 옵션이 콤보 상자에 표시됩니다.
체크 박스
확인란을 사용하여 상자를 클릭하여 표시되는 하나 이상의 옵션을 선택할 수 있습니다. 옵션에는 레이블이 있으며 선택한 옵션을 명확하게 시각화 할 수 있습니다.
확인란은 두 가지 상태를 가질 수 있습니다.
- 선택됨 (켜짐), 상자에 체크 표시로 표시
- 선택 취소 (꺼짐), 투명 상자로 표시
공간을 절약하기 위해 콤보 상자에서 옵션을 선택할 때 확인란을 사용할 수 있습니다. 이 경우 확인란은 세 번째 상태도 가질 수 있습니다.
혼합, 켜짐 및 꺼짐 상태의 조합을 의미하며 상자에 검은 색 점으로 표시됩니다. 확인란이있는 콤보 상자에서 다중 선택을 나타 내기 위해 표시됩니다.
아래와 같이 UserForm에 체크 박스를 삽입합니다.
- 리본에서 실행 탭을 클릭합니다.
- 드롭 다운 목록에서 Run Sub / UserForm을 선택합니다.
- 선택한 옵션의 상자를 클릭하십시오.
OptionButton
라디오 버튼이라고도하는 옵션 버튼을 사용하여 제한된 상호 배타적 인 선택 항목 내에서 단일 항목을 선택할 수 있습니다. 옵션 버튼은 일반적으로 그룹 상자 또는 프레임에 포함됩니다.
옵션 버튼은 작은 원으로 표시됩니다. 옵션 버튼은 다음 두 가지 상태 중 하나를 가질 수 있습니다.
- 선택됨 (켜짐), 원 안에 점으로 표시
- 지워짐 (꺼짐), 공백으로 표시
틀
그룹 상자라고도하는 프레임 컨트롤을 사용하여 관련 컨트롤을 하나의 시각적 단위로 그룹화 할 수 있습니다. 일반적으로 옵션 단추, 확인란 또는 밀접하게 관련된 내용은 프레임 컨트롤에 그룹화됩니다.
프레임 컨트롤은 선택적 레이블이있는 직사각형 개체로 표시됩니다.
"선택"캡션이있는 프레임을 삽입합니다.
프레임 컨트롤에 "예"및 "아니요"캡션이있는 두 개의 옵션 단추를 삽입합니다. 예 및 아니오 옵션은 상호 배타적입니다.
- 리본에서 실행 탭을 클릭합니다.
- 드롭 다운 목록에서 Run Sub / UserForm을 선택합니다.
- 선택한 옵션을 클릭하십시오.
ToggleButton
토글 버튼을 사용하여 예 또는 아니오와 같은 상태 또는 켜기 또는 끄기와 같은 모드를 나타낼 수 있습니다. 버튼을 클릭하면 활성화 된 상태와 비활성화 된 상태가 번갈아 나타납니다.
아래와 같이 UserForm에 토글 버튼을 삽입하십시오-
리본에서 실행 탭을 클릭합니다.
드롭 다운 목록에서 Run Sub / UserForm을 선택합니다. 토글 버튼은 기본적으로 활성화 상태입니다.
토글 버튼을 클릭합니다. 토글 버튼이 비활성화됩니다.
토글 버튼을 다시 클릭하면 활성화됩니다.
CommandButton
명령 단추를 사용하여 사용자가 클릭 할 때 일부 동작을 수행하는 매크로를 실행할 수 있습니다. 워크 시트에서 명령 단추를 사용하여 매크로를 실행하는 방법을 이미 배웠습니다.
명령 단추는 누름 단추라고도합니다. 아래와 같이 UserForm에 명령 버튼을 삽입합니다.
- 명령 버튼을 마우스 오른쪽 버튼으로 클릭하십시오.
- 하위 Commandbutton1_click ()에 다음 코드를 입력합니다.
ProjectCodes2.DropDown
- 리본에서 실행 탭을 클릭합니다.
- 드롭 다운 목록에서 Run Sub / UserForm을 선택합니다.
명령 단추를 클릭하십시오. 코드에서 작성한 작업이므로 콤보 상자의 드롭 다운 목록이 열립니다.
TabStrip
UserForm에 Excel 탭과 유사한 탭 표시 줄을 삽입 할 수 있습니다.
스크롤 바
스크롤 막대를 사용하여 스크롤 화살표를 클릭하거나 스크롤 상자를 끌어 값 범위를 스크롤 할 수 있습니다.
원하는 위치에 그려서 UserForm에 스크롤바를 삽입하고 스크롤바의 길이를 조정합니다.
- 스크롤 막대를 마우스 오른쪽 버튼으로 클릭합니다.
- 드롭 다운 목록에서 코드보기를 선택합니다. 코드 창이 열립니다.
- 하위 ScrollBar1_Scroll () 아래에 다음 줄을 추가합니다.
TextBox2.Text = "Scrolling Values"
- 리본에서 실행 탭을 클릭합니다.
- 드롭 다운 목록에서 Run Sub / UserForm을 선택합니다.
스크롤 상자를 끕니다. 텍스트 – 스크롤링 값은 스크롤 막대 스크롤에 대한 작업으로 지정한대로 텍스트 상자에 표시됩니다.
MsgBox ()
MsgBox () 함수를 사용하여 무언가를 클릭 할 때 메시지를 표시 할 수 있습니다. 지침 또는 일부 정보, 경고 또는 오류 경고 일 수 있습니다.
예를 들어 스크롤 상자 스크롤을 시작할 때 값이 스크롤된다는 메시지를 표시 할 수 있습니다.
메시지 상자 아이콘 표시
특정 메시지를 나타내는 메시지 상자 아이콘 디스플레이를 사용할 수 있습니다. 목적에 맞게 여러 개의 메시지 상자 아이콘이 있습니다.
- ScrollBar1_scroll 아래에 다음 코드를 입력합니다.
MsgBox "Select Ok or Cancel", vbOKCancel, "OK - Cancel Message"
MsgBox "It's an Error!", vbCritical, "Run time result"
MsgBox "Why this value", vbQuestion, "Run time result"
MsgBox "Value Been for a Long Time", vbInformation, "Run time result"
MsgBox "Oh Is it so", vbExclamation, "Run time result"
- 리본에서 실행 탭을 클릭합니다.
- 드롭 다운 목록에서 Run Sub / UserForm을 선택합니다.
- 스크롤 상자를 끕니다.
다음 메시지 상자가 연속적으로 표시됩니다.
사용자 양식 디자인
이제 UserForm에서 사용할 수있는 다양한 컨트롤을 이해했습니다. 컨트롤을 선택하고 필요한 경우 그룹화하고 의미있는 순서에 따라 사용자 정의 폼에 정렬합니다. 각 컨트롤에 해당하는 코드로 필요한 작업을 작성합니다.
UserForm의 예는이 튜토리얼 라이브러리의 VBA 튜토리얼을 참조하십시오.