Getting metadata from videos using @remotion/media-parser
Using @remotion/media-parser
, you can get metadata from a variety of video formats: MP4, MKV, AVI, WebM and MOV.
Getting metadata from a URL
Specify the fields
you would like to read and the URl as src
.
This works in the browser as well as in Node.js and Bun.
Parsing a hosted videotsx
import {parseMedia } from '@remotion/media-parser';constresult = awaitparseMedia ({src : 'https://example.com/my-video.mp4',fields : {durationInSeconds : true,dimensions : true,},});console .log (result .durationInSeconds ); // 10console .log (result .dimensions ); // {width: 1920, height: 1080}
Getting metadata from a local path
Use nodeReader
to read a file from a filesystem.
This can be used in Node.js and Bun.
Parsing a video from a file pathtsx
import {parseMedia } from '@remotion/media-parser';import {nodeReader } from '@remotion/media-parser/node';constresult = awaitparseMedia ({src : '/tmp/video.mp4',fields : {durationInSeconds : true,dimensions : true,},reader :nodeReader ,});console .log (result .durationInSeconds ); // 10console .log (result .dimensions ); // {width: 1920, height: 1080}
Getting metadata from a File
If you take user uploads in the browser, they will be in the form of a File
.
Use webFileReader
to read a video from a File
.
Parsing a video from a file pathtsx
import {parseMedia } from '@remotion/media-parser';import {webFileReader } from '@remotion/media-parser/web-file';// You would get this from a `<input type="file">`constfile = newFile ([], 'video.mp4');constresult = awaitparseMedia ({src :file ,fields : {durationInSeconds : true,dimensions : true,},reader :webFileReader ,});console .log (result .durationInSeconds ); // 10console .log (result .dimensions ); // {width: 1920, height: 1080}
Available fields
You can read the duration, the dimensions, the framerate, the container format, the codecs, the ID3 tags and more information from a video file.
See Fields for a complete list.
Getting metadata as soon as possible
Parsing a video from a Filetsx
import {parseMedia } from '@remotion/media-parser';constresult = awaitparseMedia ({src : 'https://example.com/my-video.mp4',fields : {durationInSeconds : true,dimensions : true,},onDurationInSeconds : (durationInSeconds ) => {console .log (durationInSeconds ); // 10},});console .log (result .dimensions ); // {width: 1920, height: 1080}