(previously, subtitle-parsing-tool)
Zero-dependency, subtitle parser written in TypeScript. Parses subtitle files and generates a collection of timed objects.
Now includes typings!
- SRT
- WebVTT
npm i simple-subtitle-parser
import { parser } from 'simple-subtitle-parser';
With types
import { parser, Cue, Format } from 'simple-subtitle-parser';
const parser = require('simple-subtitle-parser');
parser(format: Format, rawText: string)
format
Denotes the format of the subtitles to be parsed. Accepts 2 values:
- SRT
- WEBVTT
rawText
The raw data for the subtitles to parse.
A Promise
that resolves to an array of Cue
type objects
extractFormatFromFileName(fileName: string);
fileName
The filename
An object of the following shape:
{
extension: string;
format: Format
}
The following types are available:
An exported object of strings which correspond to the supported formats
enum Format
Format.Srt
Format.WebVtt
Format.Unsupported
interface Cue
A subtitle time encoded object of the following shape:
{
sequence: number;
startTime: Time;
endTime: Time;
text: string[];
}
interface Time
Each time formatted object is encoded in the following way:
{
hours: number;
minutes: number;
seconds: number;
ms: number;
totals: {
inSeconds: number;
};
}