PGR21.com
- 자유 주제로 사용할 수 있는 게시판입니다.
- 토론 게시판의 용도를 겸합니다.
Date 2019/08/01 23:33:49
Name 산양
Subject [일반] 배워서 남주네) 엑셀과 vba를 이용해 공정관리 시트 구현하기 - 1 (수정됨)

배워서 남주네) 엑셀과 vba를 이용해 공정관리 시트 구현하기 - 0

pgr21.com/?b=8&n=82011
*엑셀 파일은 윗 링크에 있습니다.


안녕하세요. 시간당 생산성을 높여 생산량을 늘려보고 싶은 (전)학생산양입니다.


이번 편에서는 본격적인 vba 코드 리뷰를 하기 전에 시트를 어떻게 건드려놨는지 간단히 뜯어보겠습니다.


1. 기본적인 레이아웃입니다.

1

1) 연도를 갱신하는 곳입니다. 연도를 입력한 뒤 갱신하면 해당 연도에 맞게 토/일을 빨간 색으로 칠해줍니다.
해당 파일에서 크게 의미있는 부분은 아니지만 저는 vba 내부에서 연월일을 다뤄보고 싶어서 추가했습니다.

2) 해당 월로 이동하는 곳입니다. E1셀에 1~12까지의 숫자를 입력한 뒤, 월 이동 버튼을 누르면 우측 월단위 셀로 이동하는 기능을 구현했습니다. 월에 해당하지 않는 숫자를 입력할 경우 데이터 유효성에 걸립니다.

3) 좌측에 새롭게 추가한 공정 일정을 우측 차트에 반영하는 곳입니다. 클릭시 가장 마지막 공정의 월을 찾아 해당 월로 스크롤합니다.

4) 기본적으로 셀에 음영이 들어간 곳을 제외하면 입력이 불가능하게 구현했습니다. 이를 엑셀에서는 '시트 보호'라고 하는데, 뒷 부분에서 다시 설명하겠습니다.

5) 일정을 가시화한 막대그래프입니다. 파란색은 기존 일정, 붉은색은 일정대비 진도율입니다. 3)의 새로고침을 누르면 차트가 가장 마지막 행에 있는 공정의 월을 찾아 해당 월로 스크롤합니다.



2. 내 엑셀에 무슨 지거리를 했길래 입력이 안되는데요

2

1) 시트 보호 기능을 걸었습니다. 
아무것도 건드리지 않은 엑셀은 [시트보호가 꺼져있어서] 셀 서식-보호 탭에서 잠금 기능을 활성화해도 모든 기능에 접근권한이 있기 때문에,
시트 보호 기능을 활성화 한 뒤 잠금 기능을 활용할 수 있습니다.
여기서 어줍잖게 제가 설명해봐야 다른 곳에서 잘 설명해놨으니 저는 기본적인 용례만 간단히 소개한 뒤, 자세한 내용은 검색해서 보시면 좋을 것 같습니다.


2) K열과 L열 사이에 틀고정 기능을 활성화했습니다.
틀 고정 기능은 현재 활성화한 셀 기준 좌상단 화면을 고정하여 스크롤되지 않게 하는 기능입니다. 공정관리 시트는 공정 일정과 가시화된 데이터를 비교해가면서 봐야 효율이 오르니 L열부터 이동하게 만들었습니다.

L, M, N열은 우측 차트에 쓸 값을 참조해둔 열입니다. 관리할 때 이런 데이터는 굳이 볼 필요가 없으니 접어두는 편이 깔끔하겠지요. 스포를 하자면 이 숨기기 기능때문에 코딩하면서 개고생을 한 경험이 있습니다. 이 이야기는 나중에 다시 말씀드리도록 하겠습니다.



3. 입력 양식은 어떻게 일정하게 만들어?

3

우클릭 - 셀 서식을 클릭하면 이렇게 뜹니다.

저처럼 굳이 사용자 지정 탭에서 형식을 고정하지 않더라도 다른 형식을 이용할 수 있겠습니다.
사용자 지정에 있는 여러가지 요상한 문자들이 궁금하다면 [엑셀 와일드카드 문자]로 검색하면 됩니다.

