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

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

반갑습니다,아별님

 

진행바 응용을 하려고 하니 잘 안되어 질문 드립니다

 

아별님께서 답변주신 진행바 파일로 응용

 

1.진행바가 진행되는 동안 다른 명령을 실행 하려고 합니다

2.다른 메뉴가 실행되는 동안에 진행바가 표시 되게

 

유첨파일 참조해 주십시요


댓글 '3'

profile

[레벨:30]아별

2013.02.04 01:00:32
*.130.73.75

맑은이슬님.. 반갑습니다.

다른분에게 했던 답변을 참고하셨군요..

훈늉한 자세입니다. ^^)b

 

답변 하나 하나에 정성한 다한 보람이 있네요.. ^_^;;

 

첨부파일을 참고하시기 바랍니다.

다운받기 : abyul.com_progressBar_20130130-3.xlsm

 

대부분 작업이 오래 걸리는 작업은 순환문이기때문에..

For문이나 While문의 변수를 사용해서 진행바를 표시하면 될 것 같습니다.

그 외의 작업에는 가중치를 줘서 중간 중간에 한번씩 점프를 시켜야할 것 같네요..

이 프로세스 끝났으면 10%쯤 되겠다해서.. 10%로 점프를.. @_@;;

근데.. 순환문이 아닌데 시간이 오래 걸린다는 것은.. 뭔가 코딩에 문제가 있어보이네요.. @_@;;

그리고.. 대분분의 작업에는 작업진행바가 필요없습니다. 순식간에 끝나버려서요.. @_@;;

 

Application.OnTime 등을 이용해서 예측된 시간에서 동작시키는 것은 오히려 더 신뢰도가 떨어질 것 같습니다.

컴퓨터 사양에 따라 처리 속도는 천차만별이기때문이죠..

 

 

'### 이하 코드~~~


'### 여러 프로세스로 구성된 작업 진행바 만들기
'### Created by http://abyul.com/
'### initial date : 2013.02.04 am 00:28
Dim frm As ufrmProgressBar
Dim maxCount As Long
Dim fullWidth As Long
Dim lngProgress As Long

Sub abProgressBarShow()
    Set frm = New ufrmProgressBar
    frm.Label1.BackColor = 125
    frm.Label1.Caption = ""
    maxCount = 3000 + ActiveWorkbook.Styles.Count + 200 + 2000
    lngProgress = 0
    fullWidth = frm.TextBox1.Width
    frm.Show
End Sub

Sub abProgressBarMain()
    Call dummy1
    Call dummy2
    Call Macro1
    Call dummy3
    frm.Label1.Width = fullWidth
    frm.Label2.Caption = "작업 진행율 : " & Format(1, "0.0%")
    Set frm = Nothing
End Sub


Sub dummy1()
    Dim sht As Worksheet: Set sht = Sheets.Add
    Dim rng As Range: Set rng = sht.Range("A1")
    For i = 1 To 3000
        DoEvents
        rng.Offset(i).Value2 = i
        lngProgress = lngProgress + 1
        frm.Label1.Width = fullWidth * (lngProgress / maxCount)
        frm.Label2.Caption = "작업 진행율 : " & Format(lngProgress / maxCount, "0.0%")
        If i = 1000 Then
            Debug.Print i
        End If
    Next i
End Sub

Sub dummy2()
    Dim sht As Worksheet: Set sht = Sheets.Add
    Dim rng As Range: Set rng = sht.Range("A1")
    For i = 1 To sht.Parent.Styles.Count
        DoEvents
        rng.Offset(i).Value2 = sht.Parent.Styles(i).Name
        lngProgress = lngProgress + 1
        frm.Label1.Width = fullWidth * (lngProgress / maxCount)
        frm.Label2.Caption = "작업 진행율 : " & Format(lngProgress / maxCount, "0.0%")
    Next i
End Sub

Sub dummy3()
    Dim sht As Worksheet: Set sht = Sheets.Add
    Dim rng As Range: Set rng = sht.Range("A1")
    For i = 1 To 2000
        DoEvents
        rng.Offset(i).Value2 = i
        lngProgress = lngProgress + 1
        frm.Label1.Width = fullWidth * (lngProgress / maxCount)
        frm.Label2.Caption = "작업 진행율 : " & Format(lngProgress / maxCount, "0.0%")
    Next i
End Sub


