• 목록
  • 아래로
  • 위로
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%) 1901660/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 687
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 4367
486 [Python] 내일 날짜를 구하기 3 이니스프리 이니스프리 21.03.31.23:46 767
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 1400
482 [Python] Youtube Playlist에 담긴 동영상들을 역순으로 불러오기 이니스프리 이니스프리 21.03.19.00:41 146
481 [미디어위키]웹호스팅상의 미디어위키 사용자들께 대박 좋은 일이 일어났어요! 2 입체그림 21.03.14.10:53 127
480 [Python] 파이썬으로 평균을 구하는 두 가지 방법 이니스프리 이니스프리 21.03.13.21:58 166
479 [Python] 동영상 파일의 재생시간 길이를 구하기 (OpenCV vs MoviePy) 이니스프리 이니스프리 21.03.12.22:33 4636
478 [Python] Youtube_dl 사용시 주의할 점 이니스프리 이니스프리 21.03.12.22:14 128
477 [Python] Youtube Data API를 이용하여 특정 채널의 모든 비디오 링크를 얻는 함수 이니스프리 이니스프리 21.03.12.22:05 388
476 php8.0 대응 라이믹스 오류 해결법 NUBE title: 크롬NUBE 21.03.08.11:39 265
475 [Python] 동영상 파일의 포맷 변환 - FFmpy 모듈 이니스프리 이니스프리 21.03.07.12:14 242
474 [Python] glob.glob() 정렬 방법 정리! 이니스프리 이니스프리 21.03.07.00:49 1499
473 [Python] 윈도우에서 pyaudio 모듈 설치 에러 해결하는 방법 3 이니스프리 이니스프리 21.03.06.15:11 524
472 외국어(인도-유럽어족) 학습에 관하여 4 이니스프리 이니스프리 21.02.21.00:01 122
471 ionicons.com - 오픈 소스 아이콘 4 이니스프리 이니스프리 21.02.14.18:59 307
470 나리야 익명보드 및 내 글 알림 관련 Q&A image 이니스프리 이니스프리 21.02.14.17:30 105
469 [Python] 크롤링한 bytes를 string으로 변환 이니스프리 이니스프리 21.02.14.15:32 109
468 [Python] BeautifulSoup에서 class명에 공백이 있을 때 검색 방법 이니스프리 이니스프리 21.02.13.00:26 2022
467 [Python] Instalooter 에러 발생 시 대처법 1 이니스프리 이니스프리 21.01.31.13:37 215