여기서도 월에 데이터 유효성을 걸었던 것처럼 입력 형식을 제한할 수 있습니다.

* 데이터 유효성 검사는 보통 여러명이 돌려가며 쓰는데 입력 패턴이 다양하면 후처리가 매우 곤란해지는 파일]에 사용하면 매우 유용합니다. 



4. 틀고정과 숨기기

4
mybpstation station finder




이렇게 공정관리표에 적용한 기능들을 간단하게 둘러보았습니다.

다음 편부터 본격적으로 vba 코드 리뷰를 해보겠습니다.




* 지난번 글에서 파이썬 이야기가 잠깐 나와 그 이야기를 해보겠습니다.

1. vba보다 파이썬이 쉽나요
- 저도 지금 파이썬을 같이 공부하고 있습니다. 둘 다 극에 달한 입장이 아니다보니 섣부르게 평가하기 어렵다라는 점은 잘 알고 있지만, 감히 코더의 입장이 아닌 단순 업무활용을 위한 사용자의 입장에서만 이야기해보겠습니다.

- 언어 자체로는 저 역시 파이썬이 더 쉽다고 생각합니다. 변수 선언, 직관성, 배열array에 대한 접근성은 훨씬 편하더군요. 특히 딕셔너리형은 배열에 대한 깊은 이해가 없어도 쓸 수 있다는 게 참 매력적이었습니다. 풍부한 레퍼런스 및 입문서도 장점이었구요.

- 그러나 vba는...
1. [내가 코딩의 키읔도 몰라도 마우스로 코딩이 가능하다]는 점이 굉장히 매력적입니다.

매크로 기능을 이용하면 1) 일단 컴퓨터가 짜주는 코드를 보며 역공학을 할 수도 있고, 2) 복잡한 내부 신택스를 다 알 필요 없이 내가 구현하고자 하는 코드뭉치를 따낼 수 있습니다.

물론 손코딩에 비하면 매크로는 굉장히 비효율적이고 느리긴 하지만, 내가 직접 하는 거 보다는 빠르고 편하지요. 


2. 엑셀과의 연동성도 매우 높다보니, [엑셀의 특정 셀들을 vba의 변수 취급해서 꾸역꾸역 기능 구현]을 해낼 수 있다는 점 역시 매력적이라 생각합니다. 변수 선언과 활용에 익숙해지면 빛이 바라는 장점이지만, 초심자들에게 이만큼 강력한 기능을 보여주는 언어는 없다고 생각하구요.


- 이 이야기는 매크로로 구현이 가능한 부분까지에 한정합니다. 예를 들어 매개변수와 함수, 배열, 개체변수 이런 것들은... 좀..

* 파워포인트가 엑셀에 비해 vba나 매크로 관련 언급이 없는 게 바로 개체변수 때문이라고 생각합니다. 얘들은 매크로로 컴퓨터가 코드를 짜주지 않거든요. 그러니 손코딩을 해야하는데 그럴거면 파이썬을 배우는 게 빠른걸요.


- 따라서, 정리해보면...

매크로 -> 셀 참조 방법 익혀서 매크로 일부 수정 -> if나 select case같은 논리문 익혀 조건 지정 -> for / for each / do.. loop 같은 반복문 익혀 필요한 부분까지 실행하게 구현

이 단계까지는 vba쪽 접근성이 훨씬 좋다고 생각합니다. 이 뒤부터는 뭐... 필요하면 그때그때 배워나가는거죠.



2. 왜 자꾸 영어로 된 사이트만 말하세요
- 제가 사이트 고르는 기준은 두가지입니다. 1) 영문일 것, 2) 텍스트일 것. 왜냐구요? 그래야 월급도둑질을 하기가 좋아서요. 엑셀 관련 스크린샷이 떠있다면 더더욱 자신감이 생깁니다.

통합규정 1.3 이용안내 인용

