Jose Diaz-Gonzalez commited on
Commit
3c3f846
·
1 Parent(s): ef70fdd

Combine README.nd and README.rst

Browse files
Files changed (2) hide show
  1. README.md +0 -146
  2. README.rst +172 -9
README.md DELETED
@@ -1,146 +0,0 @@
1
- # A lightweight, dependency-free Python library for downloading YouTube Videos.
2
-
3
- Downloading videos from YouTube shouldn't require some bloatware application,
4
- it's usually a niche condition you want to do so in the first place. So I
5
- present to you, PyTube!
6
-
7
-
8
-
9
- ## Installation
10
- If you are on Mac OS X or Linux, chances are that one of the following two commands will work for you:
11
-
12
- ```
13
- $ easy_install pytube
14
- ```
15
-
16
- or even better:
17
-
18
- ```
19
- $ pip install pytube
20
- ```
21
-
22
- or you can get the [source code from github](https://github.com/NFicano/pytube).
23
-
24
- ### Roadmap
25
-
26
- The only features I see implementing in the near future are:
27
-
28
- - refactor console printing into separate command-line utility.
29
- - Add nosetests
30
- - Add Sphinx documentation
31
-
32
- ## Usage Example
33
-
34
- ``` python
35
- from pytube import YouTube
36
-
37
- # not necessary, just for demo purposes
38
- from pprint import pprint
39
-
40
- yt = YouTube()
41
-
42
- # Set the video URL.
43
- yt.url = "http://www.youtube.com/watch?v=Ik-RsDGPI5Y"
44
-
45
- # Once set, you can see all the codec and quality options YouTube has made
46
- # available for the perticular video by printing videos.
47
-
48
- pprint(yt.videos)
49
-
50
- #[<Video: MPEG-4 Visual (.3gp) - 144p>,
51
- # <Video: MPEG-4 Visual (.3gp) - 240p>,
52
- # <Video: Sorenson H.263 (.flv) - 240p>,
53
- # <Video: H.264 (.flv) - 360p>,
54
- # <Video: H.264 (.flv) - 480p>,
55
- # <Video: H.264 (.mp4) - 360p>,
56
- # <Video: H.264 (.mp4) - 720p>,
57
- # <Video: VP8 (.webm) - 360p>,
58
- # <Video: VP8 (.webm) - 480p>]
59
-
60
- # The filename is automatically generated based on the video title.
61
- # You can override this by manually setting the filename.
62
-
63
- # view the auto generated filename:
64
- print yt.filename
65
-
66
- #Pulp Fiction - Dancing Scene [HD]
67
-
68
- # set the filename:
69
- yt.filename = 'Dancing Scene from Pulp Fiction'
70
-
71
- # You can also filter the criteria by filetype.
72
-
73
- pprint(yt.filter('flv'))
74
-
75
- #[<Video: Sorenson H.263 (.flv) - 240p>,
76
- # <Video: H.264 (.flv) - 360p>,
77
- # <Video: H.264 (.flv) - 480p>]
78
-
79
- # notice that the list is ordered by lowest resolution to highest. If you
80
- # wanted the highest resolution available for a specific file type, you
81
- # can simply do:
82
- print yt.filter('mp4')[-1]
83
- #<Video: H.264 (.mp4) - 720p>
84
-
85
- # you can also get all videos for a given resolution
86
- pprint(yt.filter(res='480p'))
87
-
88
- #[<Video: H.264 (.flv) - 480p>,
89
- #<Video: VP8 (.webm) - 480p>]
90
-
91
- # to select a video by a specific resolution and filetype you can use the get
92
- # method.
93
-
94
- video = yt.get('mp4', '720p')
95
-
96
- # NOTE: get() can only be used if and only if one object matches your criteria.
97
- # for example:
98
-
99
- pprint(yt.videos)
100
-
101
- #[<Video: MPEG-4 Visual (.3gp) - 144p>,
102
- # <Video: MPEG-4 Visual (.3gp) - 240p>,
103
- # <Video: Sorenson H.263 (.flv) - 240p>,
104
- # <Video: H.264 (.flv) - 360p>,
105
- # <Video: H.264 (.flv) - 480p>,
106
- # <Video: H.264 (.mp4) - 360p>,
107
- # <Video: H.264 (.mp4) - 720p>,
108
- # <Video: VP8 (.webm) - 360p>,
109
- # <Video: VP8 (.webm) - 480p>]
110
-
111
- # Notice we have two H.264 (.mp4) available to us.. now if we try to call get()
112
- # on mp4..
113
-
114
- video = yt.get('mp4')
115
- # MultipleObjectsReturned: get() returned more than one object -- it returned 2!
116
-
117
- # In this case, we'll need to specify both the codec (mp4) and resolution
118
- # (either 360p or 720p).
119
-
120
- # Okay, let's download it!
121
- video.download()
122
-
123
- # Downloading: Pulp Fiction - Dancing Scene.mp4 Bytes: 37561829
124
- # 37561829 [100.00%]
125
-
126
- # Note: If you wanted to choose the output directory, simply pass it as an
127
- # argument to the download method.
128
- video.download('/tmp/')
129
- ```
130
-
131
- ## Background
132
-
133
- After missing the deadline to register for PyCon 2012, I decided to write what
134
- became PyTube and crawler to collect all the YouTube links for the talks
135
- on [PyVideos.org](http://pyvideo.org/).
136
-
137
- To avoid having to encode them to mp4 (so I could watch them on my iPhone)
138
- I wrote it so you could specify an encoding format.
139
-
140
- In recently weeks interest has picked up in the project, so I decided to
141
- dedicate more time to further its development and actively maintain it.
142
-
143
- ## Philosophy
144
-
145
- My only real goal for this is to never require any third party dependancies,
146
- to keep it simple and make it reliable.
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
README.rst CHANGED
@@ -1,14 +1,177 @@
1
- PyTube: Download YouTube videos without the bloat
2
- =================================================
 
3
 
4
- PyTube is a YouTube video download Apache2 Licensed library, written in Python,
5
- lightweight, and dependency-free.
6
 
7
- Most existing software for downloading videos from YouTube are: bloatware,
8
- often trialware, brittle and aren't extendable what-so-ever - and if you sit in
9
- terminal all day, I'm sure you'll agree things should not be this way.
10
 
11
- PyTube aims to do one thing and one thing well, provide you an API to simply
12
- download a video and get out of your way.
 
13
 
 
 
14
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ======
2
+ pytube
3
+ ======
4
 
5
+ A lightweight, dependency-free Python library for downloading YouTube Videos.
 
6
 
7
+ Description
8
+ ===========
 
9
 
10
+ Downloading videos from YouTube shouldn't require some bloatware application,
11
+ it's usually a niche condition you want to do so in the first place. So I
12
+ present to you, PyTube!
13
 
14
+ Installation
15
+ ============
16
 
17
+ If you are on Mac OS X or Linux, chances are that one of the following two commands will work for you:
18
+
19
+ Installation
20
+ ============
21
+
22
+ Using PIP via PyPI
23
+
24
+ .. code:: bash
25
+
26
+ pip install pytube==0.1.16
27
+
28
+ Using PIP via Github
29
+
30
+ .. code:: bash
31
+
32
+ pip install git+git://github.com/NFicano/[email protected]#egg=pytube
33
+
34
+ Adding to your ``requirements.txt`` file (run ``pip install -r requirements.txt`` afterwards)
35
+
36
+ .. code:: bash
37
+
38
+ git+ssh://[email protected]/NFicano/[email protected]#egg=pytube
39
+
40
+ Manually via GIT
41
+
42
+ .. code:: bash
43
+
44
+ git clone git://github.com/NFicano/pytube.git pytube
45
+ cd pytube
46
+ python setup.py install
47
+
48
+ Roadmap
49
+ =======
50
+
51
+ The only features I see implementing in the near future are:
52
+
53
+ - refactor console printing into separate command-line utility.
54
+ - Add nosetests
55
+ - Add Sphinx documentation
56
+
57
+ Usage Example
58
+ =============
59
+
60
+ ... code:: python
61
+
62
+ from pytube import YouTube
63
+
64
+ # not necessary, just for demo purposes
65
+ from pprint import pprint
66
+
67
+ yt = YouTube()
68
+
69
+ # Set the video URL.
70
+ yt.url = "http://www.youtube.com/watch?v=Ik-RsDGPI5Y"
71
+
72
+ # Once set, you can see all the codec and quality options YouTube has made
73
+ # available for the perticular video by printing videos.
74
+
75
+ pprint(yt.videos)
76
+
77
+ #[<Video: MPEG-4 Visual (.3gp) - 144p>,
78
+ # <Video: MPEG-4 Visual (.3gp) - 240p>,
79
+ # <Video: Sorenson H.263 (.flv) - 240p>,
80
+ # <Video: H.264 (.flv) - 360p>,
81
+ # <Video: H.264 (.flv) - 480p>,
82
+ # <Video: H.264 (.mp4) - 360p>,
83
+ # <Video: H.264 (.mp4) - 720p>,
84
+ # <Video: VP8 (.webm) - 360p>,
85
+ # <Video: VP8 (.webm) - 480p>]
86
+
87
+ # The filename is automatically generated based on the video title.
88
+ # You can override this by manually setting the filename.
89
+
90
+ # view the auto generated filename:
91
+ print yt.filename
92
+
93
+ #Pulp Fiction - Dancing Scene [HD]
94
+
95
+ # set the filename:
96
+ yt.filename = 'Dancing Scene from Pulp Fiction'
97
+
98
+ # You can also filter the criteria by filetype.
99
+
100
+ pprint(yt.filter('flv'))
101
+
102
+ #[<Video: Sorenson H.263 (.flv) - 240p>,
103
+ # <Video: H.264 (.flv) - 360p>,
104
+ # <Video: H.264 (.flv) - 480p>]
105
+
106
+ # notice that the list is ordered by lowest resolution to highest. If you
107
+ # wanted the highest resolution available for a specific file type, you
108
+ # can simply do:
109
+ print yt.filter('mp4')[-1]
110
+ #<Video: H.264 (.mp4) - 720p>
111
+
112
+ # you can also get all videos for a given resolution
113
+ pprint(yt.filter(res='480p'))
114
+
115
+ #[<Video: H.264 (.flv) - 480p>,
116
+ #<Video: VP8 (.webm) - 480p>]
117
+
118
+ # to select a video by a specific resolution and filetype you can use the get
119
+ # method.
120
+
121
+ video = yt.get('mp4', '720p')
122
+
123
+ # NOTE: get() can only be used if and only if one object matches your criteria.
124
+ # for example:
125
+
126
+ pprint(yt.videos)
127
+
128
+ #[<Video: MPEG-4 Visual (.3gp) - 144p>,
129
+ # <Video: MPEG-4 Visual (.3gp) - 240p>,
130
+ # <Video: Sorenson H.263 (.flv) - 240p>,
131
+ # <Video: H.264 (.flv) - 360p>,
132
+ # <Video: H.264 (.flv) - 480p>,
133
+ # <Video: H.264 (.mp4) - 360p>,
134
+ # <Video: H.264 (.mp4) - 720p>,
135
+ # <Video: VP8 (.webm) - 360p>,
136
+ # <Video: VP8 (.webm) - 480p>]
137
+
138
+ # Notice we have two H.264 (.mp4) available to us.. now if we try to call get()
139
+ # on mp4..
140
+
141
+ video = yt.get('mp4')
142
+ # MultipleObjectsReturned: get() returned more than one object -- it returned 2!
143
+
144
+ # In this case, we'll need to specify both the codec (mp4) and resolution
145
+ # (either 360p or 720p).
146
+
147
+ # Okay, let's download it!
148
+ video.download()
149
+
150
+ # Downloading: Pulp Fiction - Dancing Scene.mp4 Bytes: 37561829
151
+ # 37561829 [100.00%]
152
+
153
+ # Note: If you wanted to choose the output directory, simply pass it as an
154
+ # argument to the download method.
155
+ video.download('/tmp/')
156
+
157
+
158
+ Background
159
+ ==========
160
+
161
+ After missing the deadline to register for PyCon 2012, I decided to write what
162
+ became PyTube and crawler to collect all the YouTube links for the talks
163
+ on PyVideos.
164
+
165
+ To avoid having to encode them to mp4 (so I could watch them on my iPhone)
166
+ I wrote it so you could specify an encoding format.
167
+
168
+ In recently weeks interest has picked up in the project, so I decided to
169
+ dedicate more time to further its development and actively maintain it.
170
+
171
+ Philosophy
172
+ ==========
173
+
174
+ My only real goal for this is to never require any third party dependancies,
175
+ to keep it simple and make it reliable.
176
+
177
+ .. _PyVideos: http://pyvideo.org/