소프트웨어 엑셀로 KBS1 KBS2 MBC SBS 등 편성표 가져오기
2022.06.07 05:10
몇가지 추가 또는 수정하였습니다. 이것으로 마무리 할까 합니다.^^ 지상파 편성표 웹크롤링.xlsm
- 오늘 이후 날로 특정 날짜나 요일 입력시 해당 데이터를 하루씩 가져오도록 하였습니다.
- 일주일치 작성하려면 각 시트 추가 후 해당 일자 각각 실행하면 되겠습니다.
- 당연히 요일 지정은 오늘을 포함하여 일주일 치에만 사용할 수 있습니다.
- 날짜와 요일을 시트 이름으로 설정
- 보기 좋게 시간 부분을 두자리로 통일
alt+F8 -> GetTVProgramOn 실행
참고로 코드중 Array(9, 7, 11, 5) 에 채널 번호를 추가/제거하여 쉽게 원하는 채널만 가져 올 수 있습니다.
안녕하세요? 쉬는 날 질문게시판에 올라온 내용을 YouTube 보고 공부하였습니다.
질문; excel 시트로 방송 편성표 가져올 때의 질문 입니다 - https://windowsforum.kr/qna/18100846
YouTube에 알맞은 동영상이 있어서 따라하였습니다. ; https://www.youtube.com/watch?v=h6CUDIyF0fw
- 첨부 엑셀 파일 속성에 링크 기록하였습니다.
- 동영상을 보시면 아시겠지만, Microsoft HTML Object Library와 Microsoft Internet Controls를 참조합니다.
질문의 Daum 홈페이지가 아닌 https://tv.kt.com/ 에서 채널 정보를 가져옵니다.
인터넷익스플로러를 이용합니다. 크롬(셀레니움)을 이용하는 방법도 있는 것 같습니다.
지상파 편성표.xlsm 매크로 포함으로 열어야 합니다.
alt + F8 누르면 매크로 실행 창이 나오고,
GetTVProgram 실행하면,
아래쪽 화면처럼 질문한 양식과 비슷한 데이터를 얻을 수 있습니다. ^^ 포맷은 좀 더 추가하면 될 것 같습니다.
단순한 웹페이지는 가져올때 엑셀-데이터-웹으로 가져올 수 있는데, 요즘 웹페이지는 구조가 복잡하여 쉽지만은 않습니다.
파워쿼리를 좀 더 잘 사용할 수 있으면 가능할지 모르겠습니다만, 표 안에 표 구조를 가지고 있어서 잘 안되더군요.
관심있으신 분은 alt+F11 누르면 코드를 볼 수 있습니다만,
유튜브 내용을 조금 수정한 정도라서 유튜브 동영상을 보시고 포함된 코드를 보시는 것을 추천드립니다.^^
유튜브 동영상에서 코드를 제공하지 않아서 모두 보면서 타이핑하였습니다. 2~3시간 걸린듯 합니다.
- PC 성능에 따라서, 성능이 느려서 에러가 나면 아래 코드중 TimeValue("00:00:01") 부분의 초를 늘려 주면 될 것 같습니다.
- 아래는 유튜브 원본 코드입니다.(수정된 코드는 엑셀 파일안에 있으니 참고하십시오.)
Sub GetTVProgram()
Dim ie As InternetExplorer
Dim strURL As String
Dim nCnt As Integer
Dim i As Integer
Dim strTVName As String
Dim strDate As String
Dim ele As IHTMLElement
Set ie = CreateObject("InternetExplorer.application")
strURL = "https://tv.kt.com/tv/channel/pChInfo.asp"
ie.navigate strURL
ie.Visible = True
Do While (ie.readyState <> READYSTATE_COMPLETE Or ie.Busy = True)
DoEvents
Loop
'1초 추가 대기
Application.Wait (Now + TimeValue("00:00:01"))
nCnt = Range("A60000").End(xlUp).Row
For i = 0 To 10
ie.document.getElementById("linkChannel" & i).Click
'TV명 가져오기
strTVName = ie.document.getElementById("linkChannel" & i).innerText
Application.Wait (Now + TimeValue("00:00:01"))
'날짜 가져오기
strDate = ie.document.getElementsByClassName("day")(0).innerText
'프로그램 및 장르 가져오기
For Each ele In ie.document.getElementsByClassName("program")
If ele.parentElement.parentElement.parentElement.className = "board tb_schedule" Then
Range("A" & nCnt) = strDate
Range("B" & nCnt) = strTVName
Range("C" & nCnt) = ele.innerText '프로그램
Range("D" & nCnt) = ele.nextElementSibling.innerText '장르
nCnt = nCnt + 1
End If
Next ele
Next i
ie.Quit
Set ie = Nothing
End Sub
댓글 [14]
-
슈머슈마 2022.06.07 05:16
와 ~. 이건 뭘로 만드신건가요? -
지후빠 2022.06.07 05:27
안녕하세요? 엑셀 VBA (VBS와 거의 비슷) 입니다. ^^
-
선우아버 2022.06.07 07:22
관심 가져주시고 많은 시간을 할애해 주셨네요. 감사합니다...^^*
덕분에 간단히 편성표를 복사해 올수 있었습니다.
ps. 매주 일주일치의 작업을 해야 하는데...
kt 홈페이지의 주간편성표 페이지로 VBA 수정좀 해주실수 없나요?
시간 나실때 부탁좀 드리겠습니다.
아울러 다시 한번 감사드립니다.
-
지후빠 2022.06.07 20:13
GetTVProgramSunday 매크로를 추가하였습니다. 지상파 편성표 2.xlsm
오늘 기준으로 다음 일요일의 데이터를 가져옵니다. ^^
-
지후빠 2022.06.08 01:31
앗! 매주일주일치... 매주일요일인줄 착각했습니다. 시간 날때 다시 해보겠습니다.ㅠㅠ
-
상발이 2022.06.07 13:58
수고하셨습니다.
-
맨션에살자 2022.06.07 16:53
역쉬 지후빠님!!
쵝오~~
-
cungice 2022.06.07 22:23
수고 많으셨습니다. 감사합니다.
-
가을사랑 2022.06.08 05:55
멋진 아이디어
대단하십니다. -
지후빠 2022.06.08 08:18
댓글과 추천해주신 여러분 감사드립니다.^^
쓰는데 크게 불편하지 않을 것 같아서 이쯤에서 멈출까 합니다.~
-
선우아버 2022.06.08 08:40
지후빠님 매우 매우 감사합니다. *^^*
이로써 기본틀을 구축 할수가 있을것 같습니다.
수고 하셨습니다!!!
감사 합니다!!!
-
와로 2022.06.09 07:21
또 꿀팁 한건(?) 하셨네요 ^ㅡ^
수고하셨습니다~!
-
mso 2022.06.10 15:00
오래전에 링크를 받은 것이라 출처가 생각나진 않지만 지금도 사용하고 있습니다.
자후빠님 외 이런 것도 있다는 정도로 봐주셨으면 합니다.
https://docs.google.com/spreadsheets/d/1D9jF3KVYAZBvYRDMzZ8oEnGwVojanrIW7FQFl4n2TOk/edit#gid=0/
-
지후빠 2022.06.10 21:17
안녕하세요? 어떻게 만들어진 것인지 궁금한데 속을 알 수 없네요.ㅠㅠ 감사합니다.
번호 | 제목 | 글쓴이 | 조회 | 추천 | 등록일 |
---|---|---|---|---|---|
[공지] | 강좌 작성간 참고해주세요 | gooddew | - | - | - |
127 | 소프트웨어| [포토샵] 인물 배경 분리 및 배경 합성 [12] | 무월 | 1541 | 16 | 04-05 |
126 | 소프트웨어| [포토샵] 짝눈 보정 [15] | 무월 | 1577 | 17 | 04-06 |
125 | 소프트웨어| ACDsee 로 이미지파일 빨리 분류하는 법 [1] | ton3d | 1153 | 4 | 04-06 |
124 | 소프트웨어| [포토샵] 도장 투명 이미지 추출 [23] | 무월 | 3011 | 20 | 04-07 |
123 | 소프트웨어| [포토샵] 이미지 패턴 합성 [11] | 무월 | 876 | 9 | 04-09 |
122 | 소프트웨어| [포토샵] 낙관 만들기 [7] | 무월 | 2006 | 11 | 04-09 |
121 | 소프트웨어| [포토샵] 하늘 자동 인식 교체 [8] | 무월 | 1420 | 11 | 04-12 |
120 | 소프트웨어| [포토샵] 배니싱 포인트 텍스트 왜곡 배치 [10] | 무월 | 1129 | 13 | 04-12 |
119 | 소프트웨어| [오토핫키]듀얼모니터에서 커서 점프하기 Version 6 [7] | shot4u | 2180 | 14 | 04-13 |
118 | 소프트웨어| 카멜님의 VHDmanLite 0.04 사용법/0.05추가 [10] | keen | 1496 | 14 | 04-23 |
117 | 소프트웨어| 슬기로운 스포티파이(Spotify) 생활 [4] | 와로 | 1451 | 5 | 05-04 |
116 | 소프트웨어| 비즈니스용 MS Office365 신규 UI적용하기 [2] | 마집사 | 2650 | 6 | 05-27 |
» | 소프트웨어| 엑셀로 KBS1 KBS2 MBC SBS 등 편성표 가져오기 [14] | 지후빠 | 2712 | 14 | 06-07 |
114 | 소프트웨어| NIUBI Partition Editor에 배드(불량) 섹터 검사 기능이 있... [2] | 그루터기 | 1133 | 7 | 06-18 |
113 | 소프트웨어| Symantec Endpoint Protection(SEP) 삭제방법(삭제시 비밀... [3] | 타천사둘리 | 2111 | 6 | 06-29 |
112 | 소프트웨어| 노턴 시큐리티 Ver.22.20.5.40 한글판 탐지 제외 설정 방법 [2] | 타천사둘리 | 1398 | 1 | 07-06 |
111 | 소프트웨어| [실사] AOMEI Backupper PXE 부팅 사용 방법 [10] | 무월 | 1580 | 14 | 07-13 |
110 | 소프트웨어| [실사] WinRE.wim 업데이트 통합 및 XPE 생성 [11] | 무월 | 1620 | 15 | 07-18 |
109 | 소프트웨어| dup2patcher.dll 디컴파일링-1 [6] | sunshine | 837 | 5 | 07-21 |
108 | 소프트웨어| dup2patcher.dll 디컴파일링-2 [3] | sunshine | 553 | 5 | 07-21 |