You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
youtube-dl/Home

548 lines
23 KiB

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<title>
rg3 / youtube-dl / wiki / Home &mdash; Bitbucket
</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<meta name="description" content="" />
<meta name="keywords" content="rg3,youtube-dl,is,a,small,command-line,program,for,downloading,videos,from,YouTube.com.,wiki" />
<link rel="stylesheet" type="text/css" href="http://bitbucket-assets.s3.amazonaws.com/css/layout.css?10293858" />
<link rel="stylesheet" type="text/css" href="http://bitbucket-assets.s3.amazonaws.com/css/screen.css?10293858" />
<link rel="stylesheet" href="http://bitbucket-assets.s3.amazonaws.com/css/reset.css?10293858" type="text/css" />
<link rel="stylesheet" href="http://bitbucket-assets.s3.amazonaws.com/css/main.css?10293858" type="text/css" />
<link rel="stylesheet" type="text/css" href="http://bitbucket-assets.s3.amazonaws.com/css/print.css?10293858" media="print" />
<link rel="search" type="application/opensearchdescription+xml" href="/opensearch.xml" title="Bitbucket" />
<link rel="icon" href="http://bitbucket-assets.s3.amazonaws.com/img/logo_new.png" type="image/png"/>
<script type="text/javascript">var MEDIA_URL = "http://bitbucket-assets.s3.amazonaws.com/"</script>
<script type="text/javascript" src="http://bitbucket-assets.s3.amazonaws.com/js/lib/bundle.020510May.js"></script>
<script type="text/javascript">
$(document).ready(function() {
$('.dropdown').hover(
function(){
$(this).addClass('open');
$(this).next('ul.dropdown-list').css('display', 'block');
},
function(){
$('.dropdown').removeClass('open');
$(this).next('ul.dropdown-list').css('display', 'none');
}
);
$.ajaxSetup ({ cache: false });
});
</script>
<noscript>
<style type="text/css">
.dropdown-container-text .dropdown {
position: static !important;
}
</style>
</noscript>
<link rel="stylesheet" href="http://bitbucket-assets.s3.amazonaws.com/css/highlight/default.css" type="text/css" />
<script type="text/javascript">
$(document).ready(function() {
$('#wiki table:not(.highlighttable)').addClass('wikitable');
$('#wiki table.wikitable tr:even').addClass('crow2');
});
</script>
<link href="/rg3/youtube-dl/rss" rel="alternate nofollow" type="application/rss+xml" title="RSS Feed for youtube-dl" />
<style type="text/css">
/* body { background: #fff url('/m/img/layout/bg_header_new.png') repeat-x left 24px !important; } */
</style>
</head>
<body class="">
<div id="header-wrap" class="clearfix">
<div id="header" class="clearfix">
<ul id="global-nav">
<li id="global-nav-home"><a href="http://www.atlassian.com">Atlassian Home</a></li>
<li id="global-nav-documentation"><a href="http://confluence.atlassian.com/display/BITBUCKET">Documentation</a></li>
<li id="global-nav-support"><a href="/support">Support</a></li>
<li id="global-nav-blogs"><a href="http://blog.bitbucket.org">Blog</a></li>
<li id="global-nav-forums"><a href="http://groups.google.com/group/bitbucket-users">Forums</a></li>
</ul>
<div id="logo">
<a href="/">Bitbucket by Atlassian</a>
</div>
<div id="main-nav" class="clearfix">
<ul class="clearfix">
<li><a href="/plans">Pricing &amp; Signup</a></li>
<li><a href="/repo/all">Explore Bitbucket</a></li>
<li><a href="/account/signin/">Log in</a></li>
<li class="search-box">
<form action="/repo/all/" method="get">
<input id="search" type="text" name="name" />
</form>
</li>
</ul>
</div>
</div>
</div>
<div id="content-wrapper">
<div id="wrapper">
<div id="content-wrapper">
<div id="content">
<script type="text/javascript" src="http://bitbucket-assets.s3.amazonaws.com/js/lib/jquery.cookie.js"></script> <!--REMOVE WHEN NEWER BUNDLE THAN 030309Mar -->
<script type="text/javascript">
var date = new Date();
date.setTime(date.getTime() + (365 * 24 * 60 * 60 * 1000));
var cookieoptions = { path: '/', expires: date };
window._shard = 'bitbucket01 (ID 8)';
$(document).ready(function(){
$('#toggle-repo-content').click(function(){
$('#repo-desc-cloneinfo').toggle('fast');
$('#repo-menu').toggle();
$('#repo-menu-links-mini').toggle(100);
$('.repo-desc-description').toggle('fast');
var avatar_new_width = ($('.repo-avatar').width() == 35) ? 16 : 35;
$('.repo-avatar').animate({ width: avatar_new_width }, 250);
if ($.cookie('toggle_status') == 'hide') {
$.cookie('toggle_status', 'show', cookieoptions);
$(this).css('background-image','url(http://bitbucket-assets.s3.amazonaws.com/img/repo-toggle-up.png)');
} else {
$.cookie('toggle_status', 'hide', cookieoptions);
$(this).css('background-image','url(http://bitbucket-assets.s3.amazonaws.com/img/repo-toggle-down.png)');
}
});
if ($.cookie('toggle_status') == 'hide') {
$('#toggle-repo-content').css('background-image','url(http://bitbucket-assets.s3.amazonaws.com/img/repo-toggle-down.png)');
$('#repo-desc-cloneinfo').hide();
$('#repo-menu').hide();
$('#repo-menu-links-mini').show();
$('.repo-desc-description').hide();
$('.repo-avatar').css({ width: '16px' });
} else {
$('#toggle-repo-content').css('background-image','url(http://bitbucket-assets.s3.amazonaws.com/img/repo-toggle-up.png)');
$('#repo-desc-cloneinfo').show();
$('#repo-menu').show();
$('#repo-menu-links-mini').hide();
$('.repo-desc-description').show();
$('.repo-avatar').css({ width: '35px' });
}
});
</script>
<div id="tabs">
<ul class="ui-tabs-nav">
<li>
<a href="/rg3/youtube-dl/overview"><span>Overview</span></a>
</li>
<li>
<a href="/rg3/youtube-dl/downloads"><span>Downloads (0)</span></a>
</li>
<li>
<a href="/rg3/youtube-dl/src"><span>Source</span></a>
</li>
<li>
<a href="/rg3/youtube-dl/changesets"><span>Changesets</span></a>
</li>
<li class="ui-tabs-nav-issues ui-tabs-selected">
<a href="/rg3/youtube-dl/wiki"><span>Wiki</span></a>
</li>
<li class="ui-tabs-nav-issues">
<a href="/rg3/youtube-dl/issues?status=new&amp;status=open"><span>Issues (17) &raquo;</span></a>
<ul>
<li><a href="/rg3/youtube-dl/issues?status=new">New issues</a></li>
<li><a href="/rg3/youtube-dl/issues?status=new&amp;status=open">Open issues</a></li>
<li><a href="/rg3/youtube-dl/issues?status=resolved&amp;status=invalid&amp;status=duplicate">Closed issues</a></li>
<li><a href="/rg3/youtube-dl/issues">All issues</a></li>
<li><a href="/rg3/youtube-dl/issues/query">Advanced query</a></li>
<li><a href="/rg3/youtube-dl/issues/new">Create new issue</a></li>
</ul>
</li>
<li class="tabs-right tabs-far-right">
<a href="/rg3/youtube-dl/descendants"><span>Forks/Queues (17)</span></a>
</li>
<li class="tabs-right">
<a href="/rg3/youtube-dl/zealots"><span>Followers (97)</span></a>
</li>
</ul>
</div>
<div id="repo-menu">
<div id="repo-menu-links">
<ul>
<li>
<a href="/rg3/youtube-dl/rss" class="noborder repo-menu-rss" title="RSS Feed for youtube-dl">RSS</a>
</li>
<li>
<a href="/rg3/youtube-dl/atom" class="noborder repo-menu-atom" title="Atom Feed for youtube-dl">Atom</a>
</li>
<li>
<a href="/rg3/youtube-dl/pull" class="link-request-pull">
pull request
</a>
</li>
<li><a href="/rg3/youtube-dl/fork" class="link-fork">fork</a></li>
<li><a href="/rg3/youtube-dl/hack" class="link-hack">patch queue</a></li>
<li>
<a rel="nofollow" href="/rg3/youtube-dl/follow" class="link-follow">follow</a>
</li>
<li><a class="link-download">get source &raquo;</a>
<ul>
<li><a rel="nofollow" href="/rg3/youtube-dl/get/190d2d0fd729.zip" class="zip">zip</a></li>
<li><a rel="nofollow" href="/rg3/youtube-dl/get/190d2d0fd729.gz" class="compressed">gz</a></li>
<li><a rel="nofollow" href="/rg3/youtube-dl/get/190d2d0fd729.bz2" class="compressed">bz2</a></li>
</ul>
</li>
</ul>
</div>
<div id="repo-menu-branches-tags">
<ul>
<li class="icon-branches">
branches &raquo;
<ul>
<li><a href="/rg3/youtube-dl/src/190d2d0fd729">default</a></li>
</ul>
</li>
<li class="icon-tags">
tags &raquo;
<ul>
<li><a href="/rg3/youtube-dl/src/190d2d0fd729">tip</a></li>
<li><a href="/rg3/youtube-dl/src/f8e09aa30813">2010.08.04</a></li>
<li><a href="/rg3/youtube-dl/src/09a81c91cceb">2010.07.24</a></li>
<li><a href="/rg3/youtube-dl/src/de50210f6416">2010.07.22</a></li>
<li><a href="/rg3/youtube-dl/src/ebc3c1a8ea94">2010.06.06</a></li>
<li><a href="/rg3/youtube-dl/src/1d3bca5d5e5d">2010.04.04</a></li>
<li><a href="/rg3/youtube-dl/src/d6f421afc953">2010.04.03</a></li>
<li><a href="/rg3/youtube-dl/src/a40f32f2978a">2010.04.02</a></li>
<li><a href="/rg3/youtube-dl/src/eadec6d49e8a">2010.03.13</a></li>
<li><a href="/rg3/youtube-dl/src/c69858fd4850">2010.03.07</a></li>
<li><a href="/rg3/youtube-dl/src/9ade3c8f7a53">2010.01.19</a></li>
<li><a href="/rg3/youtube-dl/src/eabc9bc8ab3c">2009.12.26</a></li>
<li><a href="/rg3/youtube-dl/src/6947c04fb1b4">2009.09.13</a></li>
<li><a href="/rg3/youtube-dl/src/4597eb63af5c">2009.09.08</a></li>
<li><a href="/rg3/youtube-dl/src/df8b882d8b39">2009.08.08</a></li>
<li><a href="/rg3/youtube-dl/src/2793d3270ff9">2009.06.29</a></li>
<li><a href="/rg3/youtube-dl/src/4bc5ac772e8a">2009.05.25</a></li>
<li><a href="/rg3/youtube-dl/src/3f498fb56291">2009.05.23</a></li>
<li><a href="/rg3/youtube-dl/src/31198e942e00">2009.05.13</a></li>
<li><a href="/rg3/youtube-dl/src/1dd3c78e417e">2009.03.28</a></li>
<li><a href="/rg3/youtube-dl/src/8dc1b312077f">2009.03.03</a></li>
<li><a href="/rg3/youtube-dl/src/ef03a5f5f333">2009.02.07</a></li>
<li><a href="/rg3/youtube-dl/src/ee7b97092712">2009.01.31</a></li>
<li><a href="/rg3/youtube-dl/src/846c13fabe78">2008.10.16</a></li>
<li><a href="/rg3/youtube-dl/src/9636c1843c6f">2008.09.20</a></li>
<li><a href="/rg3/youtube-dl/src/afa03d33275e">2008.07.22</a></li>
</ul>
</li>
</ul>
</div>
<div class="cb"></div>
</div>
<div id="repo-desc" class="layout-box">
<div id="repo-menu-links-mini" class="right">
<ul>
<li>
<a href="/rg3/youtube-dl/rss" class="noborder repo-menu-rss" title="RSS Feed for youtube-dl"></a>
</li>
<li>
<a href="/rg3/youtube-dl/atom" class="noborder repo-menu-atom" title="Atom Feed for youtube-dl"></a>
</li>
<li>
<a href="/rg3/youtube-dl/pull" class="tooltip noborder link-request-pull" title="Pull request"></a>
</li>
<li><a href="/rg3/youtube-dl/fork" class="tooltip noborder link-fork" title="Fork"></a></li>
<li><a href="/rg3/youtube-dl/hack" class="tooltip noborder link-hack" title="Patch queue"></a></li>
<li><a class="tooltip noborder link-download" title="Get source"></a>
<ul>
<li><a rel="nofollow" href="/rg3/youtube-dl/get/190d2d0fd729.zip" class="zip">zip</a></li>
<li><a rel="nofollow" href="/rg3/youtube-dl/get/190d2d0fd729.gz" class="compressed">gz</a></li>
<li><a rel="nofollow" href="/rg3/youtube-dl/get/190d2d0fd729.bz2" class="compressed">bz2</a></li>
</ul>
</li>
</ul>
</div>
<h3>
<a href="/rg3">rg3</a> /
<a href="/rg3/youtube-dl/wiki/Home">youtube-dl</a>
<span>(<a href="http://bitbucket.org/rg3/youtube-dl/wiki/">http://bitbucket.org/rg3/youtube-dl/wiki/</a>)</span>
</h3>
<p class="repo-desc-description">youtube-dl is a small command-line program for downloading videos from <a href="http://YouTube.com" rel="nofollow">YouTube.com</a>.</p>
<div id="repo-desc-cloneinfo">Clone this repository (size: 341.1 KB): <a href="http://bitbucket.org/rg3/youtube-dl" onclick="$('#clone-url-ssh').hide();$('#clone-url-https').toggle();return(false);"><small>HTTPS</small></a> / <a href="ssh://hg@bitbucket.org/rg3/youtube-dl" onclick="$('#clone-url-https').hide();$('#clone-url-ssh').toggle();return(false);"><small>SSH</small></a><br/>
<pre id="clone-url-https">$ hg clone <a href="http://bitbucket.org/rg3/youtube-dl">http://bitbucket.org/rg3/youtube-dl</a></pre>
<pre id="clone-url-ssh" style="display:none;">$ hg clone <a href="ssh://hg@bitbucket.org/rg3/youtube-dl">ssh://hg@bitbucket.org/rg3/youtube-dl</a></pre></div>
<div class="cb"></div>
<a href="#" id="toggle-repo-content"></a>
</div>
<div class="global-divider-header issues-nav">
<div id="wiki-nav-links">
<span class="right">
<nobr>
<small>hg clone http://bitbucket.org/rg3/youtube-dl/wiki</small>
</nobr>
</span>
<b><a href="/rg3/youtube-dl/wiki/Home" class="wiki-icon-home">Home</a></b>
<a href="/rg3/youtube-dl/wiki/history/Home" class="wiki-icon-history">History</a>
<a href="http://www.wikicreole.org/wiki/Creole1.0" class="wiki-icon-markup">Wiki Markup</a>
</div>
<div class="cb"></div>
</div>
<div id="wiki">
<p></p>
<h1 id="youtube-dl-download-videos-from-youtubecom">youtube-dl: Download videos from YouTube.com</h1>
<p>(and more...)</p>
<h2 id="what-is-it">What is it?</h2>
<p><em>youtube-dl</em> is a small command-line program to download videos from YouTube.com and a few more sites. It requires the <a href="http://www.python.org/">Python interpreter</a>, version 2.x (x being at least 4), and it's not platform specific. It should work in your Unix box, in Windows or in Mac OS X. The latest version is <strong>2010.10.03</strong>. It's released to the public domain, which means you can modify it, redistribute it or use it however you like.</p>
<p>I'll try to keep it updated if YouTube.com changes the way you access their videos. After all, it's a simple and short program. However, I can't guarantee anything. If you detect it stops working, check for new versions and/or inform me about the problem, indicating the program version you are using. If the program stops working and I can't solve the problem but you have a solution, I'd like to know it. If that happens and you feel you can maintain the program yourself, tell me. My contact information is at <a href="http://rg03.wordpress.com/contact-me/">rg03.wordpress.com</a>.</p>
<p>Thanks for all the feedback received so far. I'm glad people find my program useful.</p>
<h2 id="usage-instructions">Usage instructions</h2>
<p>In Windows, once you have installed the Python interpreter, save the program with the <em>.py</em> extension and put it somewhere in the PATH. Try to follow the <a href="/rg3/youtube-dl/wiki/youtube-dl_under_Windows_XP">guide to install youtube-dl under Windows XP</a>.</p>
<p>In Unix, download it, give it execution permission and copy it to one of the PATH directories (typically, <em>/usr/local/bin</em>).</p>
<p>After that, you should be able to call it from the command line as <em>youtube-dl</em> or <em>youtube-dl.py</em>. I will use <em>youtube-dl</em> in the following examples. Usage instructions are easy. Use <em>youtube-dl</em> followed by a video URL or identifier. Example: <em>youtube-dl "<code>http://www.youtube.com/watch?v=foobar</code>"</em>. The video will be saved to the file <em>foobar.flv</em> in that example. As YouTube.com videos are usually in Flash Video format, their extension should be <em>flv</em>. In Linux and other unices, video players using a recent version of <em>ffmpeg</em> can play them. That includes MPlayer, VLC, etc. Those two work under Windows and other platforms, but you could also get a specific FLV player of your taste.</p>
<p>If you try to run the program and you receive an error message containing the keyword <em>SyntaxError</em> near the end, it means your Python interpreter is too old.</p>
<h2 id="more-usage-tips">More usage tips</h2>
<p>The program is usually invoked as <em>youtube-dl</em> followed by options and the video URLs. Listing all the options here would make this text too long, so you can run <em>youtube-dl --help</em> and get a summary of them. From that point on you can start experimenting with the different options yourself. The most common ones are -t (or -l) to include the video title in the file name, and either -f or -b to download a high quality version of the video. Also, the -o option can specify the output file name and path. It allows special character sequences that can be used as templates to be replaced. See the "Output template" section for more details.</p>
<h2 id="download-it">Download it</h2>
<p>Note that if you directly click on these hyperlinks, your web browser will most likely display the program contents. It's usually better to right-click on it and choose the appropriate option, normally called <em>Save Target As</em> or <em>Save Link As</em>, depending on the web browser you are using.</p>
<h3 id="httpbitbucketorgrg3youtube-dlraw20101003youtube-dl20101003"><a href="http://bitbucket.org/rg3/youtube-dl/raw/2010.10.03/youtube-dl">2010.10.03</a></h3>
<ul><li><strong>MD5</strong>: c552c00881845689900b67525ac6f72b
</li><li><strong>SHA1</strong>: 436006432018fca75298e63742bb2c13feb42f98
</li><li><strong>SHA256</strong>: eb6a5deb494e8949918ca5a674d961439963fadd822df67dfa49ce47fa326d75
</li></ul>
<h2 id="faq">FAQ</h2>
<p>The <a href="/rg3/youtube-dl/wiki/Frequently_Asked_Questions">Frequently Asked Questions</a> page contains answers to some common questions that pop up in my e-mail and in the issue tracker. Be sure to check it before reporting problems.</p>
<h2 id="supported-sites">Supported sites</h2>
<ul><li>YouTube.com.
</li><li>YouTube.com playlists (playlist URLs in "view_play_list" form).
</li><li>YouTube.com searches, using the special keyword "ytsearch" as a form of URL, as in "ytsearch:cute kittens". Do not forget the quotes if you want to include spaces in your search. Other variants are "ytsearchN" to download more than the first result, with N being a number, and "ytsearchall".
</li><li>metacafe.com.
</li><li>Google Video.
</li><li>Google Video searches ("gvsearch" keyword).
</li><li>Photobucket videos.
</li><li>Yahoo! video.
</li><li>Yahoo! video searches ("ybsearch" keyword).
</li><li>Dailymotion.
</li><li>A generic downloader that works in some sites.
</li></ul>
<h2 id="proxy-support">Proxy support</h2>
<p>youtube-dl supports downloading videos through a proxy, by setting the http_proxy environment variable to the proxy URL, as in <code>http://proxy_machine_name:port/</code>.</p>
<h2 id="youtube-formats">YouTube formats</h2>
<p>Using the -f option and other related options, you can specify the video format to be downloaded from YouTube. Instead of keeping a video format table here, I will refer you to the <a href="http://en.wikipedia.org/wiki/YouTube#Quality_and_codecs">list of YouTube formats on Wikipedia</a>.</p>
<h2 id="output-template">Output template</h2>
<p>The -o option allows users to indicate a template for the output file names. The basic usage is not to set any template arguments when downloading a single file, like in <em>youtube-dl -o funny_video.flv "<code>http://some/video</code>"</em>. However, it may contain special sequences that will be replaced when downloading each video. The special sequences have the format <strong>%(NAME)s</strong>. To clarify, that's a percent symbol followed by a name in parenthesis, followed by a lowercase S. Allowed names are:</p>
<ul><li><em>id</em>: The sequence will be replaced by the video identifier.
</li><li><em>url</em>: The sequence will be replaced by the video URL.
</li><li><em>uploader</em>: The sequence will be replaced by the nickname of the person who uploaded the video.
</li><li><em>title</em>: The sequence will be replaced by the literal video title.
</li><li><em>stitle</em>: The sequence will be replaced by a simplified video title, restricted to alphanumeric characters and dashes.
</li><li><em>ext</em>: The sequence will be replaced by the appropriate extension (like <em>flv</em> or <em>mp4</em>).
</li><li><em>epoch</em>: The sequence will be replaced by the Unix epoch when creating the file.
</li><li><em>ord</em>: The sequence will be replaced by a five-digit number that will be increased with each download, starting at zero.
</li></ul>
<p>As you may have guessed, the default template is <em>%(id)s.%(ext)s</em>. When some command line options are used, it's replaced by other templates like <em>%(title)s-%(id)s.%(ext)s</em>. You can specify your own.</p>
<h2 id="authors">Authors</h2>
<ul><li>Ricardo Garcia Gonzalez: program core, YouTube.com InfoExtractor, metacafe.com InfoExtractor and YouTube playlist InfoExtractor.
</li><li>Danny Colligan: YouTube search InfoExtractor, ideas and patches.
</li><li>Benjamin Johnson: Google Video InfoExtractor, Photobucket InfoExtractor, Yahoo! Video InfoExtractor, generic InfoExtractor, ideas, patches, etc.
</li><li>Many other people contributing patches, code, ideas and kind messages. Too many to be listed here. You know who you are. Thank you very much.
</li></ul>
<p>Copyright © 2006-2010 Ricardo Garcia Gonzalez</p>
</div>
</div>
<div id="footer" class="clearfix">
<ul class="footer-nav">
<li>Copyright &copy; 2010 <a href="http://atlassian.com">Atlassian</a><span class="pipe">|</span></li>
<li><a href="http://www.atlassian.com/hosted/terms.jsp">Terms of Service</a><span class="pipe">|</span></li>
<li><a href="http://www.atlassian.com/about/privacy.jsp">Privacy</a></li>
</ul>
<ul class="social-nav">
<li class="blog"><a href="http://blog.bitbucket.org">Bitbucket Blog</a></li>
<li class="twitter"><a href="http://www.twitter.com/bitbucket">Twitter</a></li>
</ul>
</div>
<div id="footer2" class="clearfix">
We run
<a href="http://www.djangoproject.com/">Django 1.2.3</a> /
<a href="http://bitbucket.org/jespern/django-piston/">Piston 0.2.3rc1</a> /
<a href="http://www.selenic.com/mercurial/">Hg 1.6</a> /
<a href="http://www.python.org">Python 2.7.0</a> /
r3577 | bitbucket01
</div>
</div>
</div>
<!-- <script type="text/javascript"> Cufon.now(); </script> -->
<script type="text/javascript">
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-2456069-3'], ['_trackPageview']);
var _gaq = _gaq || [];
_gaq.push(['atl._setAccount', 'UA-6032469-33'], ['atl._trackPageview']);
(function() {
var ga = document.createElement('script');
ga.src = ('https:' == document.location.protocol ? 'https://ssl' :
'http://www') + '.google-analytics.com/ga.js';
ga.setAttribute('async', 'true');
document.documentElement.firstChild.appendChild(ga);
})();
</script>
</body>
</html>