1. FAQ
  2. 엑셀(Excel)
  3. AfterEffects
  4. Premiere
  5. Photoshop
  6. ETC

이 게시판은 아별닷컴 회원만 질문을 올릴 수 있습니다. 회원에게 주어지는 특권인셈이지요. 회원이 아닌 분들은 열람만 가능합니다.

데이터가 있을 경우 수식 넣기??

VBA 조회 수 2985 추천 수 0 2012.03.20 10:56:31

원래는 셀에다가

 

=IF(AM3<0,"가치하락",IF(AND(AD3<0,AF3<>AG3),향상유형1,IF(AD3>0,향상유형2,IF(AND(AD3=0,AF3<AG3),향상유형3,IF(AND(AD3<0,AF3=AG3),향상유형4,"")))))

 

이런 수식을 넣어서 사용했는데요, 이걸 VBA로 교체할 수 있을까요??

 

참조되는 3행부터 데이터가 무한대로 갈 수 있기때문에...데이터 행이 늘어날때마다 드래그하면 실수를 많이 하게 되어서 문의해봅니다.

 

감사합니다.


댓글 '4'

profile

[레벨:30]아별

2012.03.20 11:29:44
*.104.126.21

엑셀 파일을 올려주세요..

일단 IF문이 너무 복잡해보이네요.. VLOOKUP등으로 대체할 수 있을지 봐야할 것 같구요..

음.. VBA로 대체하는게 좋은 방법은 아닌 것 같습니다.

데이터 행이 늘어날때마다 드래그해서 자동채우기 하지 마시고.. 범위를 선택하고 Ctrl+D를 눌러서 자동채우기 하세요..

맨 위의 셀을 아래쪽으로 채워줍니다.

 

엑셀 2007이상 버전이시라면..

표를 사용하시면 데이터가 늘어날때마다 수식이 자동으로 채워집니다.

 

결국은 엑셀 파일을 올려주셔야 딱 맞는 답변이 가능하겠네요..

 

감사합니다.

[레벨:1]아우릭

2012.03.20 13:10:04
*.98.14.90

A열에 데이터가 있을 경우 수식을 적용합니다.

BV 열은

=IF(AM3<0,"가치하락",IF(AND(AD3<0,AF3<>AG3),향상유형1,IF(AD3>0,향상유형2,IF(AND(AD3=0,AF3<AG3),향상유형3,IF(AND(AD3<0,AF3=AG3),향상유형4,"")))))

으로 AM, AD,AF,AG 세가지 열의 수치를 비교해서 텍스트를 입력합니다.

BW 열은

=IF(AD3>0,"증가",IF(AD3=0,"동일","절감"))

으로 AD열의 수치가 양수 음수 0 를 판단하여 텍스트를 입력합니다.

이 과정을 셀에 수식을 안남기고 vba로만 처리하고십습니다.

파일은 댓글에 첨부하였습니다.

 

감사합니다.

첨부
profile

[레벨:30]아별

2012.03.20 14:16:49
*.104.126.21

아우릭님..

VBA로 수식을 입력하고.. 수식을 값으로 만드는 방법을 사용했습니다.

굳이.. 각 행별로 VBA로 평가하고 값을 입력할 필요는 없을 것 같네요..


첨부파일을 다운 받으신 다음..

화면 오른쪽에 있는 "유형 평가하기" 버튼을 클릭하시면 유형을 평가해줍니다. (물론 값으로만 남습니다.)

(이름 정의가 외부 파일로 되어 있어서.. MasterCode란 시트를 만들고 이름 정의를 다시 했습니다.)

다운 받기 : 2012.3.20.VBAcla.01-2.xlsm


도움이 되셨기를..



첨부파일에 사용된 VBA 코드입니다.

=> 기준을 A3로 잡고.. A열에 데이터가 무한대로 증가해도 대응할 수 있도록 코드를 작성하였습니다.

     핵심은.. 영역을 설정하는 Range(rngRef, rngRef.End(xlDown)).Offset(0, 73) 코드입니다.

      기준셀부터 기준셀의 맨아래셀까지의 범위를 오른쪽으로 73번 이동시킨 영역.. 

      첨부파일로 본다면.. BV3:BV250입니다. A열의 데이터가 늘어나면 BV의 대상 영역도 같이 늘어납니다.

 

Option Explicit


