From:             
Operating system: All
PHP version:      5.3.2
Package:          Filesystem function related
Bug Type:         Feature/Change Request
Bug description:fgetcsv should take empty string as an escape

Description:
------------
Currently fgetcsv() gives a warning if the escape parameter is set as an
empty string (and the default is a backslash). I have some data that has
backslashes in it and it's not an escape character. Even though most of the
times fgetcsv() reads the data correctly, there is a little chance it will
do it wrong if a backslash is the last character of a multiline cell, which
is usually stored like this:



"\\\line1

line2\\\"



In order to fix that I supply chr(8) as an escape character because I know
for sure the data does not have the character. And if I pass an empty
string instead fgetcsv() will give a warning and refuse to read a line. 



I suggest that fgetcsv() does accept an empty string as an escape and do no
escaping in that case, which is quite usual. 

For ex., a MySql statement "Load Data Infile ... Into Table" has it as
"Escaped By None" to achieve the same result. 







Test script:
---------------
if (!$Handle=fopen("sites.txt", "rb")) return false;

print_r(fgetcsv($Handle, 0, "\t", '"', ""));

fclose($Handle);



Expected result:
----------------
array( ... ) - depends on the input file

Actual result:
--------------
Warning: fgetcsv(): escape must be character in ...

-- 
Edit bug report at http://bugs.php.net/bug.php?id=51496&edit=1
-- 
Try a snapshot (PHP 5.2):            
http://bugs.php.net/fix.php?id=51496&r=trysnapshot52
Try a snapshot (PHP 5.3):            
http://bugs.php.net/fix.php?id=51496&r=trysnapshot53
Try a snapshot (PHP 6.0):            
http://bugs.php.net/fix.php?id=51496&r=trysnapshot60
Fixed in SVN:                        
http://bugs.php.net/fix.php?id=51496&r=fixed
Fixed in SVN and need be documented: 
http://bugs.php.net/fix.php?id=51496&r=needdocs
Fixed in release:                    
http://bugs.php.net/fix.php?id=51496&r=alreadyfixed
Need backtrace:                      
http://bugs.php.net/fix.php?id=51496&r=needtrace
Need Reproduce Script:               
http://bugs.php.net/fix.php?id=51496&r=needscript
Try newer version:                   
http://bugs.php.net/fix.php?id=51496&r=oldversion
Not developer issue:                 
http://bugs.php.net/fix.php?id=51496&r=support
Expected behavior:                   
http://bugs.php.net/fix.php?id=51496&r=notwrong
Not enough info:                     
http://bugs.php.net/fix.php?id=51496&r=notenoughinfo
Submitted twice:                     
http://bugs.php.net/fix.php?id=51496&r=submittedtwice
register_globals:                    
http://bugs.php.net/fix.php?id=51496&r=globals
PHP 4 support discontinued:          http://bugs.php.net/fix.php?id=51496&r=php4
Daylight Savings:                    http://bugs.php.net/fix.php?id=51496&r=dst
IIS Stability:                       
http://bugs.php.net/fix.php?id=51496&r=isapi
Install GNU Sed:                     
http://bugs.php.net/fix.php?id=51496&r=gnused
Floating point limitations:          
http://bugs.php.net/fix.php?id=51496&r=float
No Zend Extensions:                  
http://bugs.php.net/fix.php?id=51496&r=nozend
MySQL Configuration Error:           
http://bugs.php.net/fix.php?id=51496&r=mysqlcfg

Reply via email to