Sub Macro1()
    Sheets.Add
    Range("B4:J33").Select
    Selection.FormulaR1C1 = "=RAND()*100"
    Selection.Borders(xlDiagonalDown).LineStyle = xlNone
    Selection.Borders(xlDiagonalUp).LineStyle = xlNone
   
    With Selection.Borders(xlEdgeLeft)
        .LineStyle = xlContinuous
        .ColorIndex = 0
        .TintAndShade = 0
        .Weight = xlThin
    End With

'### 코드 생략 ~~~


        lngProgress = lngProgress + 100
        frm.Label1.Width = fullWidth * (lngProgress / maxCount)
        frm.Label2.Caption = "작업 진행율 : " & Format(lngProgress / maxCount, "0.0%")
   

'### 코드 생략 ~~~

 

 

첨부

[레벨:5]맑은이슬

2013.02.04 10:36:09
*.247.145.54

감사 합니다,덕분에 많은 공부 하고 갑니다

profile

[레벨:30]아별

2013.02.04 12:09:07
*.104.126.21

도움이 되셨다니 다행입니다.

MaxCount를 설정하는게 관건이겠네요..

적절한 값으로 설정하는게 중요합니다.

즐거운 하루 되세요.. ^^

문서 첨부 제한 : 0Byte/ 2.00MB
파일 제한 크기 : 2.00MB (허용 확장자 : *.*)
List of Articles
번호 제목 글쓴이 날짜 조회 수sort
공지 공지 [공지] 아별닷컴의 엑셀 질문방 폐쇄합니다. 카페 질문방 이용하세요.. imagefile [레벨:30]아별 2015-04-23 49391
93 VBA 병합효과 file [3] [레벨:4]고수가되고파 2012-11-22 6150
92 VBA 하이퍼링크셀 선택시 셀값을 오토필터 값으로 연결 file [레벨:1]speena 2015-03-11 6055
91 VBA 특정색 행 삭제 메크로 배워보고 싶습니다~ imagefile [2] [레벨:1]굿한넘 2015-01-12 5666
90 VBA 엑셀 랜덤돌리기 질문입니다 file [2] [레벨:4]신강현 2012-12-07 5378
89 VBA 특정값이 변경될 경우 매크로실행 또는 0이 아닐경우 실행 [2] [레벨:3]jmsynn 2014-10-24 5273
88 VBA win7 64bit / 64bit 엑셀 / 32bit DLL의 사용법이 궁금합니다. file [레벨:1]컴바치 2013-01-04 5147
87 VBA 파일&폴더 ExecuteExcel4Macro로 다른 파일 열지않고 셀 데이터 가져오기 시 실패 file [레벨:1]소주보이 2014-02-28 5060
86 VBA 2개의 시트를 비교하여 다른 부분을 찾아내는 프로시저 질문입니다! file [3] [레벨:6]파이스 2011-11-24 4993
85 VBA 엑셀 내용에서 영어만 모두 제거할 수 있을까요?? [1] [레벨:1]초보배움 2015-02-20 4985
84 VBA 엑셀 vba 함수 질문드릴게요. [4] [레벨:4]신강현 2013-03-04 4970
83 VBA 외부 어플리케이션 실행 & 유저폼 일괄 닫기 & 리본 메뉴 사용자 추가 탭 숨기거나 보이게 하는 방법 [7] [레벨:3]엑셀대단해 2012-02-08 4825
82 VBA 수식이 입력된 셀은 자동으로 색상이 들어가게 하는 방법 [5] [레벨:4]부루끄 2011-07-15 4779
81 VBA 엑셀 메모의 배경으로 삽입한 이미지 추출하기 file [레벨:2]이런젬젬 2015-01-06 4701
80 VBA [긴급] Range 범위 "A2:A10" -> 를 변수로 받게 하는 방법.. file [3] [레벨:1]마리너 2012-07-05 4523
79 VBA vba로 서식정렬 [4] [레벨:2]정용규 2015-01-03 4483
78 VBA VBA 서적 추천좀 해주세요 [1] [레벨:1]김학래 2013-04-01 4458
77 VBA 아별님! 엑셀 질문입니다. _ 고급필터를 활용한 데이터 분리 작업(각 시트로 분리) file [3] [레벨:2]북곰 2013-04-06 4417
» VBA 진행바 응용(다른 메뉴 실행중) _ 작업 진행바 Progress bar file [3] [레벨:5]맑은이슬 2013-02-02 4386
75 VBA 현재 선택 된 셀을 기준으로 같은방식의 연산결과 값을 산출하는 법 file [1] [레벨:4]부루끄 2011-07-26 4335
74 VBA vba 방향키 질문입니다 [4] [레벨:4]기능인 2013-07-11 4330