All Notable changes to Csv
will be documented in this file
- Nothing
- Nothing
- Nothing
- Nothing
- Improve package exception throwing by adding new exceptions classes that extends
the
League\Csv\Exception
exception marker class #360, #361 feature proposed and developed by Darren MillerLeague\Csv\UnavailableFeature
League\Csv\InvalidArgument
League\Csv\SyntaxError
- Nothing
- bug fix
bom_match
function see issue #363 resolved based on PR from Jerry Martinez - bug fix
delemiter_detect
function see issue #366
- Nothing
- Nothing
- Nothing
- Nothing
-
Adding support for controlling empty record presence in
Reader::getRecords
return value.Reader::includeEmptyRecords
Reader::skipEmptyRecords
Reader::isEmptyRecordsIncluded
-
Adding support for controlling Input BOM usage in the library:
AbstractCsv::skipInputBOM
AbstractCsv::includeInputBOM
AbstractCsv::isInputBOMIncluded
- Nothing
EmptyEscapeParser::parse
no longer auto skip empty records
- Nothing
XMLConverter::import
see #348 thanks @kusabi- Support for
thead
,tfoot
andtbody
inHTMLConverter::convert
via the addition of protected methodsHTMLConverter::addHTMLAttributes
andHTMLConverter::appendHeaderSection
#348 thanks @kusabi
- Nothing
- Internal improvement in
Reader
dockblock thanks @ghobaty. - Improve strict comparison when using
preg_match
. - Improve CSV control in
Stream
.
- Nothing
- Nothing
- Nothing
AbstractCSV::chunk
see #325 remove CSV flags from the Stream class to avoid infinite loop.- Internal improve
HTMLConverter
.
- Nothing
- Supports for PHP7.4 empty string for the escape character
- Supports for empty string for the escape character with a polyfill for PHP7.4- versions.
AbstractCSV::getPathname
see #321 thanks @tomkyle
League\Csv\RFC4180Field
useAbstractCSV::setEscape
method with an empty string instead.
-
AbstractCSV::__construct
correctly initializes properties -
AbstractCSV::createFromString
named constructor default argument is now the empty string -
AbstractCSV::setEscape
now accepts the empty string likefputcsv
andfgetcsv
-
Writer::insertOne
fixes throwing exception when record can not be inserted -
XMLConverter
convert to string the record value to avoid PHP warning onnull
value -
Internal
Stream::createFromString
named constructor default argument is now the empty string -
Internal
Stream::fwrite
improved -
Internal
Stream::__destruct
no longer emit warning on invalid stream filter removal. -
Internal
Stream::seek
returns0
if the seeked position0
is valid see #321 thanks @HaozhouChen -
Reader:getHeader
when the record is an empty line.
- Nothing
- Nothing
- Nothing
Writer::setFlushThreshold
should accept 1 as an argument #289CharsetConverter::convert
should not try to convert numeric value #287
- Nothing
- Nothing
- Nothing
Writer::insertOne
allow empty array to be added to the CSV (allow inserting empty row)- Removed all return type from named constructor see #285
- Added PHPStan for static code analysis
- Nothing
- Nothing
- Nothing
is_iterable
polyfill for PHP7.0Reader::getHeader
no longer throws exception because of a bug in PHP7.2+ issue #279
- Nothing
- Nothing
- Nothing
-
issue with
error_get_last
usage when using a modified PHP error handler see #254 - fixed by @csiszarattila -
Removed seekable word from Stream exception messages.
- Nothing
- Support for non seekable stream. When seekable feature are required an exceptions will be thrown.
League\Csv\EncloseField
to force enclosure insertion on every field. #269League\Csv\EscapeFormula
a League CSV formatter to prevent CSV Formula Injection in Spreadsheet programs.League\Csv\RFC4180Field::addTo
accept an option$replace_whitespace
argument to improve RFC4180 compliance.League\Csv\Abstract::getContent
to replaceLeague\Csv\Abstract::__toString
. The__toString
method may trigger a Fatal Error with non seekable stream, instead you are recommended to used the newgetContent
method which will trigger an exception instead.
League\Csv\Abstract::__toString
useLeague\Csv\Abstract::getContent
instead. the__toString
triggers a Fatal Error when used on a non-seekable CSV document. use thegetContent
method instead which will trigger an exception instead.
- Bug fixes headers from AbstractCsv::output according to RFC6266 #250
- Make sure the internal source still exists before closing it #251
- Make sure the
Reader::createFromPath
default open mode isr
see #258 and #266
- Nothing
- Nothing
- Nothing
- CSV controls not applied when calling Writer::insertOne
- Nothing
- Improved CSV Records selection
League\Csv\Reader::getRecords
to access all CSV recordsLeague\Csv\Statement
provides a constraint builder to select CSV records.League\Csv\ResultSet
represents the result set of the selected CSV records.League\Csv\delimiter_detect
function to detect CSV delimiter character
- Improved CSV document header selection.
League\Csv\Reader::getHeader
League\Csv\Reader::getHeaderOffset
League\Csv\Reader::setHeaderOffset
- Improved CSV Records conversion
League\Csv\CharsetConverter
converts CSV records charset.League\Csv\XMLConverter
converts CSV records into DOMDocumentLeague\Csv\HTMLConverter
converts CSV records into HTML table.
- Improved Exception handling
League\Csv\Exception
the default exceptionLeague\Csv\CannotInsertRecord
- Improved CSV document output
League\Csv\AbstractCsv::chunk
method to output the CSV document in chunkLeague\Csv\bom_match
function to detect BOM sequence in a given stringLeague\Csv\ByteSequence
interface to decoupled BOM sequence from CSV documents
- Improved CSV records column count consistency on insertion
League\Csv\ColumnConsistency
- Improved CSV document flush mechanism on insertion
League\Csv\Writer::setFlushThreshold
League\Csv\Writer::getFlushThreshold
- Improve RFC4180 compliance
League\Csv\RFC4180Field
to format field according to RFC4180 rules
- Nothing
-
Improved CSV record insertion
League\Csv\Writer::insertOne
only accepts an array and returns a integerLeague\Csv\Writer::insertAll
only accepts an iterable of array and returns an integer
-
Normalized CSV offset returned value
League\Csv\Reader::fetchColumn
always returns the CSV document original offset.
examples
directoryPHP5
support- The following method is removed because The BOM API is simplified:
League\Csv\AbstractCsv::stripBOM
- All conversion methods are removed in favor of the conversion classes:
League\Csv\Writer::jsonSerialize
League\Csv\AbstractCsv::toHTML
League\Csv\AbstractCsv::toXML
League\Csv\AbstractCsv::setInputEncoding
League\Csv\AbstractCsv::getInputEncoding
- The following methods are removed because the PHP stream filter API is simplified:
League\Csv\AbstractCsv::isActiveStreamFilter
League\Csv\AbstractCsv::setStreamFilterMode
League\Csv\AbstractCsv::appendStreamFilter
League\Csv\AbstractCsv::prependStreamFilter
League\Csv\AbstractCsv::removeStreamFilter
League\Csv\AbstractCsv::clearStreamFilters
- The following methods are removed because switching between connections is no longer possible:
League\Csv\AbstractCsv::newReader
League\Csv\AbstractCsv::newWriter
League\Csv\Reader::getNewline
League\Csv\Reader::setNewline
- The Exception mechanism is improved thus the following class is removed:
League\Csv\Exception\InvalidRowException
;
- The CSV records filtering methods are removed in favor of the
League\Csv\Statement
class:League\Csv\AbstractCsv::addFilter
,League\Csv\AbstractCsv::addSortBy
,League\Csv\AbstractCsv::setOffset
,League\Csv\AbstractCsv::setLimit
;
- CSV records selecting API methods is simplified:
League\Csv\Reader::each
League\Csv\Reader::fetch
League\Csv\Reader::fetchAll
League\Csv\Reader::fetchAssoc
League\Csv\Reader::fetchPairsWithoutDuplicates
- Formatting and validating CSV records on insertion is simplified, the following methods are removed:
League\Csv\Writer::hasFormatter
League\Csv\Writer::removeFormatter
League\Csv\Writer::clearFormatters
League\Csv\Writer::hasValidator
League\Csv\Writer::removeValidator
League\Csv\Writer::clearValidators
League\Csv\Writer::getIterator
- The following Formatters and Validators classes are removed from the package:
League\Csv\Plugin\SkipNullValuesFormatter
League\Csv\Plugin\ForbiddenNullValuesValidator
League\Csv\Plugin\ColumnConsistencyValidator
replace byLeague\Csv\ColumnConsistency
League\Csv\Writer
no longers implements theIteratorAggregate
interfaceLeague\Csv\AbstractCsv::fetchDelimitersOccurrence
is removed replace byLeague\Csv\delimiter_detect
function
- None
- None
Writer::insertOne
was silently failing when inserting record in a CSV document in non-writing mode.- bug fix docblock
- None
- Nothing
- Nothing
- internal
Reader::getRow
when using aStreamIterator
issue #213 - Removed
@deprecated
from selected methods issue #208
- Nothing
AbstractCsv::createFromStream
to enable working with resource stream issue #202
League\Csv\AbstractCsv::stripBom
League\Csv\Reader::getOffset
League\Csv\Reader::getLimit
League\Csv\Reader::getSortBy
League\Csv\Reader::getFilter
League\Csv\Reader::setOffset
League\Csv\Reader::setLimit
League\Csv\Reader::addSortBy
League\Csv\Reader::addFilter
League\Csv\Reader::fetch
League\Csv\Reader::each
League\Csv\Reader::fetchPairsWithoutDuplicates
League\Csv\Reader::fetchAssoc
League\Csv\Writer::removeFormatter
League\Csv\Writer::hasFormatter
League\Csv\Writer::clearFormatters
League\Csv\Writer::removeValidator
League\Csv\Writer::hasValidator
League\Csv\Writer::clearValidators
League\Csv\Writer::jsonSerialize
League\Csv\Writer::toHTML
League\Csv\Writer::toXML
- Nothing
- Nothing
- Nothing
- Nothing
- BOM filtering fix issue #184
AbstractCsv::BOM_UTF32_LE
value fixed
- Nothing
- Nothing
- Nothing
getInputBOM
method name is now consistent everywhere in the API PR #171- preserve fileObject CSV controls commit #8a20c56
- Change
output
method header content-type value totext/csv
PR #175
- Nothing
- The package now includes its own autoloader.
Ouput::getInputEncoding
Ouput::setInputEncoding
Ouput::getEncodingFrom
replaced byOuput::getInputEncoding
Ouput::setEncodingFrom
replaced byOuput::setInputEncoding
- Stream Filters are now url encoded before usage issue #72
- All internal parameters are now using the snake case format
- Nothing
Reader::fetchPairs
Reader::fetchPairsWithoutDuplicates
- Nothing
Reader::fetchColumn
andReader::fetchAssoc
now returnIterator
Reader::fetchAssoc
callable argument expects an indexed row using the submitted keys as its first argumentReader::fetchColumn
callable argument expects the selected column value as its first argument- Default value on
setOutputBOM
is removed AbstractCsv::getOutputBOM
always return a stringAbstractCsv::getInputBOM
always return a string
Controls::setFlags
Controls::getFlags
Controls::detectDelimiterList
QueryFilter::removeFilter
QueryFilter::removeSortBy
QueryFilter::hasFilter
QueryFilter::hasSortBy
QueryFilter::clearFilter
QueryFilter::clearSortBy
Reader::query
- The
$newline
argument fromAbstractCsv::createFromString
Reader::fetch
replacesLeague\Csv\Reader::query
for naming consistencyControls::fetchDelimitersOccurrence
to replaceControls::detectDelimiterList
the latter gives erronous results
Controls::detectDelimiterList
Reader::query
- The
$newline
argument fromAbstractCsv::createFromString
- Streamming feature no longer trim filter name argument issue #122
- Fix default
SplFileObject
flags usage PR #130 AbstractCsv::createFromString
no longer trim the submitted string issue #132
- Nothing
- Nothing
- Nothing
- Enclosures should be removed when a BOM sequence is stripped issue #102
- Nothing
- Nothing
- Nothing
SplFileObject
flags were not always applied using query filter issue #99
- Nothing
stripBOM
query filtering method to ease removing the BOM sequence when querying the CSV document.- All query filters are now accessible in the
Writer
class for conversion methods.
- Nothing
- Internal code has been updated to take into account issue #68479
setFlags
on conversion methods SplFileObject default flags areSplFileObject::READ_AHEAD|SplFileObject::SKIP_EMPTY
insertOne
now takes into account the escape character when modified after the first insert.
- Nothing
- Nothing
- Nothing
setFlags
:SplFileObject::DROP_NEW_LINE
can be remove usingsetFlags
method.
- Nothing
- A new flexible mechanism to format and validate a row before its insertion by adding
Writer::addFormatter
to add a formatter to theWriter
objectWriter::removeFormatter
to remove an already registered formatterWriter::hasFormatter
to detect the presence of a formatterWriter::clearFormatters
to clear all registered formatterWriter::addValidator
to add a validator to theWriter
objectWriter::removeValidator
to remove an already registered validatorWriter::hasValidator
to detect the presence of a validatorWriter::clearValidators
to clear all registered validatorLeague\Csv\Exception\InvalidRowException
exception thrown when row validation failed
- Classes to maintain removed features from the
Writer
classLeague\Csv\Plugin\ColumnConsistencyValidator
to validate column consistency on insertionLeague\Csv\Plugin\ForbiddenNullValuesValidator
to validatenull
value on insertionLeague\Csv\Plugin\SkipNullValuesFormatter
to formatnull
value on insertion
- Nothing
jsonSerialize
,toXML
andtoHTML
output can be modified usingReader
query options methods.AbstractCSV::detectDelimiterList
index keys now represents the occurrence of the found delimiter.getNewline
andsetNewline
are accessible on theReader
class too.- the named constructor
createFromString
now accepts the$newline
sequence as a second argument to specify the last added new line character to better work with interoperability. - Default value on CSV controls setter methods
setDelimiter
,setEnclosure
andsetEscape
are removed - Default
SplFileObject
flags value is nowSplFileObject::READ_CSV|SplFileObject::DROP_NEW_LINE
- All CSV properties are now copied when using
newReader
andnewWriter
methods - BOM addition on output improved by removing if found the existing BOM character
- the
AbstractCSV::output
method now returns the number of bytes send to the output buffer Reader::fetchColumn
will automatically filter out non existing values from the return array
- Setting
ini_set("auto_detect_line_endings", true);
is no longer set in the class constructor. Mac OS X users must explicitly set this ini options in their script. Writer
andReader
default constructor are removed from public API in favor of the named constructors.- All
Writer
methods and constant related to CSV data validation and formatting before insertionWriter::getNullHandlingMode
Writer::setNullHandlingMode
Writer::setColumnsCount
Writer::getColumnsCount
Writer::autodetectColumnsCount
Writer::NULL_AS_EXCEPTION
Writer::NULL_AS_EMPTY
Writer::NULL_AS_SKIP_CELL
AbstractCSV::setOutputBOM
AbstractCSV::getOutputBOM
AbstractCSV::getInputBOM
to manage BOM character with CSV.
- Nothing
- Nothing
- Nothing
Writer::setNewline
,Writer::getNewline
to control the newline sequence character added at the end of each CSV row.
- Nothing
- Nothing
- Nothing
Reader::fetchAssoc
now also accepts an integer as first argument representing a row index.
- Nothing
- Nothing
- Nothing
- Nothing
- Nothing
- Bug Fixed
detectDelimiterList
- Nothing
- Stream Filter API in
League\Csv\AbstractCsv
- named constructors
createFromPath
andcreateFromFileObject
inLeague\Csv\AbstractCsv
to ease CSV object instantiation detectDelimiterList
inLeague\Csv\AbstractCsv
to replace and remove the use ofRuntimeException
indetectDelimiter
setEncodingFrom
andsetDecodingFrom
inLeague\Csv\AbstractCsv
to replacesetEncoding
andgetEncoding
for naming consistencynewWriter
andnewReader
methods inLeague\Csv\AbstractCsv
to replaceWriter::getReader
andReader::getWriter
- Nothing
League\Csv\Reader::each
more strict$callable
MUST returnstrue
League\Csv\AbstractCsv::detectDelimiter
League\Csv\AbstractCsv::setEncoding
andLeague\Csv\AbstractCsv::getEncoding
League\Csv\Reader::setSortBy
League\Csv\Reader::setFilter
League\Csv\Reader::getWriter
League\Csv\Writer::getReader
League\Csv\Reader::fetchCol
League\Csv\Writer::setColumnsCount
,League\Csv\Writer::getColumnsCount
,League\Csv\Writer::autodetectColumnsCount
to enable column consistency in writer modeLeague\Csv\Reader::fetchColumn
replacesLeague\Csv\Reader::fetchCol
for naming consistency
League\Csv\Reader::fetchCol
- Nothing
- Nothing
- Nothing
- Nothing
$open_mode
default tor+
inLeague\Csv\AbstractCsv
constructors
- Nothing
League\Csv\Writer::setNullHandlingMode
andLeague\Csv\Writer::getNullHandlingMode
to handlenull
value
- Nothing
setting ini_set("auto_detect_line_endings", true);
no longer needed for Mac OS
- Nothing
League\Csv\Reader::addSortBy
,League\Csv\Reader::removeSortBy
,League\Csv\Reader::hasSortBy
,League\Csv\Reader::clearSortBy
to improve sortingLeague\Csv\Reader::clearFilter
to align extract filter capabilities to sorting capabilities
League\Csv\Reader::setSortBy
replaced by a better implementation
League\Csv\Reader::setOffset
now default to 0;League\Csv\Reader::setLimit
now default to -1;detectDelimiter
bug fixes
- Nothing
League\Csv\Reader::each
to ease CSV import dataLeague\Csv\Reader::addFilter
,League\Csv\Reader::removeFilter
,League\Csv\Reader::hasFilter
to improve extract filter capabilitiesdetectDelimiter
method toLeague\Csv\AbstractCsv
to sniff CSV delimiter character.
League\Csv\Reader::setFilter
replaced by a better implementation
- Nothing
- Nothing
- Change namespace from
Bakame\Csv
toLeague\Csv
- Nothing
- Nothing
- Nothing
$open_mode
validation is done by PHP internals directly
- Nothing
toXML
method to transcode the CSV into a XML inBakame\Csv\AbstractCsv
toHTML
method bug inBakame\Csv\AbstractCsv
output
method accepts an optional$filename
argumentBakame\Csv\Reader::fetchCol
default to$columnIndex = 0
Bakame\Csv\Reader::fetchOne
default to$offset = 0
- Move from
PSR-0
toPSR-4
to autoload the library
Bakame\Csv\Reader
methods fixedjsonSerialize
bug fixed
getEncoding
andsetEncoding
methods toBakame\Csv\AbstractCsv
Bakame\Csv\Writer::insertOne
takes into account CSV controlstoHTML
method takes into account encoding
Bakame\Csv\Writer
Bakame\Csv\Writer
andBakame\Csv\Reader
extendBakame\Csv\AbstractCsv
- Nothing
Bakame\Csv\Reader::fetchOne
is no longer deprecatedBakame\Csv\Reader::fetchCol
no longer accepts a third parameter$strict
Bakame\Csv\Codec
now the library is composer of 2 main classesBakame\Csv\Reader::getFile
Bakame\Csv\Reader::fetchValue
Bakame\Csv\Reader
no longer implements theArrayAccess
interface
Bakame\Csv\Reader
implementsIteratorAggregate
InterfaceBakame\Csv\Reader::createFromString
to create a CSV object from a raw stringBakame\Csv\Reader::query
accept an optional$callable
parameter
Bakame\Csv\Reader::getFile
in favor ofBakame\Csv\Reader::getIterator
Bakame\Csv\ReaderInterface
useless interface
Bakame\Csv\Reader::fetch*
$callable
parameter is normalized to accept an arrayBakame\Csv\Reader::fetchCol
accepts a third parameter$strict
Bakame\Csv\Reader
implements the following interfacesJsonSerializable
andArrayAccess
Bakame\Csv\Reader::toHTML
to output the CSV as a HTML tableBakame\Csv\Reader::setFilter
,Bakame\Csv\Reader::setSortBy
,Bakame\Csv\Reader::setOffset
,Bakame\Csv\Reader::setLimit
,Bakame\Csv\Reader::query
to perform SQL like queries on the CSV content.Bakame\Csv\Codec::setFlags
,Bakame\Csv\Codec::getFlags
, Bakame\Csv\Codec::__construct : add an optional$flags
parameter to enable the use ofSplFileObject
constants flags
Bakame\Csv\Reader::fetchOne
replaced byBakame\Csv\Reader::offsetGet
Bakame\Csv\Reader::fetchValue
useless method
Bakame\Csv\Reader::output
output the CSV data directly in the output bufferBakame\Csv\Reader::__toString
can be use to echo the raw CSV
Bakame\Csv\Reader::fetchAssoc
when users keys and CSV row data don't have the same length
Bakame\Csv\ReaderInterface
Bakame\Csv\Reader
class
Bakame\Csv\Codec::loadString
returns aBakame\Csv\Reader
objectBakame\Csv\Codec::loadFile
returns aBakame\Csv\Reader
objectBakame\Csv\Codec::save
returns aBakame\Csv\Reader
object
Bakame\Csv\CsvCodec
class renamedBakame\Csv\Codec
- Nothing
- Nothing
Bakame\Csv\Codec::create
from public API
Initial Release of Bakame\Csv