A simple and intuitive youtube picture snapper and video clipper.
- This package
- FFMPEG
- Client#snap
- Client#clip
- Client#duration
Before we start, all code references towards video
will come back to the following snippet.
import YoutubeClient from 'youtube-snapper';
const video = new YoutubeClient(<YoutubeURL>, <YTDLOptions>);
options | type | default | description |
---|---|---|---|
dirname | string | './snaps' | The location of where the file is saved |
filename | string | 'SNAP-<TIMESTAMP>.png' | The base name of the file being saved |
You can take as many pictures as there is seconds in a video (I think) with the following snippet:
const response = await video.snap(
[15, 30, 45, 60, 75, 90, 105, 120, 135, 145],
{ dirname: './snaps' }
);
/* This snippet will take 10 snaps each occuring 15 seconds of each other.
This will automatically create the dirname you assign or the default dirname which is `./snaps`.
After taking all snaps it will return the following:
*/
{
dirname: './snaps',
dirpath: 'D:\\youtube-snapper\\snaps',
files: [
'SNAP-1707580174709_1.png',
'SNAP-1707580174709_2.png',
'SNAP-1707580174709_3.png',
'SNAP-1707580174709_4.png',
'SNAP-1707580174709_5.png',
'SNAP-1707580174709_6.png',
'SNAP-1707580174709_7.png',
'SNAP-1707580174709_8.png',
'SNAP-1707580174709_9.png',
'SNAP-1707580174709_10.png'
],
timestamps: [
15, 30, 45, 60, 75,
90, 105, 120, 135, 150
],
time: 6581,
url: 'https://www.youtube.com/watch?v=Bag1gUxuU0g',
quality: 'highest',
requestOptions: {
headers: {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.101 Safari/537.36'
}
}
}
options | type | default | description |
---|---|---|---|
dirname | string | './clips' | The location of where the file is saved |
filename | string | 'CLIP-<TIMESTAMP>.mp4' | The base name of the file being saved |
This method allows you to clip certain parts of videos. You can also clip the entire video if that's what you want. There is one small issue, currently clips are saved audioless, expect this to change in the future.
const clip = await video.clip(15, 80, { dirname: './clips' });
/*
This will clip starting from 15 seconds until it reaches either the end of the video or when the video is at 80 seconds.
This method will also automatically make the dirname you provide or fallback onto the default dirname which is `./clips`.
The output after creating the clip will look something a like:
*/
{
dirname: './clips',
dirpath: 'D:\\youtube-snapper\\clips',
files: [ 'CLIP-1707580414207.mp4' ],
timestamps: [ 15, 80 ],
time: 13944,
url: 'https://www.youtube.com/watch?v=Bag1gUxuU0g',
quality: 'highest',
requestOptions: {
headers: {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.101 Safari/537.36'
}
}
name | type | default | description |
---|---|---|---|
settings | Record<format, 'unix' | 'full' | 'simple'> | 'simple' | unix: unix timestamp simple: h:m:s full: hh:mm:ss |
Duration will simply return the duration of the video. I added it as I thought I needed full time string but ended up needing nothing more than timestamps. But since it was already there it can now be used as followed:
const durationFull = await video.duration({ format: 'full' });
const durationSimple = await video.duration({ format: 'simple' });
const durationUnix = await video.duration({ format: 'unix' });
// Output:
// full
('00:04:34');
// simple
('4:34');
// unix
274;
- I have noticed that setting the video quality settings on
highest
doesn't always save. If your video did not save trylowest
, mostly music videos had this problem in my testing.