zikwall / m3u-content-parser
Installs: 257
Dependents: 0
Suggesters: 0
Security: 0
Stars: 12
Watchers: 3
Forks: 7
Open Issues: 0
pkg:composer/zikwall/m3u-content-parser
Requires
- php: >=7.1.0
This package is auto-updated.
Last update: 2025-10-06 20:14:43 UTC
README
m3u Content Parser
Minimalistic, functional and easy to use playlist parser
Example usage
use zikwall\m3ucontentparser\M3UContentParser; use zikwall\m3ucontentparser\M3UItem; $parser = new M3UContentParser('https://iptv-org.github.io/iptv/countries/ru.m3u'); $parser->parse(); foreach ($parser->limit(20)->all() as $item) { /** * @var $item M3UItem */ echo $item->getTvgName(), PHP_EOL, $item->getTvgLogo(), PHP_EOL, $item->getTvgUrl(), PHP_EOL, $item->getGroupTitle(), PHP_EOL, $item->getId(), PHP_EOL; $item->getGroupId(), PHP_EOL, $item->getLanguage(), PHP_EOL, $item->getCountry(); }
More example
// rewrite current m3u content foreach ($parser->all() as $item) { /** * @var $item M3UItem */ $item ->replaceTvgName('UNNAMED ITEM') ->replaceTvgLogo('NEW LOGO URL') ->replaceTvgUrl('CHANE NEW URL'); } echo $parser->rewriteM3UFile(); output example: #EXTM3U url-tvg="http://iptvx.one/epg/epg.xml.gz" #EXTINF:-1 group-title="Новости",UNNAMED ITEM CHANE NEW URL #EXTINF:-1 group-title="Новости",UNNAMED ITEM CHANE NEW URL
Segment Parser
use zikwall\m3ucontentparser\SegmentM3U; $segmant = new SegmentM3U(); $fragment->attachSource('examples/segments/index.m3u8')->parse(); print_r($segment->getFragments()); print_r($segment->getSegments()); print_r($segment->getTime()); var_dump($segment->getIsEnding());
Complex sample
use zikwall\m3ucontentparser\M3UContentParser; use zikwall\m3ucontentparser\SegmentM3U; use zikwall\m3ucontentparser\M3UItem; use zikwall\m3ucontentparser\FragmentM3UItem; $parser = new M3UContentParser('https://iptv-org.github.io/iptv/countries/ru.m3u'); $parser->parse(); foreach ($parser->limit(10)->offset(10)->all() as $item) { /** * @var $item M3UItem */ $segment = new SegmentM3U(); $segment->attachSource($item->getTvgUrl())->parse(); if ($segment->getIsFragmentSource() === true) { /** * @var $fragment FragmentM3UItem */ echo $segment->getCleanSource(), PHP_EOL; foreach ($segment->getFragments() as $fragment) { $subSegment = new SegmentM3U(); $subSegment->attachSource($segment->getNewSource($fragment->fragment))->parse(); echo $segment->getNewSource($fragment->fragment), PHP_EOL; } continue; } // ... conventional segment processing foreach ($segment->getSegments() as $segmentItem) { /** * @var $segmentItem SegmentM3UItem */ echo $segment->getNewSource($segmentItem->segment), PHP_EOL; // display generated chunk links // http://xxxxx/stream8/stream2020_2_23_13_44_7-65006.ts // http://xxxxx/stream8/stream2020_2_23_13_44_18-65007.ts // http://xxxxx/stream8/stream2020_2_23_13_44_28-65008.ts // ... } }
Seemed complicated? It is even easier!
$segment = new SegmentM3U(); $segment->attachSource('http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/variable.m3u8')->parse(); if ($segment->getIsFragmentSource() === true) { $segments = []; foreach ($segment->getFragments() as $fragment) { $subSegment = new SegmentM3U(); $subSegment->attachSource($segment->getNewSource($fragment->fragment))->parse(); echo $segment->getNewSource($fragment->fragment), PHP_EOL; /** * Get total duration */ echo sprintf('Duration is: %0.2f seconds', $subSegment->getDuration()), PHP_EOL; foreach ($subSegment->getSegments() as $sgmt) { echo $subSegment->getNewSource($sgmt->segment), PHP_EOL; } } /** * Original: http://mhd.xxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/variable.m3u8 * Cleaning: http://mhd.xxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vl2w/ * * Return stream links (FRAGMENTS): * - http://mhd.xxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vl2w/playlist.m3u8 // LOW * - http://mhd.xxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vm2w/playlist.m3u8 // MIDDLE * - http://mhd.xxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/playlist.m3u8 // HIGH */ /** * Each all fragments return SegmentM3UItem Object * http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/playlist.m3u8 * * Array * ( * [0] => zikwall\m3ucontentparser\SegmentM3UItem Object * ( * [duration] => 6 * [segment] => segment-1582439833-08914115.ts * ) * [1] => zikwall\m3ucontentparser\SegmentM3UItem Object * ( * [duration] => 6 * [segment] => segment-1582439833-08914116.ts * ) * ... */ /** * Convert to valid links, example: * * http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/segment-1582439833-08914207.ts * http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/segment-1582439833-08914208.ts * http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/segment-1582439833-08914209.ts * http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/segment-1582439833-08914210.ts * http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/segment-1582439833-08914211.ts * http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/segment-1582439833-08914212.ts * http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/segment-1582439833-08914213.ts * http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/segment-1582439833-08914214.ts * http://mhd.xxxxxxx.tv/p/k5OqlMqeQONvANUJOq9GFQ,1582553567/streaming/ntvnn/324/vh1w/segment-1582439833-08914215.ts */ }
Even easier
$segment = new SegmentM3U(); $segment->attachSource('http://hls.kinoplayer.co/hls/PaSSagir.iz.SanFranCissko.2O17.HDRip/playlist.m3u8')->parse(); foreach ($segment->getSegments() as $sgmt) { echo $segment->getNewSource($sgmt->segment), PHP_EOL; } echo sprintf('Duration is: %0.2f seconds', $segment->getDuration()), PHP_EOL;
More examples Segment parser
You can try different combinations of examples yourself
API
- The parser constructor accepts a link or file path:
$parser = new M3UContentParser('https://iptv-org.github.io/iptv/countries/ru.m3u');
- Parsing is called by the same method:
$parser->parse();
Methods in m3u parser
-
getCahce() -
getResfresh() -
getTvgUrl() -
limit(int) -
offset(int) -
all() -
getItems() -
rewriteM3UFile()
Methods in m3u item object
-
getId() -
getTvgId() -
getTvgName() -
getTvgUrl() -
getTvgLogo() -
getTvgShift() -
getGroupId() -
getGroupTitle() -
getExtGrp() -
getCensored() -
getLanguage() -
getCountry() -
getAudioTrack() -
getAudioTrackNum() -
getExtraAttributes()
API Segment
-
getFragments()return array of tracks with props -
getSegments()return array of segments in track -
getTime()return array of timecodes: hours, minutes, seconds and string format HH:MM:SS & original value -
getDuration()return float value duration of seconds -
getIsEnding()return bool value, indicates whether the stream has an ending or not -
getIsFragmentSource() -
getNewSource(string $sub_source) -
getHashHeaders() -
getDirtyItems()
Installation
composer require zikwall/m3u-content-parser
Develop Mode
{
"minimum-stability": "dev",
"repositories": [
{
"type": "git",
"url": "https://github.com/zikwall/m3u-content-parser.git"
}
],
"require": {
"zikwall/m3u-content-parser": "dev-master"
}
}
Questions?
For all questions and suggestions - welcome to Issues