• 목록
  • 아래로
  • 위로
import youtube_dl, operator, os, glob
from moviepy.editor import *


# 유튜브 영상을 다운받는 함수입니다.
def yt_download(url): 
    ydl_opts = {'outtmpl': '%(title)s.%(ext)s', 
                'format':' bestvideo+bestaudio'
            }
    with youtube_dl.YoutubeDL(ydl_opts) as ydl:
        ydl.download([url])
        info = ydl.extract_info(url, download=False) # 유튜브에 저장된 파일명을 받아옵니다.
        filename = ydl.prepare_filename(info)
        print(filename)
    return filename


# 확장자를 확인하고, 특수문자를 제거하는 함수입니다.
def check_file(filename): 
    if not os.path.isfile(filename):
        name = ''.join(filename.split('.')[:-1])
        filename = glob.glob(name + '.*')[0]
    name, ext = os.path.splitext(filename)
    name_edit = ''.join([x for x in name if x.isalnum() or x.isspace() or x == '_' or x == '-'])
    new_filename = name_edit + ext
    os.rename(filename, new_filename)
    return new_filename


# 영상을 rotation 하는 함수입니다.
def rotate_video(filename): 
    clip = VideoFileClip(filename)
    clip = clip.rotate(270, resample='bicubic') # 270도 또는 90도 rotation 합니다.
    name, ext = os.path.splitext(filename)
    print(ext)
    clip.write_videofile(name + '_rotate.mp4') # MP4로 설정해야 오류가 가장 적네요.
    return


url = 'URL을 입력하세요'
filename = yt_download(url)
filename = check_file(filename)
rotate_video(filename)

 

 

안녕하세요?

 

유튜브 영상 중에 모바일용으로 회전된 영상을 PC용으로 다시 회전시키는 스크립트에요 ^^

 

youtube_dl과 moviepy를 사용했구요.

 

 

이론적으로는 간단하지만 다음과 같은 문제가 있더군요 ㄷㄷ

 

1. 유튜브 서버에 저장된 파일과 실제 다운받은 파일의 확장자가 불일치한 경우가 있어요.

 

youtube_dl에서 merge할 때 확장자를 MKV로 바꿔버리는 경우가 있더군요.

(pytube는 어떨지 모르겠네요 ^^)

 

https://stackoverflow.com/questions/59987612/python-youtube-dl-it-is-possible-to-get-merging-files-extension

 

위와 같은 방식으로 해결한 분이 계시던데, 저는 가능하면 어떠한 확장자에 대해서도 대처할 수 있는 방법으로 구현했네요 :)

 

2. 특수문자가 파일명에 포함되어 있으면 moviepy에서 에러가 발생하는 경우가 있어요 ㅠㅠ

 

3. interpolation 방식은 bicubic이나 bilinear가 무난하던데 아무래도 완벽하지는 않네요~

 

 

일단 MP4, WEBM, MKV파일의 경우를 테스트해봤는데

 

이외에 다른 경우가 또 있을지도 모르겠네요 ㅜㅜ

 

 

그럼 남은 연휴 즐겁게 보내세요!

 

제가 업무 때문에 경황이 없어서 당분간은 글을 작성하지 못할 것 같네요 ㅠㅠ

 

항상 감사드려요 :)

 

 

+) 만약 youtube_dl이 작동하지 않는다면 pytube로 해결하시면 되어요 ^^

작성자
이니스프리 119 Lv. (0%) 1887110/115200000EXP

당분간 일신상의 사정으로 쪽지나 댓글로 답변을 드리기 어렵습니다. 죄송합니다.

 

CSVpuymXAAAVVpd.jpg

댓글 4

NoYeah
profile image
궁금한 점이 있습니다.
성인 인증이나 비공개와 같은 경우로 반드시 로그인이 필요한 영상의 경우에도 다운로드가 되나요?
comment menu
2020.10.04. 00:49

신고

"NoYeah님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → NoYeah
profile image

제가 성인 영상이나 비공개 영상을 본 경험이 없어서 테스트해본 적이 없네요~
구글링해보니 조금 우회적이지만 쿠키를 이용하여 youtube-dl로 비공개 영상을 다운받는 방법에 대한 글이 있긴 하군요 ㄷㄷ
https://daveparrish.net/posts/2018-06-22-How-to-download-private-YouTube-videos-with-youtube-dl.html

