Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/imelgrat/opml-parser
A PHP-based OPML Parser Class. Extracts the properties of content from OPML files
https://github.com/imelgrat/opml-parser
composer composer-package extract opml opml-files opml-outline opml-parser opml-to-json parser parsing-engine parsing-library php rss rss-feed xml xml-parser
Last synced: 2 months ago
JSON representation
A PHP-based OPML Parser Class. Extracts the properties of content from OPML files
- Host: GitHub
- URL: https://github.com/imelgrat/opml-parser
- Owner: imelgrat
- License: mit
- Created: 2016-09-12T17:55:55.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2018-12-12T11:39:36.000Z (about 6 years ago)
- Last Synced: 2024-11-16T02:06:37.100Z (2 months ago)
- Topics: composer, composer-package, extract, opml, opml-files, opml-outline, opml-parser, opml-to-json, parser, parsing-engine, parsing-library, php, rss, rss-feed, xml, xml-parser
- Language: PHP
- Size: 725 KB
- Stars: 8
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
OPML Parser
==================[![GitHub license](https://img.shields.io/github/license/imelgrat/opml-parser.svg?style=flat-square)](https://github.com/imelgrat/opml-parser/blob/master/LICENSE)
[![GitHub release](https://img.shields.io/github/release/imelgrat/opml-parser.svg?style=flat-square)](https://github.com/imelgrat/opml-parser/releases)
[![Total Downloads](https://poser.pugx.org/imelgrat/opml-parser/downloads)](https://packagist.org/packages/imelgrat/opml-parser)
[![GitHub issues](https://img.shields.io/github/issues/imelgrat/opml-parser.svg?style=flat-square)](https://github.com/imelgrat/opml-parser/issues)
[![GitHub stars](https://img.shields.io/github/stars/imelgrat/opml-parser.svg?style=flat-square)](https://github.com/imelgrat/opml-parser/stargazers)OPML Parser Class: Extract the properties of content from OPML files.
A file with the OPML file extension is an Outline Processor Markup Language file. It's saved using the XML format, and is used to exchange information between applications regardless of the operating system.
The OPML file format is often seen used as the import/export format for RSS feed reader programs. Since a file of this format can hold a collection of RSS subscription information, it's the ideal format for backing up or sharing RSS feeds.
The class retrieves local or remote OPML file and parses it to extract its content into a PHP iterator. Each of the iterator elements contains the URLs of the listed content as well all other the properties of each content entry such as: name, link target, description, RSS feed, creation date and content type (RSS, HTML, song, booklist, etc..).Developed by [Ivan Melgrati](https://twitter.com/imelgrat)
Requirements
------------* PHP >= 5.3.0
Installation
------------### Composer
The recommended installation method is through
[Composer](http://getcomposer.org/), a dependency manager for PHP. Just add
`imelgrat/opml-parser` to your project's `composer.json` file:```json
{
"require": {
"imelgrat/opml-parser": "*"
}
}[More details](http://packagist.org/packages/imelgrat/opml-parser) can
be found over at [Packagist](http://packagist.org).### Manually
1. Copy `src/opml-parser.php` to your codebase, perhaps to the `vendor`
directory.
2. Add the `OPML_Parser` class to your autoloader or `require` the file
directly.Then, in order to use the OPML class, you need to invoke the "use" operator to bring the class into skope.
```php
ParseLocation('http://www.bbc.co.uk/podcasts.opml', null);// Walk through each item in the same way as we would if $parser were a string (thanks to the Iterator interface)
foreach ($parser as $key => $item)
{
echo "Item: " . $key . '
- ';
- ' . '' . $attribute . ':' . $value . ' ';
foreach ($item as $attribute => $value)
{
echo '
}
echo '
echo '
';
}
?>
```
Feedback
--------
Please open an issue to request a feature or submit a bug report. Or even if
you just want to provide some feedback, I'd love to hear. I'm also available on
Twitter as [@imelgrat](https://twitter.com/imelgrat).
Contributing
------------
1. Fork it.
2. Create your feature branch (`git checkout -b my-new-feature`).
3. Commit your changes (`git commit -am 'Added some feature'`).
4. Push to the branch (`git push origin my-new-feature`).
5. Create a new Pull Request.