소프트웨어 엑셀로 KBS1 KBS2 MBC SBS 등 편성표 가져오기
2022.06.06 20: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.06 20:16
와 ~. 이건 뭘로 만드신건가요? -
지후빠 2022.06.06 20:27
안녕하세요? 엑셀 VBA (VBS와 거의 비슷) 입니다. ^^
-
선우아버 2022.06.06 22:22
관심 가져주시고 많은 시간을 할애해 주셨네요. 감사합니다...^^*
덕분에 간단히 편성표를 복사해 올수 있었습니다.
ps. 매주 일주일치의 작업을 해야 하는데...
kt 홈페이지의 주간편성표 페이지로 VBA 수정좀 해주실수 없나요?
시간 나실때 부탁좀 드리겠습니다.
아울러 다시 한번 감사드립니다.
-
지후빠 2022.06.07 11:13
GetTVProgramSunday 매크로를 추가하였습니다. 지상파 편성표 2.xlsm
오늘 기준으로 다음 일요일의 데이터를 가져옵니다. ^^
-
지후빠 2022.06.07 16:31
앗! 매주일주일치... 매주일요일인줄 착각했습니다. 시간 날때 다시 해보겠습니다.ㅠㅠ
-
상발이 2022.06.07 04:58
수고하셨습니다.
-
맨션에살자 2022.06.07 07:53
역쉬 지후빠님!!
쵝오~~
-
cungice 2022.06.07 13:23
수고 많으셨습니다. 감사합니다.
-
가을사랑 2022.06.07 20:55
멋진 아이디어
대단하십니다. -
지후빠 2022.06.07 23:18
댓글과 추천해주신 여러분 감사드립니다.^^
쓰는데 크게 불편하지 않을 것 같아서 이쯤에서 멈출까 합니다.~
-
선우아버 2022.06.07 23:40
지후빠님 매우 매우 감사합니다. *^^*
이로써 기본틀을 구축 할수가 있을것 같습니다.
수고 하셨습니다!!!
감사 합니다!!!
-
와로 2022.06.08 22:21
또 꿀팁 한건(?) 하셨네요 ^ㅡ^
수고하셨습니다~!
-
mso 2022.06.10 06:00
오래전에 링크를 받은 것이라 출처가 생각나진 않지만 지금도 사용하고 있습니다.
자후빠님 외 이런 것도 있다는 정도로 봐주셨으면 합니다.
https://docs.google.com/spreadsheets/d/1D9jF3KVYAZBvYRDMzZ8oEnGwVojanrIW7FQFl4n2TOk/edit#gid=0/
-
지후빠 2022.06.10 12:17
안녕하세요? 어떻게 만들어진 것인지 궁금한데 속을 알 수 없네요.ㅠㅠ 감사합니다.
번호 | 제목 | 글쓴이 | 조회 | 추천 | 등록일 |
---|---|---|---|---|---|
[공지] | 강좌 작성간 참고해주세요 | gooddew | - | - | - |
957 | 윈 도 우| 자식 VHDX 사용할 때 나름 간편하게 부팅메뉴 등록하기 | ANT-MAN | 2767 | 2 | 03-23 |
956 | 소프트웨어| VHD 에 윈도우 및 프로그램 설치 후 WIM 파일로 만들기 [6] | 타천사둘리 | 2765 | 13 | 07-21 |
955 | 기 타| 배치 파일 팁 (echo문) [4] | adda | 2762 | 9 | 03-08 |
954 | 기 타| 포토샵 많이 좋아졌네요!! [3] | 집에서뒹굴 | 2759 | 5 | 08-02 |
953 | 모 바 일| [Tip] 카카오톡 흔들어 QR 코드 생성하기 [3] | asklee | 2759 | 10 | 03-15 |
952 | 소프트웨어| WinISO Download-Update 모음 [11] | sunshine | 2749 | 20 | 11-12 |
951 | 윈 도 우| 관리자 계정용 PE의 한계점 (휴지통 도난사건) [15] | maniaa | 2747 | 6 | 05-26 |
950 | 윈 도 우| 향상된 윈도우 자동 로그인 On/Off 스크립트 [6] |
|
2745 | 13 | 02-11 |
949 | 윈 도 우| 요즘 한창인 windows rs4 update후 삭제 안되는 windows.ol... |
|
2745 | 2 | 04-02 |
948 | 윈 도 우| WinPE 한글화 관련(2) [19] | sunshine | 2733 | 21 | 02-25 |
947 | 윈 도 우| [실사] 윈도우10,11 PIN번호 분실 암호 재설정으로 우회 로... [9] | 무월 | 2729 | 11 | 12-07 |
946 | 윈 도 우| 표준 사용자 계정을 관리자 계정으로 변경하기 [13] |
|
2719 | 17 | 01-19 |
945 | 기 타| bat로 포터블 만들기 간단 팁 [9] | 슈머슈마 | 2719 | 20 | 11-12 |
944 | 윈 도 우| 카리스마조님 PrincePE V21 실행 방법입니다. [19] | 하늘은높고 | 2717 | 19 | 03-06 |
943 | 윈 도 우| 추가)PE 우측하단 워터마크에 각종 정보 넣기 [14] | 히이이잌 | 2714 | 24 | 06-16 |
942 | 소프트웨어| 동기화 기능 사용하지 않을 때 크롬 확장 프로그램 쉽게 설... [3] | 미유키로즈 | 2713 | 3 | 03-26 |
941 | 윈 도 우| SSD 에서 파일 삭제를 주의해야 되는 이유 [3] | gooddew | 2710 | 12 | 04-10 |
940 | 윈 도 우| PE SSD에 설치하기. [3] | 센돔타오르 | 2710 | 8 | 03-20 |
939 | 윈 도 우| Ventoy 설정법 (예제 포함) [1] |
|
2707 | 10 | 07-27 |
938 | 소프트웨어| Drvinst 디지탈 서명 [9] | sunshine | 2706 | 8 | 03-30 |