Sub evaluateType()


    Dim rngRef As Range

    Set rngRef = Range("A3")

    

    With Range(rngRef, rngRef.End(xlDown)).Offset(0, 73)

        .FormulaR1C1 = _

            "=IF(RC[-35]<0,""가치하락"",IF(AND(RC[-44]<0,RC[-42]<>RC[-41]),향상유형1,IF(RC[-44]>0,향상유형2,IF(AND(RC[-44]=0,RC[-42]<RC[-41]),향상유형3,IF(AND(RC[-44]<0,RC[-42]=RC[-41]),향상유형4,"""")))))"

        .Value = .Value

    End With

    

    With Range(rngRef, rngRef.End(xlDown)).Offset(0, 74)

        .FormulaR1C1 = _

            "=IF(RC[-45]>0,""증가"",IF(RC[-45]=0,""동일"",""절감""))"

        .Value = .Value

    End With


End Sub



첨부

[레벨:1]아우릭

2012.03.20 14:49:21
*.98.14.90

감사합니다, 정말 큰 도움이 되었습니다.

 

Formula 로 VBA에서 직접 계산해서 넣는다는것이 되는군요~

문서 첨부 제한 : 0Byte/ 2.00MB
파일 제한 크기 : 2.00MB (허용 확장자 : *.*)
List of Articles
번호 제목 글쓴이 날짜 조회 수sort
공지 공지 [공지] 아별닷컴의 엑셀 질문방 폐쇄합니다. 카페 질문방 이용하세요.. imagefile [레벨:30]아별 2015-04-23 48977
602 엑셀일반 활성창 이동 [2] [레벨:3]해바라기1 2011-09-01 3015
601 엑셀일반 하이퍼 링크 [1] [레벨:5]눈물바다 2014-09-26 3017
600 엑셀일반 도움 부탁드려요 ㅜㅜ 정렬 질문입니다. [2] [레벨:1]captainkidd 2013-11-25 3018
599 피벗테이블 Vlookup 에서 혼동이 와 문의드려요~ file [11] [레벨:1]예진 2012-11-11 3020
598 피벗테이블 엑셀 데이터 정리관련 문의~~~ [2] [레벨:2]flash 2011-12-30 3022
597 엑셀일반 엑셀 관련 질문입니다. imagefile [2] [레벨:1]JYK 2013-11-11 3032
596 피벗테이블 Pivot file [11] [레벨:1]예진 2012-11-05 3036
595 엑셀일반 엑셀 이미지 [레벨:3]블루짱이 2023-10-21 3040
594 VLookup 두개이상의 범위조건을 만족하는 값을 구하려면..? file [3] [레벨:2]파란달 2013-05-02 3041
593 매크로 함수를 VBA로 바꾸면 될까요??? (ExecuteExcel4Macro in UDF) file [2] [레벨:1]테스킨 2011-07-12 3043
592 아별툴관련질문 아별 설치후 추가기능 선택시 에러발생 imagefile [레벨:1]aratus 2014-05-09 3045
591 엑셀수식 sumproduct 관련 질문이 있습니다. [2] [레벨:2]광택입니다 2011-10-28 3049
590 일별 구매 현황에서 품목별 최근,최고,최저 단가구하기 file [1] [레벨:1]강상준 2010-11-02 3064
589 VBA 질문있습니다. 아뵬님. ㅠ _ 텍스트 박스 회전시키는 VBA 코드 [1] [레벨:6]ryanoh 2011-11-15 3065
588 엑셀일반 특정열을 밑으로 25칸 내리는 방법이 있나요? file [2] [레벨:0]싸이 2012-10-30 3066
587 VBA 엑셀파일 검색후 불러오기 문의 file [3] [레벨:2]광택입니다 2012-09-19 3068
586 VBA 두번째 질문 file [1] [레벨:2]광택입니다 2011-10-21 3072
585 VLookup 어떻게 수식을 만들어야할지 모르겟어요ㅜㅜ file [3] [레벨:1]영우세령아빠 2013-04-12 3075
584 엑셀일반 최적조합 찾기 질문 입니다.[해찾기][메크로] file [2] [레벨:0]느낌가득 2012-04-03 3076
583 날짜/시간 수식 날짜 함수 관련 문의합니다. file [3] [레벨:3]fmbass98 2013-02-19 3080