findologic/libflexport
最新稳定版本:v3.1.1
Composer 安装命令:
composer require findologic/libflexport
包简介
FINDOLOGIC export toolkit for XML and CSV data export
README 文档
README
Table of Contents
Synopsis
This project provides an export library for XML and CSV generation according to the FINDOLOGIC export patterns.
- XML https://docs.findologic.com/doku.php?id=xml_export_documentation:XML_2_format
- CSV https://docs.findologic.com/doku.php?id=csv_export_documentation:csv_2_format
- Note that CSV support is still relatively new. Consider it beta-quality.
Export recommendation
Using the XML export is recommended by FINDOLOGIC. The XML is easier to read and has some advantages over the CSV export like:
- No encoding issues as the encoding attribute is provided in the XML response
<?xml version="1.0" encoding="UTF-8"?>. - Validation is more reliable.
- Simple escaping of content using the
<![CDATA[...]]>-tag. - Standardized structure.
- Dynamically extract the products from the database via
startandcountparameter in the url. - No limited file size for XML because of pagination.
- Using multiple groups per product.
The key advantage for CSV is that it is possible to use way more groups than for XML. On the other hand:
- Groups only regulate visibility - it's not possible to show different values per group.
- The format is prone to encoding issues if non-UTF-8 data is fed into it.
- Total export size is limited by file size, while XML pagination theoretically allows exports of arbitrary size.
Limitations
Currently, only input text encoded in UTF-8 is supported. To use this library with other types of encoding, one of the following is necessary:
- Convert all text to UTF-8 prior to passing it to
libflexport. - Use the XML exporter and modify the library to change the XML header to contain the required encoding.
- FINDOLOGIC is capable of handling most encodings, but only with XML.
Basic usage
Setup
- Include as composer dependency using
composer require findologic/libflexport - Load
./vendor/autoload.phpinto the project
XML export
require_once './vendor/autoload.php'; use FINDOLOGIC\Export\Exporter; $exporter = Exporter::create(ExporterType::XML); $item = $exporter->createItem('123'); $item->addName('Test'); $item->addUrl('http://example.org/test.html'); $item->addPrice(13.37); // Alternative long form: // $name = new Name(); // $name->setValue('Test'); // $item->setName($name); // $url = new Url(); // $url->setValue('http://example.org/test.html'); // $item->setUrl($url); // $price = new Price(); // $price->setValue(13.37); // $item->setPrice($price); $xmlOutput = $exporter->serializeItems([$item], 0, 1, 1);
CSV export
require_once './vendor/autoload.php'; use FINDOLOGIC\Export\Exporter; $exporter = Exporter::create(ExporterType::CSV); $item = $exporter->createItem('123'); $item->addPrice(13.37); $item->addName('Test'); $item->addUrl('http://example.org/test.html'); // Alternative long form: // $name = new Name(); // $name->setValue('Test'); // $item->setName($name); // $url = new Url(); // $url->setValue('http://example.org/test.html'); // $item->setUrl($url); // $price = new Price(); // $price->setValue(13.37); // $item->setPrice($price); // Date is mandatory for CSV. $item->addDateAdded(new \DateTime()); $csvOutput = $exporter->serializeItems([$item], 0, 1, 1);
Examples
For more specific examples, please have a look at the examples directory.
Compatibility
The status of the major versions of libflexport is outlined below. Version numbers generally follow semantic versioning principles.
| Version | Branch | PHP support | Receives bug fixes | Receives enhancements | End of life |
|---|---|---|---|---|---|
| 3.X | develop | >=8.1 | ✔️ | ✔️ | Not in the foreseeable future |
| 2.X | 2.x | >=7.1 | ✔️ | ❌ | Not in the foreseeable future |
| 1.X | 1.x | 5.6 - 7.3 | ✔️ | ❌ | TBD |
| 0.X | ❌ | 5.6 - 7.0 | ❌ | ❌ | 2017-11-24 |
All versions will most likely remain available for as long as the infrastructure to do so exists.
Contributors
See contribution guide.
统计信息
- 总下载量: 163.97k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 5
- 点击次数: 0
- 依赖项目数: 3
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-01-04