"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.
법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
홍승식
19/08/01 23:43
수정 아이콘
선생님 교재용 엑셀파일을 첨부로 올려주실 순 없으신가요? (굽신굽신)
19/08/01 23:43
수정 아이콘
최상단부 링크 0번 글에 있습니다
홍승식
19/08/01 23:44
수정 아이콘
감사. 압도적 감사. (꾸벅~)
19/08/02 08:18
수정 아이콘
(수정됨) 실제 작업은 DB에서 이뤄지는 데이터를 화면에 보여주는 일을 프로세스화 하고 개발중인 미생1인데, 엑셀로 할때 더 편한 경우들이 많습니다.
VBA만 잘하면 뭔가 될거 같은데 막상 그 시작점에서 그걸 못하다보니 매번 그냥 몇개 함수로 이거저거 하고 끝나게 되는게 너무 아쉬운 그런게 있죠..

잘 읽어보고 참고해서 공부를 해볼까 합니다. 감사합니다.
비상하는로그
19/08/02 10:10
수정 아이콘
와 감사합니다.
마침 공부 해야하나 찾아보고 있었는데 감사합니다
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회 추천
82621 [일반] 모니터 3대 때문에 파멸한 어떤 법관의 이야기 [16] metaljet10707 19/09/07 10707 5
82620 [정치] 뭐 아들녀석이 또? '국회의원 장제원 아들 래퍼 노엘 음주운전' [151] 차오루16692 19/09/07 16692 4
82615 [정치] 어떻게 행동하는 검찰이 정치검찰입니까? [184] 행복a11745 19/09/07 11745 42
82613 [정치] 비건 미국 대북특별대표, 북미 협상 실패시 한일 핵무장론 거론 [41] 홍승식8021 19/09/07 8021 2
82612 [정치] 검찰이란 조직과 검찰개혁 [237] 음냐리12489 19/09/07 12489 23
82610 [정치] 윤석열이 과연 어떤인간일까요? [288] 펠릭스30세(무직)27130 19/09/07 27130 26
82609 [일반] [10] 이제 추석에는 좀 놀아야지 [4] 나와 같다면6099 19/09/07 6099 4
82604 [정치] 의혹만 있지 불법은 아니니 괜찮다? [292] 안경15325 19/09/06 15325 58
82595 [정치] 조국을 쉴드치거나 두둔하는 사람은 없습니다. [262] 안경19586 19/09/06 19586 76
82593 [일반] [10] 여러 나라의 추석 [15] 이치죠 호타루8353 19/09/05 8353 13
82592 [정치] 14년 전의 데쟈뷰 [30] StayAway8841 19/09/05 8841 18
82590 [정치] 靑 "檢수사, 내란음모 수준…조국이 장관으로 오는게 두려운 것" [318] 사악군23666 19/09/05 23666 54
82588 [일반] 우리는 왜 안전한 먹거리를 먹을 수 없는가 [28] 7971 19/09/05 7971 40
82584 [정치] 민주당 공식 트위터 이거 제정신인가요?(동양대 총장 관련) [412] 차오루24701 19/09/05 24701 94
82564 [일반] 늦었지만 엑시트를 보고 왔습니다. [20] 콩사탕6824 19/09/04 6824 5
82562 [정치] 투표로 세상을 바꿀 수는 없었습니다. [136] 로빈팍10001 19/09/04 10001 55
82561 [정치] 그분보다 어용지식인,언론인들이 더 신물납니다 [35] Gloomy9469 19/09/04 9469 23
82555 [정치] 이게 다 자한당 탓이다 [69] 피정8617 19/09/04 8617 15
82549 [정치] 조국 후보자에 대한 내 심경의 변화를 만든 글 두가지 [98] 곰주12786 19/09/04 12786 34
82545 [정치] 헌재 “시장이 행정구 구청장 임명, 지방자치제 합헌” [27] 군디츠마라9412 19/09/03 9412 1
82544 [일반] 제13호 태풍 링링이 북상중입니다. [38] 아유10923 19/09/03 10923 2
82543 [일반] '손빈병법'에 대해 [9] 성상우6874 19/09/03 6874 9
82540 [일반] 이런 느낌으로 글을 쓰고 있는데 괜찮을까요? [16] 태양연어6623 19/09/03 6623 0
목록 이전 다음
댓글

+ : 최근 1시간내에 달린 댓글
+ : 최근 2시간내에 달린 댓글
맨 위로