comment menu
2020.10.04. 10:00

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

NoYeah → 이니스프리
profile image
음.. 약간 성인 영상이라고 하니 좀 그렇긴한데;;
의외로 로그인을 꼭해야 볼 수 있는 영상들이 많더라구요. 항상 로그인 되어 있어서 몰랐는데 다운받으려고 하니 의의로 많더라구요;;
comment menu
2020.10.05. 00:51

신고

"NoYeah님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → NoYeah
profile image
제가 근무 시작한지 얼마 안 되어서 정신이 없네요 ㅠㅠ
오늘도 방금 퇴근했구요 ㅜㅜ

미국의 R등급 같은 취지로 말씀드렸어요~
마약이 영상에 등장하거나 자살을 다루면 당연히 R등급이고
심지어 비긴 어게인이나 킹스 스피치 같은 영화도 욕설이 등장해서 R등급 아닌가요?? ㄷㄷ

유튜브의 영상 수위에 대한 규제 기준을 모르지만 대략 비슷하지 않을까 추측해보네요~
그럼 일교차가 큰데 감기 조심하시고 굿밤 되세요!
감사합니다 :)
comment menu
2020.10.06. 23:59

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 마스터 24.02.11.17:21 602
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 4283
500 [Python] 이미지 파일의 Exif 정보 삭제하기 (+ 식빵자세 산냥이) image 이니스프리 이니스프리 21.07.03.13:42 262
499 [Python] PDF2image 모듈이 실행되지 않을 때 이니스프리 이니스프리 21.06.23.20:36 2608
498 유료 VPN 선택과 관련하여 참고할 웹 문서! 2 이니스프리 이니스프리 21.06.08.19:28 248
497 [Python] 영어로 표기된 날짜를 숫자로 변환 이니스프리 이니스프리 21.05.30.11:39 1068
496 [Python] Google Trend의 '최근 인기 검색어' 크롤링 3 이니스프리 이니스프리 21.05.02.12:24 486
495 [Python] for 문에 두 개의 리스트를 넣고 enumerate를 사용하는 방법 이니스프리 이니스프리 21.05.01.21:01 219
494 [Python] 입력받은 연도가 윤년이 아니면 그보다 가장 가까운 과거의 윤년을 출력하기 8 이니스프리 이니스프리 21.04.19.20:23 435
493 [Javascript] 이미지 업로드 전 가로x세로 사이즈를 확인하여 지정된 크기 이상인 경우 alert 띄우는 스크립트 이니스프리 이니스프리 21.04.17.21:28 123
492 [HTML] 특정 사이트의 파비콘을 다운로드 받는 방법 이니스프리 이니스프리 21.04.16.22:02 260
491 [Javascript] 값을 이용하여 배열의 요소를 삭제하는 방법 이니스프리 이니스프리 21.04.13.22:10 97
490 [Gnuboard] DB 테이블 중 g5_board_file에 대하여 이니스프리 이니스프리 21.04.11.16:25 392
489 [Windows] Windows 업데이트 원천 방지하기 5 image Seia Seia 21.04.10.07:10 245
488 [Docker] Docker 다시 알고 사용하기 Seia Seia 21.04.10.07:04 167
487 [미디어위키/리버티 스킨] 모바일 환경에서 가로로 긴 표가 짤리는 현상 개선하기(스크롤 구현) image 가온이 가온이 21.04.09.20:07 219
486 [Python] 내일 날짜를 구하기 3 이니스프리 이니스프리 21.03.31.23:46 766
485 [Python] 네이트 실시간 검색어 크롤링 1 이니스프리 이니스프리 21.03.22.20:16 1005
484 [Python] 간단하게 내 ip 확인하기 3 이니스프리 이니스프리 21.03.20.00:26 221
483 [Python] 특정 서버와 내 PC 간의 시간 차이를 구하기 (테스트 중) 이니스프리 이니스프리 21.03.20.00:11 1397
482 [Python] Youtube Playlist에 담긴 동영상들을 역순으로 불러오기 이니스프리 이니스프리 21.03.19.00:41 144
481 [미디어위키]웹호스팅상의 미디어위키 사용자들께 대박 좋은 일이 일어났어요! 2 입체그림 21.03.14.10:53 127