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

php筆記之:有規律大文件的讀取與寫入的分析

這幾天在做一個東西.研究php讀取行數較多的文件(大概上百萬行).考慮到效率問題.進行了簡單的研究.總結如下

第一條.file()函數的效率問題.

file()函數的效率很底下 如果是有規律的文件.比如每行一條相應數據.那么盡量不要是用file()函數

可以使用file_get_contents()然后用explode切割.這樣效率會快三分之一

舉個例子:

文件樣式如下:

11111/n

22222/n

33333/n

44444/n

55555/n

...../n

nnnnnnnnnnn/n

如果用file($file)讀入的話.耗時很長.

可以用如下方法explode("/n",file_get_contents($file));效率會快很多.

第二條,數組的遍歷方式.

數據已經被讀入數組了.下面就是遍歷了.

我所需要的是確定數組中有無一個值的存在,比如說44444是否在數組中.首先想到的是in_array()

不過實驗了下發現效率很低下.于是參考別人的代碼想到一個辦法.把數組翻轉過來.變成所有值都為1.原來的值變成了索引.那么只要我在if里寫($arr[索引]==1)去判斷.果然效率高出很多.

在數組的遍歷過程中.如果數組個頭非常大,并且數組中的數據并不是全能用到的話,最好把用來遍歷的數組抽出來.這樣會提高很多效率.

第三條,數組的存儲.

把計算過后的數據保存起來.存在一個文件中.考慮了三種方法.一種是直接寫成php文件.一種是serialize,一種是json串.

第一種方式

直接寫入文件<?php 連接var_export($var)連接";"連接?>保存成php

需要的時候直接require進來.

第二種方式.把變量serialize然后file_put_contents()進入文件.使用的時候unserialize就ok.

第三種方式和第二種類似.只不過寫成了json串.

經過測試.發現第二種效率最高.第三種其次.和第二種效率不相上下.第一種最慢.和我預想的差距很大.真是大跌眼鏡.

php技術php筆記之:有規律大文件的讀取與寫入的分析,轉載需保留來源!

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

主站蜘蛛池模板: 国产在线视频网 | 日本一区二区视频在线观看 | 四虎影视免费永久在线观看黄 | 国产精品伦理久久久久 | 99久久精品免费精品国产 | 亚洲五月激情综合图片区 | 99久久精品国产片 | 中文不卡视频 | 国产亚洲欧美另类久久久 | 成人毛片18女人毛片免费 | 伊人激情视频 | 久久大伊人 | 欧美色欧美亚洲另类二区不卡 | 91精品91久久久久久 | 日韩 欧美 国产 亚洲 中文 | 国产床戏无遮挡免费观看网站 | 亚洲精品成人久久久影院 | 国产精品女同一区二区久久 | 91精品国产高清91久久久久久 | 久久婷婷国产麻豆91天堂 | 小说区图片区视频区 | 亚鲁鲁国产 | 国产精品黑色丝袜的老师 | 色播影院性播免费看 | 2021国产成人精品国产 | 亚洲激情综合 | 一区二区三区在线免费 | 激情文学小说区另类小说同性 | 2021最新在线精品国产 | 色女人在线视频 | 一区二区三区在线视频播放 | 免费国产一区二区三区 | 欧美精品第56页在线视频观看 | 久久久国产一区二区三区 | 日本一道一区二区免费看 | 久久精品系列 | 国产成人香蕉在线视频网站 | 国产精品久久久久影院色老大 | 亚洲综合激情六月婷婷在线观看 | 九九久久国产 | free性开放欧美群做a |