日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

php读取csv指定行_PHP快速读取CSV大文件指定行

發布時間:2023/12/2 php 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php读取csv指定行_PHP快速读取CSV大文件指定行 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1、如何快速獲取CSV大文件的總行數?

辦法一:直接獲取文件內容,使用換行符進行拆分得出總行數,這種辦法對小文件可行,處理大文件時不可行;

辦法二:使用fgets一行一行遍歷,得出總行數,這種辦法比辦法一好一些,但大文件仍有超時的可能;

辦法三:借助SplFileObject類,直接將指針定位到文件末尾,通過SplFileObject::key方法獲取總行數,這種辦法可行,且高效。

具體實現方法:

代碼如下:

$csv_file = 'path/bigfile.csv';

$spl_object = new SplFileObject($csv_file, 'rb');

$spl_object->seek(filesize($csv_file));

echo $spl_object->key();

2、如何快速獲取CSV大文件的數據?

仍然使用PHP的SplFileObject類,通過seek方法實現快速定位。

代碼如下:

$csv_file = 'path/bigfile.csv';

$start = 100000; // 從第100000行開始讀取

$num = 100; // 讀取100行

$data = array();

$spl_object = new SplFileObject($csv_file, 'rb');

$spl_object->seek($start);

while ($num-- && !$spl_object->eof()) {

$data[] = $spl_object->fgetcsv();

$spl_object->next();

}

print_r($data);

3、綜合上面兩點,整理成一個csv文件讀取的類:

代碼如下:

class CsvReader {

private $csv_file;

private $spl_object = null;

private $error;

public function __construct($csv_file = '') {

if($csv_file && file_exists($csv_file)) {

$this->csv_file = $csv_file;

}

}

public function set_csv_file($csv_file) {

if(!$csv_file || !file_exists($csv_file)) {

$this->error = 'File invalid';

return false;

}

$this->csv_file = $csv_file;

$this->spl_object = null;

}

public function get_csv_file() {

return $this->csv_file;

}

private function _file_valid($file = '') {

$file = $file ? $file : $this->csv_file;

if(!$file || !file_exists($file)) {

return false;

}

if(!is_readable($file)) {

return false;

}

return true;

}

private function _open_file() {

if(!$this->_file_valid()) {

$this->error = 'File invalid';

return false;

}

if($this->spl_object == null) {

$this->spl_object = new SplFileObject($this->csv_file, 'rb');

}

return true;

}

public function get_data($length = 0, $start = 0) {

if(!$this->_open_file()) {

return false;

}

$length = $length ? $length : $this->get_lines();

$start = $start - 1;

$start = ($start < 0) ? 0 : $start;

$data = array();

$this->spl_object->seek($start);

while ($length-- && !$this->spl_object->eof()) {

$data[] = $this->spl_object->fgetcsv();

$this->spl_object->next();

}

return $data;

}

public function get_lines() {

if(!$this->_open_file()) {

return false;

}

$this->spl_object->seek(filesize($this->csv_file));

return $this->spl_object->key();

}

public function get_error() {

return $this->error;

}

}

4、調用方法如下:

代碼如下:

include('CsvReader.class.php');

$csv_file = 'path/bigfile.csv';

$csvreader = new CsvReader($csv_file);

$line_number = $csvreader->get_lines();

$data = $csvreader->get_data(10);

echo $line_number, chr(10);

print_r($data);

總結,上述CsvReader類并不只針對CSV大文件,對于其他文本類型的大文件或超大文件同樣可用,前提是將類中fgetcsv方法稍加改動為fgets即可。

本文原創發布php中文網,轉載請注明出處,感謝您的尊重!

總結

以上是生活随笔為你收集整理的php读取csv指定行_PHP快速读取CSV大文件指定行的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。