一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

PHP 讀取大文件的X行到Y行內容的實現代碼

需要讀取一個文件的幾行內容,但是文件比較大,所以研究了下php讀取大文件的幾行內容的方法,寫了一個方法,代碼如下(加了注釋):
緩存文件如果能夠保存在一行, 而利用算法讀取指定的行數, 自然會比全部讀出來挑選要快得多. 但php似乎這方面比較弱, 不太好操作. 就算使用SplFileObject仍然不是特別可取, 內存壓力存在.

復制代碼 代碼如下:
$fp->seek($startLine - 1);


經過測試, 此行代碼在8MB文本中游走到最后一行, 內存占用為49KB, 還算不錯. 換成fopen方式用fgets跳過的模式, 則花費29KB的內存, fopen還是占優勢.

復制代碼 代碼如下:
function getFileLines($filename, $startLine = 1, $endLine = 50, $method = 'rb'){
$content = array();

if (version_compare(php_VERSION, '5.1.0', '>=')) { // 判斷php版本(因為要用到SplFileObject,php>=5.1.0)
$count = $endLine - $startLine;
$fp = new SplFileObject($filename, $method);
$fp->seek($startLine - 1); // 轉到第N行, seek方法參數從0開始計數
for ($i = 0; $i <= $count; ++$i) {
$content[] = $fp->current(); // current()獲取當前行內容
$fp->next(); // 下一行
}
} else { //php<5.1
$fp = fopen($filename, $method);
if (!$fp)
return 'error:can not read file';
for ($i = 1; $i < $startLine; ++$i) { // 跳過前$startLine行
fgets($fp);
}

for ($i; $i <= $endLine; ++$i) {
$content[] = fgets($fp); // 讀取文件行內容
}
fclose($fp);
}
return array_filter($content); // array_filter過濾:false,null,''
}


效果不錯, SplFileObject類功能比較好.

php技術PHP 讀取大文件的X行到Y行內容的實現代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美整片完整片视频在线 | 日本精品1在线区 | 激情五月六月婷婷 | 国产中文在线视频 | 久久综合爱 | 国产成人一区二区三区影院免费 | 婷婷亚洲综合五月天小说在线 | 337p欧美超大胆日本人术艺术 | 国产精品亚洲国产 | 9久re在线观看视频精品 | 91久久精品一区二区 | 亚洲精品午夜级久久久久 | 精品在线视频一区 | 97影院在线午夜 | 一二三区在线观看 | 在线播放黄色网址 | 5g影院天天5g爽天天看 | 四虎国产精品免费久久影院 | 网红主播大尺度精品福利视频 | 国产精品极品美女自在线看免费一区二区 | 国产成人免费午夜在线观看 | 国产精品高清在线观看地址 | 台湾佬自偷自拍情侣在线 | 亚洲欧美日韩视频一区 | 99久久精品国语对白 | 91精品国产色综合久久 | 九九99久久精品国产 | 黄色片网站免费在线观看 | 美女胸又大又黄的网站 | 国产精品一区二区久久精品涩爱 | 一区二区三区国产 | 色多多网站入口 | 91激情在线| 色哟哟国产精品 | 韩国免费一级片 | 精品一区二区三区的国产在线观看 | 亚洲 欧美 校园 | 亚洲美女一区 | 韩国精品一区二区久久 | 999成人精品视频在线 | 日本免费网站观看 |