• 목록
  • 아래로
  • 위로
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%) 1939280/115200000EXP

Make StudyForUs Great Again!

 

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 869
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 4546
469 AMD KOREA 라이젠 3500X 공식 런칭 예정 image 이니스프리 이니스프리 19.10.15.17:50 162
468 JLPT 성적표 및 합격증 수령 주소 변경 이니스프리 이니스프리 20.01.29.21:51 163
467 [Python] OrderedDict에 대한 간단한 소개 3 이니스프리 이니스프리 20.06.16.13:09 163
466 [펌] 하이패스 미납요금 내기 귀찮을 땐, 동네 편의점? image 이니스프리 이니스프리 19.08.28.14:53 165
465 [스퀘어넷] Ubuntu Server 18.04 LTS 지원 1 이니스프리 이니스프리 19.02.04.22:20 166
464 [Python] 파이썬으로 평균을 구하는 두 가지 방법 이니스프리 이니스프리 21.03.13.21:58 166
463 [Python] Function to save list into a text file line by line 이니스프리 이니스프리 22.06.11.21:33 166
462 [Vultr] Important Tax Notice 이니스프리 이니스프리 19.11.20.07:38 167
461 [Docker] Docker 다시 알고 사용하기 Seia Seia 21.04.10.07:04 167
460 [Selenium] Page down 이니스프리 이니스프리 22.06.19.12:40 167
459 사실상 일본산 제품인데 헷갈리는 브랜드 6 이니스프리 이니스프리 20.06.10.20:05 168
458 [Python] COS Pro 1급 예제 2-6 풀이 이니스프리 이니스프리 20.02.14.15:03 169
457 앱체크 라이선스 갱신과 관련하여 이니스프리 이니스프리 19.05.11.14:43 170
456 [Python] extension이 標示되지 않는 online image의 extension을 알아내기 이니스프리 이니스프리 22.04.01.20:51 170
455 [할인정보] 스와로브스키 50% 할인 image 이니스프리 이니스프리 17.01.22.22:45 173
454 [아미나] 아미나 2.0으로의 리뉴얼 계획 이니스프리 이니스프리 19.03.12.13:03 173
453 Vultr.com - 오늘자 Service Alert 이니스프리 이니스프리 20.01.17.22:02 173
452 [Python] MP4 움짤을 clip하여 thumbnail 生成하기 이니스프리 이니스프리 22.06.09.08:35 173
451 Eva Icons - 웹, iOS, 안드로이드를 위한 오픈소스 아이콘 2 이니스프리 이니스프리 18.12.08.14:38 174
450 최근 KT 해외망 간단 리뷰 이니스프리 이니스프리 19.12.25.23:21 174