最新公告
  • 欢迎您光临波比源码,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入我们
  • 解决php fgetcsv 读取csv文件数据不完整问题

    csv文件是在php中有fgetcsv函数来读取,但在linux是的php5.2.8版本中会发现fgetcsv读出来的csv文件数据不完整,在windows其它版本中,代码如下:

    1. # Open the File.  
    2. if (($handle = fopen("test.csv""r")) !== FALSE) {  
    3.     # Set the parent multidimensional array key to 0.  
    4.     $nn = 0;  
    5.     while (($data = fgetcsv($handle, 0, ",")) !== FALSE) {  
    6.          
    7. //print_r($data);  
    8.         # Count the total keys in the row.  
    9.         $c = count($data);  
    10.         # Populate the multidimensional array.  
    11.         for ($x=0;$x<$c;$x++)  
    12.         {  
    13.             $csvarray[$nn][$x] = $data[$x];  
    14.         }  
    15.         $nn++;  
    16.     }  
    17.     # Close the File.  
    18.     fclose($handle);  
    19. }  
    20. //print_r($csvarray); 

    这个代码没有任何问题,然后我放到了linux中发现有为空的字段了,问题解析出来的数据不完整,有为空的字段,网上查了下说是在php5.2.8 中存在bug,解决办法是使用自定义函数,代码如下:

    1. function __fgetcsv(& $handle$length = null, $d = ','$e = '"') {  
    2.      $d = preg_quote($d);  
    3.      $e = preg_quote($e);  
    4.      $_line = "";  
    5.      $eof=false;  
    6.      while ($eof != true) {  
    7.          $_line .= (emptyempty ($length) ? fgets($handle) : fgets($handle$length));  
    8.          $itemcnt = preg_match_all('/' . $e . '/'$_line$dummy);  
    9.          if ($itemcnt % 2 == 0)  
    10.              $eof = true;  
    11.      }  
    12.      $_csv_line = preg_replace('/(?: |[ ])?$/'$d, trim($_line));  
    13.      $_csv_pattern = '/(' . $e . '[^' . $e . ']*(?:' . $e . $e . '[^' . $e . ']*)*' . $e . '|[^' . $d . ']*)' . $d . '/';  
    14.      preg_match_all($_csv_pattern$_csv_line$_csv_matches);  
    15.      $_csv_data = $_csv_matches[1];  
    16.      for ($_csv_i = 0; $_csv_i < count($_csv_data); $_csv_i++) {  
    17.          $_csv_data[$_csv_i] = preg_replace('/^' . $e . '(.*)' . $e . '$/s''$1' , $_csv_data[$_csv_i]);  
    18.          $_csv_data[$_csv_i] = str_replace($e . $e$e$_csv_data[$_csv_i]);  
    19.      }  
    20.      return emptyempty ($_line) ? false : $_csv_data;  
    波比源码 – 精品源码模版分享 | www.bobi11.com
    1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
    2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
    3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
    4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
    5. 如有链接无法下载、失效或广告,请联系管理员处理!
    6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
    7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!

    波比源码 » 解决php fgetcsv 读取csv文件数据不完整问题

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    波比源码
    一个高级程序员模板开发平台
    升级波友尊享更多特权立即升级