You are on page 1of 9

01/25/2021 20:03:03 Sheet1 507242607.

xls

LECTURE NO: VB0007(코드창에서 작업하기)

Homepage// www.iExceller.com
최초 작성일: 4/27/2000
최종 수정일: 7/22/2002
작성자: Exceller(권현욱, exceller@netian.com)

여러분들이 VBA에 능수능란해 질수록 점점 더 많은 시간을 오늘 설명드릴 코드창


(Code Window)에서 시간을 보내시게 될 것입니다.

VBA 코드창 안에 포함되는 것들

VBA 코드창 안에는 다음의 네가지가 포함되어 질 수 있습니다.


(1) 서브 프로시져(Sub Procedure): 프로시져라는 것은 어떤 동작을 수행하는 명령들의
집합체 입니다.

(2) 펑션 프로시져(Function Procedure): 펑션이라는 것은 어떤 동작을 수행(←여기까지는


프로시저와 동일)하고 그 결과값(또는 배열)을 돌려주는(즉 리턴시켜 주는) 명령들의
집합체입니다. 언뜻 이해가 되지 않지요? Sum 함수를 생각해 보세요. 특정 범위를 합계한
다음 그 결과값을 화면상에 돌려주지 않습니까.

(3) (변수)선언(Declarations): 변수에 대해서는 이미 설명을 드렸고... 변수의 타입 등에


대한 정보를 지정해 줍니다.
(4) 프로퍼티 프로시져(Property Procedure): 프로퍼티는 보통 "속성"이라고 번역이
됩니다. 이 프로퍼티 프로시져는 "클래스 모듈"이라는 좀 특별한 모듈에서 사용되는 좀
특수한 것입니다.

파일안에는 여러 개의 모듈을 삽입할 수 있습니다. 하나의의 모듈안에 여러 개의 프로시저를


넣어둘 것인지 아니면 몇 개의 모듈에다 분산해서 넣어둘 것인지는 사용자 마음입니다.

VBA 코드 입력해 보기

VBA 모듈에 코드를 삽입하는 데는 다음의 세가지 방법이 있습니다.


(1) 가장 전통적인(?) 방법: 키보드로 그냥 입력하는 방법
(2) 매크로 기록기능을 사용하는 방법: 매크로 기록기를 사용해서 코드를 만든 다음
그것을 수정하여 사용하는 방법
(3) 복사하기: 다른 모듈에서 "복사-붙여넣기" 해서 사용하는 방법

Exceller의 경우에는 (1)을 위주로 하되 (2)와 (3)의 방법을 병행해서 쓰고 있습니다.


그러할 것입니다. 자, 이제 직접 실습해 보도록 하지요.

(1) 지난 시간에 배우신 대로 프로젝트를 하나 만들고(즉 파일을 하나 만들고) 모듈시트를


한 장 삽입합니다. 그리고 나서 아래의 코드를 가장 전통적인 방법, 즉 키보드를 이용하여
모듈시트 내에 그대로 입력합니다(백문이 불여일견, 백견이 불여일打지요?).
혹시 불가항력적인(?) 요인에 의해 입력을 못하신분은 버튼을 누르세요.

9쪽 중 1쪽
01/25/2021 20:03:03 Sheet1 507242607.xls

(2) 입력이 끝났으면 실행을 시켜 보아야 겠지요? 실행을 시키는 데는 세 가지 방법이


① 코드 내에 마우스 포인터를 위치시킨 다음에 <F5>키를 누르거나,
② "실행-Sub/사용자 정의 폼 실행" 메뉴를 선택하거나,
③ 도구모음에 있는 실행버튼( )을 눌러주면 됩니다.

아마 아래와 같은 메시지박스가 나타날 것입니다.

코드를 살펴볼까요?

Dim Msg As String


