VBA / 웹브라우저 연동 작업 시 오류 및 기능 추가 문의 드립니다.
안녕하세요. 오빠두엑셀에서 도움을 많이 받고 있는 초보 VBA 유저 입니다.
다음과 같이 VBA를 활용하여 인터넷 브라우저(익스플로러) 연동하여 데이터를 검색 하고 결과값을 입력해주는 매크로를
구현하고 있습니다.
*회사 보안프로그램으로 이미지 업로드가 되지 않아 표로 붙여넣었고, 파일로 첨부 합니다..!
구분 | B/L 번호 | 진행상태 | 통관진행상태 | (수동)진행상태 | (수동)통관진행상태 |
1 | NAM5678336 | 입항적하목록 정정 승인 | 수입신고전 | 입항적하목록 정정 승인 | 수입신고전 |
2 | ONEYRICCHM666300 | 검사/검역 식품의약품(합격) | 수입신고전 | 검사/검역 식품의약품(합격) | 수입신고전 |
3 | OOLU2704519960 | 검사/검역 식품의약품(합격) | 수입신고전 | 검사/검역 식품의약품(합격) | 수입신고전 |
4 | HDMUDALA76712000 | 검사/검역 동물검역(합격) | 수입신고전 | 검사/검역 동물검역(합격) | 수입신고전 |
5 | MEDUU6859588 | 검사/검역 동물검역(합격) | 수입신고전 | 검색결과 없음 | 검색결과 없음 |
6 | MEDUU6316613 | 검사/검역 동물검역(합격) | 수입신고전 | 검사/검역 동물검역(합격) | 수입신고전 |
7 | 검사/검역 동물검역(합격) | 수입신고전 | |||
8 | 검사/검역 동물검역(합격) | 수입신고전 | |||
9 | ONEYRICCJR657800 | 검사/검역 동물검역(합격) | 수입신고전 | 검색결과 없음 | 검색결과 없음 |
10 | MEDUD6353061 | 검사/검역 동물검역(합격) | 수입신고전 | 검색결과 없음 | 검색결과 없음 |
11 | HDMUDALA68372000 | 검사/검역 동물검역(합격) | 수입신고전 | 검색결과 없음 | 검색결과 없음 |
12 | NAM5700516 | 검사/검역 동물검역(합격) | 수입신고전 | 검사/검역 동물검역(합격) | 수입신고전 |
B/L 번호로 검색하여 진행상태와 통관진행상태에 결과값을 넣어 주는 방식으로 익스플로러와의 연동은 완료 하였으나
몇가지 오류가 발생하여 질문을 드려봅니다.
진행상태, 통관진행상태 는 매크로를 실행시켜서 나온 값이며
(수동)진행상태, (수동)통관진행상태 는 매크로를 사용하지 않고 수동으로 검색해서 붙여넣은 값 입니다.(맞는 값)
1. 첫번째 B/L 번호 칸(C3)이 빈칸 이거나 검색 결과가 나오지 않을 때(입항 전) 오류가 나지 않고 넘어갈 수 있는 방법
2. B/L번호 열(C열)이 빈칸일 때 검색 프로세스를 진행하지 않고 빈칸으로 두는 방법(구분 7번과 8번의 경우, 현재는 바로 위 셀의 값을 따라오게 됨)
3. 5번과 같이 실제로는 검색결과없음(입항 전)일 때에는 뒤의 H B/L로 한번 더 검색하고 그래도 빈칸일 시 빈칸으로 두고 다음 작업으로 넘어가는 방법(현재는 구분 5, 9, 10, 11번과 같이 M B/L 검색 결과가 없을 시 바로 위 셀의 값을 따라오게 됨. 참고로 H B/L 검색 창 주소 id : MYC0405101Q_hblNoTab1)
- 아래부터는 작성한 코드 입니다.(작업중인 파일 첨부도 하였습니다.)
Sub 수입진행상태_확인()
Dim ie As InternetExplorer
Dim URL As String
Set ie = CreateObject("internetExplorer.Application")
ie.Navigate "https://unipass.customs.go.kr/csp/index.do?tgMenuId=MYC_MNU_00000450"
ie.Visible = True
ie.Width = 1500
ie.Height = 800
Do While (ie.ReadyState <> READYSTATE_COMPLETE Or ie.Busy = True)
DoEvents
Loop
For i = 3 To Cells(Rows.Count, 3).End(3).Row
'' 빈 셀은 작업 하지 않는 것에 대해서 시도 하였으나 빈 셀에 대해서만 작업하고 첫 행의 값으로만 복사 됨
' If IsEmpty(Cells(i, 3)) Then
' Cells(i, 4).Value = ""
' Cells(i, 5).Value = ""
'
' End If
Application.Wait (Now + TimeValue("00:00:08"))
ie.Document.getElementByid("MYC0405101Q_mblNoTab1").Value = Range("C" & i)
ie.Document.getElementByid("MYC0405101Q_searchBtnTab1").Click
Application.Wait (Now + TimeValue("00:00:08"))
Range("D" & i) = ie.Document.getElementByid("MYC0405102Q_prgsStts").innerHTML
Range("E" & i) = ie.Document.getElementByid("MYC0405102Q_csclPrgsStts").innerHTML
Next i
ie.Quit
Set ie = Nothing
End Sub
↓아래 이미치처럼 검색 시 진행상태 , 통관진행상태 두가지 값을 가져오고 있습니다.
번호 | 카테고리 | 제목 | 작성자 | 작성일 | 추천 | 조회 |
[📚진짜쓰는 실무엑셀] IT/오피스 '1위' 베스트셀러! 엑셀 공부, 이 교재로 마스터하세요! (315)
![]() ![]() |
![]() ![]() |
2022.02.03 | 575 | 609619 | ||
공지사항 | 문서서식 |
⭐ [더 나은 커뮤니티 문화를 위한 Q&A 글 작성 규칙] ⭐
(197)
오빠두엑셀
|
2021.10.28
|
추천 310
|
조회 35541
|
![]() ![]() |
2021.10.28 | 310 | 35541 |
78582 | 함수/공식 |
New 조건 함수 의 관한 문의
![]() ![]() ![]() |
![]() |
15:46 | - | 26 |
78580 |
New 날짜와 시간 분할 방법 알려 주세요
![]() ![]() ![]() |
![]() |
15:14 | - | 22 | |
78575 | VBA |
New 엑셀 재고관리 프로그램 문의드립니다..
![]() ![]() |
![]() |
04:23 | - | 64 |
78570 | 대시보드 |
New 대시보드에 표 형식으로 표현도 가능한가요?
![]() ![]() |
![]() |
2025.05.12 | - | 65 |
78569 | 함수/공식 |
New 서로 다른 양식의 견적서 엑셀 파일 한곳에 정리 하기
(5)
![]() |
![]() |
2025.05.12 | - | 84 |
78565 | 함수/공식 |
New 검색보고서 만들기 질문드립니다.
![]() ![]() |
![]() |
2025.05.12 | - | 82 |
78563 | VBA |
New VBA 수정 부탁드립니다. ㅠ
(3)
![]() |
![]() |
2025.05.12 | - | 71 |
78560 | 함수/공식 |
New 어떻게 내용을 가져올수 있을지 고수님들의 해결방법들을 공유 받고 싶습니다!!....
![]() ![]() ![]() |
![]() |
2025.05.12 | - | 43 |
78559 | 파워쿼리/피벗 |
New 엑셀 자동화 질문 입니다...
![]() ![]() |
![]() |
2025.05.12 | - | 64 |
78555 | 함수/공식 |
New 시트에서 원하는 열의 자료만 가져오고싶은데 아무리 해도 수식오류가 나서 도움을 구하고자 합니다
![]() ![]() |
![]() |
2025.05.12 | - | 41 |
78554 | 함수/공식 |
New 변동하는 절대참조값 적용
(6)
답변완료
![]() |
![]() |
2025.05.12 | - | 63 |
78553 | 대시보드 |
New 대시보드_슬라이서 자동으로 눌러지게 하는방법
![]() ![]() |
![]() |
2025.05.12 | - | 46 |
78548 | 대시보드 |
New 어떤 엑셀을 적용해야하는 지 문의드립니다!
(1)
![]() |
![]() |
2025.05.11 | - | 63 |
78546 | 함수/공식 |
New 월별 매출액 자동입력할 수 있는 방법 또는 함수 궁금합니다!
![]() ![]() |
![]() |
2025.05.11 | - | 84 |
78544 | 함수/공식 |
New 중복값 제거 함수에 관하여
![]() ![]() ![]() |
![]() |
2025.05.11 | - | 72 |
78543 | 함수/공식 |
New 데이터 추출 및 정렬관련 초보질문
![]() ![]() ![]() |
![]() |
2025.05.11 | - | 66 |
78540 | 함수/공식 |
New 오빠두LIVE 219회 - 엑셀 '셀 병합' 자동화 보고서 만들기 오빠두엑셀님의 방법이 궁금합니다.
![]() ![]() |
![]() |
2025.05.10 | - | 56 |
78536 | 함수/공식 |
New 월별로 금액적용후 최종월에 차액을 가감 함수가 필요해요
![]() ![]() |
![]() |
2025.05.10 | - | 61 |
78535 | 기능/도구 |
New 엑셀로 25x25 인쇄가 가능한가요?
(1)
![]() |
![]() |
2025.05.10 | - | 47 |
78534 | 파워쿼리/피벗 |
New 쿼리에 함수 적용한 열 추가 시 24:00:00 활용한 계산 함수 필요할 때.
![]() ![]() |
![]() |
2025.05.10 | - | 60 |
78531 | 차트/그래프 |
New 엑셀 차트 데이터테이블
![]() ![]() ![]() |
![]() |
2025.05.09 | - | 70 |
78530 | 구글시트 |
New 구글 스프레드시트 함수 관련 질문입니다.
![]() ![]() ![]() |
![]() |
2025.05.09 | - | 60 |
78528 | 구글시트 |
New 구글 스프레드시트를 외부 엑셀 파일과 연동하는 방법이 궁금합니다.
(3)
![]() |
![]() |
2025.05.09 | - | 64 |
78525 | 문서서식 |
New 업무가 진행이 안 될 정도로, 해당 파일이 느립니다!
![]() ![]() |
![]() |
2025.05.09 | - | 89 |
78520 | 기능/도구 |
New 하이퍼링크 명칭 해제
(1)
![]() |
![]() |
2025.05.09 | - | 49 |
78518 | 피벗테이블 |
New 피벗테이블 관련 화살표 질문
![]() ![]() |
![]() |
2025.05.09 | - | 47 |
78516 | 함수/공식 |
New 호봉산정 엑셀 문의드립니다.
![]() ![]() ![]() |
![]() |
2025.05.08 | - | 55 |
78515 | 함수/공식 |
New 엑셀 질문 드립니다.ㅠ.ㅠ
![]() ![]() |
![]() |
2025.05.08 | - | 50 |
78511 | 함수/공식 |
New 입사일자로 부터 매년 알림
(2)
![]() |
![]() |
2025.05.08 | - | 66 |
78510 | 문서서식 |
New 조건부 서식 적용 문의
![]() ![]() ![]() |
![]() |
2025.05.08 | - | 97 |
@맹추 님 조회가 실패하거나 했을 때 어떻게 되는지 확인하시고,
M B/L 라디오 버튼은 선택하지 않아도 문제 없을까요?
@원조백수 님 조회가 실패 했을때는 유니패스 사이트 검색 결과에 '조회결과가 존재하지 않습니다.' 라고 나옵니다.
익스플로러 개발 도구에서의 해당 값의 좌표를 조회해보니 아래와 같았습니다.
<td colspan="8">조회결과가 존재하지 않습니다.</td>
따라서 이런 형태가 되어야 할 것으로 생각 했습니다.
M B/L 검색 결과 <td colspan="8">조회결과가 존재하지 않습니다.</td> 일때 MYC0405101Q_hblNoTab1(H B/L 검색 창) 에 검색 수행. 결과 값이 있다면 값을 가져오며, 동일하게 <td colspan="8">조회결과가 존재하지 않습니다.</td> 인 경우에는 ""(빈칸)
라디오 버튼 관련해서는 제가 설정한 사이트 주소인
https://unipass.customs.go.kr/csp/index.do?tgMenuId=MYC_MNU_00000450
에서는 디폴트 값으로 M/BL - H/BL 에 선택이 되어 있어 선택은 하지 않아도 될 것으로 보입니다.