Dim Answer As String
두 개의 문자열 변수를 선언해 주었습니다.
Msg = Application.UserName & "님 안녕하세요?"
Answer = MsgBox(Msg, vbYesNo)
Application.UserName이라는 것은 현재의 어플리케이션 프로그램(여기서는 엑셀이
명을 알아내는 명령어 입니다. 그런 다음에 &연산자를 써서 두개의 문자열을 합쳐서
그 값을 저장해 주었네요.

그 다음에 Answer라는 변수에는 메시지박스의 결과값(Yes/No)을 저장하였습니다


If Answer = vbNo Then
MsgBox "저런, 무슨 일이 있나요?"
Else
MsgBox "안녕하시다니 다행이네요."
End If
Answer변수의 값이 vbNo이면 "저런…" 메시지를, 어떤 일을 그렇지 않다면 "안녕하시다니
박스를 화면상에 나타내는 것입니다.

매크로 기록기능 사용하기

그러면 이번에는 매크로 기록기를 사용하여 코드를 작성해 볼까요?

9쪽 중 2쪽
01/25/2021 20:03:03 Sheet1 507242607.xls

(1) 아무 워크시트나 하나 선택합니다(현재 시트도 물론 괜찮지요).

(2) "도구-매크로-새 매크로 기록" 메뉴를 선택합니다.

(3) "매크로 기록" 대화상자가 나타나는데 그냥 "OK"를 선택합니다.

(4) 이제부터의 모든 동작이 코드로 기록이 되므로 쓸데없는 것을 누르지 않도록 각별히
주의하시고... "파일-페이지 설정" 메뉴를 클릭합니다.

(5) "용지 방향-가로"를 선택하고 "확인"을 누릅니다.

(6) "기록 중지" 버튼( )을 누릅니다.(또는 "도구-매크로-매크로 기록 중지" 메뉴를


선택해도 됩니다).

이제 기록된 매크로를 살펴 볼까요? VBE 창으로 갑니다(Alt + F11키를 눌러 보세요)


가서 Module1를 더블클릭하여 내용을 살펴보세요(만약 Module1이 이미 있다면 Module2
기록이 되어있을 것입니다).

Sub Macro1()
'
' Macro1 Macro
' 권현욱이(가) 2000-04-23에 기록한 매크로
'

'
With ActiveSheet.PageSetup
.PrintTitleRows = ""
.PrintTitleColumns = ""
End With
ActiveSheet.PageSetup.PrintArea = ""
With ActiveSheet.PageSetup
.LeftHeader = ""
.CenterHeader = ""
.RightHeader = ""
.LeftFooter = ""
.CenterFooter = ""
.RightFooter = ""
.LeftMargin = Application.InchesToPoints(0.75)
.RightMargin = Application.InchesToPoints(0.75)
.TopMargin = Application.InchesToPoints(1)
.BottomMargin = Application.InchesToPoints(1)
.HeaderMargin = Application.InchesToPoints(0.5)
.FooterMargin = Application.InchesToPoints(0.5)
.PrintHeadings = False
.PrintGridlines = False
.PrintComments = xlPrintNoComments
.PrintQuality = 600
.CenterHorizontally = False
.CenterVertically = False
.Orientation = xlLandscape
.Draft = False

9쪽 중 3쪽
01/25/2021 20:03:03 Sheet1 507242607.xls

.PaperSize = xlPaperA4
.FirstPageNumber = xlAutomatic
.Order = xlDownThenOver
.BlackAndWhite = False
.Zoom = 100
End With
End Sub

놀라지 않으셨는지? 분명 우리가 해준 거라고는 "파일-페이지 설정"으로가서 "가로방향


인쇄"를 선택한 것 밖에 없는데 이렇게 많은 코드가 저절로 작성이 되어 있다니 말입니다

그런데 정작 우리가 필요한 것은 위에서 노란색으로 표시한 부분입니다. 그 이외 라인은


삭제하셔도 됩니다. 즉 아래와 같이 축약을 해도 된다는 것이지요.

Sub Macro1()
With ActiveSheet.PageSetup
.Orientation=xlLandscape
End With
End Sub

매크로 기록 기능은 분명히 필요한 기능이긴 하지만 이처럼 불필요한 요소까지 모두


기록으로 남겨두기 때문에 융통성이 전혀 없으며, 또한 매크로 기록 기능으로 모든 것을
해결할 수는 없습니다.

위의 코드는 또 아래와 같이 더 축약할 수도 있습니다.

Sub Macro1()
ActiveSheet.PageSetup.Orientation=xlLandscape
End Sub

여기서 Orientation을 속성(Property)이라고 부릅니다. 즉 속성이라는 것은 오브젝트(개체


가진 특징이나 성격을 가리키는 것입니다. 또한 xlLandscape는 내장변수(이미 만들어져
있는 변수)라고 부릅니다. 복잡하지요? 으~~~ 속성, 개체, 내장변수…

이쯤에서 오늘 강좌를 요약을 해 볼까요?

매크로 기록 기능을 적극 활용하도록 하십시오.


그러나 그 결과를 보고 코드를 수정할 수는 있어야 합니다. 위의 예에서와 같이
불필요한 요소들이 많이 포함될뿐만 아니라 매크로 기록 기능으로는 MsgBox, InputBox,
변수 지정 등과 같은 기능은 수행할 수가 없습니다.
가끔 코딩을 하다 보면 프로퍼터(속성)나 Method(방법) 등이 생각나지 않을 때가 자주
있습니다. 이럴 경우에 매크로 기록 기능은 아주 유용하게 쓰입니다.

오늘은 여기까지…

Exceller's Book: 엑셀 XP 예제 활용 - 아무도 가르쳐주지 않는 엑셀 XP 비법/디지털북스刊


엑셀을 처음 접하는 분들, 엑셀을 몇 년간 사용해 왔으나 엑셀의 체계를

9쪽 중 4쪽
01/25/2021 20:03:03 Sheet1 507242607.xls

다잡고자 하는 분들, 그리고 '이제 엑셀에 대해서는 나를 당할자가


없도다'라고 생각하시는 분들도 참고하시기 바랍니다.

9쪽 중 5쪽
01/25/2021 20:03:03 Sheet1 507242607.xls

라는 것은 어떤 동작을 수행하는 명령들의

이라는 것은 어떤 동작을 수행(←여기까지는

m 함수를 생각해 보세요. 특정 범위를 합계한

는 이미 설명을 드렸고... 변수의 타입 등에

니다. 하나의의 모듈안에 여러 개의 프로시저를


해서 넣어둘 것인지는 사용자 마음입니다.

와 (3)의 방법을 병행해서 쓰고 있습니다. 대개가

나 만들고(즉 파일을 하나 만들고) 모듈시트를


를 가장 전통적인 방법, 즉 키보드를 이용하여

9쪽 중 6쪽
01/25/2021 20:03:03 Sheet1 507242607.xls

지요? 실행을 시키는 데는 세 가지 방법이 있습니다.

어플리케이션 프로그램(여기서는 엑셀이 되겠지요?)의 사용자


음에 &연산자를 써서 두개의 문자열을 합쳐서 Msg라는 문자열 변수에

지박스의 결과값(Yes/No)을 저장하였습니다.

메시지를, 어떤 일을 그렇지 않다면 "안녕하시다니…" 하는 메시지

9쪽 중 7쪽
01/25/2021 20:03:03 Sheet1 507242607.xls

되므로 쓸데없는 것을 누르지 않도록 각별히

보세요(만약 Module1이 이미 있다면 Module2에

9쪽 중 8쪽
01/25/2021 20:03:03 Sheet1 507242607.xls

고는 "파일-페이지 설정"으로가서 "가로방향


코드가 저절로 작성이 되어 있다니 말입니다!

색으로 표시한 부분입니다. 그 이외 라인은

으며, 또한 매크로 기록 기능으로 모든 것을

부릅니다. 즉 속성이라는 것은 오브젝트(개체)가


한 xlLandscape는 내장변수(이미 만들어져

매크로 기록 기능으로는 MsgBox, InputBox,

도 가르쳐주지 않는 엑셀 XP 비법/디지털북스刊

9쪽 중 9쪽

You might also like