CSDN博客

img WapWeb

PHP 小技巧之(4)如何获得txt文件中的一行数据?

发表于2004/6/25 17:33:00  1956人阅读

分类: PHP程序设计技术点滴!

我看了很多单文本数据的留言簿程序,发现这些程序效率很低,每次都要完全读入整个文件,  
现求一种方法,可以获得我想要的一行数据,而又只读取那一行数据!  
只能使用php!  
---------------------------------------------------------------  
 
使用fseek()定位  
然后fgets  
---------------------------------------------------------------  
 
不是所有人都喜欢那么笨,是因为!文件只能那么读!这是磁盘原理!你就别做梦了!所以大家都如此写,我一直用文本存储数据!你的问题应该看磁盘存储原理你就file,explode这么读吧!  
---------------------------------------------------------------  
 
也许  
$FD  =  fopen(...);  
for($i=0;$i<n;$i++)  
 $str  =  fgets($FD);  
$str  =  chop($str);  
对于大文件来说可以做得更好一些。  
---------------------------------------------------------------  
 
如果你保存文件时强制你的每个记录的大小,比如1K,如果不足1K则结尾用空格填充,那么你用fseek()然后fgets将非常快。  
fseek($FD,1000*n,SEEK_SET);  
$content  =  fread($FD,1000);  
$content  =  rtrim($content);  
---------------------------------------------------------------  
 
我觉得是,假设你有一个100000个记录的文本文件,如果强制记录的话大概是  
100M,你只要打开文件,然后定位到某个位置,并读取1K大小的数据。时间应该很快,占用内存资源也很少。  
如果你是用file()方法将文件读到数组中,再读取单个的记录的话,我想,怎么着也不能比上一个方法强吧。  
而且,你在留言中肯定应该可以存在多行内容吧,用file()方法你需要先对留言进行特殊处理在保存到文件中,而固定记录的话,你只需要添加就行了。  
但是固定记录对需要经常删除内容的文件有一些弊端,而且相对来说会浪费一些空间。  
---------------------------------------------------------------  
 
不断的填充填充,节省空间吗!一个普通网站100M空间,能放多少数据?如果数据量太大,请用数据库  
---------------------------------------------------------------  
 
to  langwan:  
别误解,我说的是用固定记录会浪费空间!  
如果留言大部分很短,你可以将1K减少为100B也行呀。  
其实这么说只是针对使用文件保存数据而言,当然最好是用数据库了(在记录数比较多时)。  
应该允许百花齐放嘛!  
---------------------------------------------------------------  
 
呵呵,不许打架。。。。。^_^。。。。。。。  
我觉得如果文件内容很多的话就用数据库。要不然为什么叫库呢。  
而且文本文件不理想。如果文件太多往往占远超过文件大小的空间(与簇有关)。10个1MB的文件绝对比100个100KB的文件占的空间小。  
讲效率就用数据库嘛。  
---------------------------------------------------------------  
 
文本数据库的效率的确不高.  除非与很好的数据结构相配合(sigh,  我还没找到很好的相关资料)  
 
用fgets对于小文件的效率可能是不高,  但是对于大文件,  用file你就会发现你浪费了大部分时间在读取不需要的东西(特别是需要的内容在前面的时候).  
 
这些函数,  都是一些时候我比你快,  另一些时候你比我快的.  不能一棒子打死.  
---------------------------------------------------------------  
 
你的那个想法有点儿类似dbase数据表的memo字段,用那个方法当然可以。但是要考虑到效率问题:即你先处理索引信息,然后再定位于实际的记录位置去读取相应的内容,也许会得不偿失。而且,php好象内置了对dbase数据表的支持,我想,如果用这种方法还不如用一个*.dbf数据表来存储数据呢!你认为呢?  
---------------------------------------------------------------  
 
fseek只是将文件读写指针进行定位,应该是调用操作系统处理文件的底层接口,并不实际读取数据。而fgets应该是从当前位置读取一定数量的内容,应该占用一定的磁盘I/O时间,而file()是将文本文件按行读取到一个数组中,这就应该是一个由编程语言提供的一个高级函数,相对来说,占用的处理时间除了磁盘I/O时间之外应该还有必须的处理程序执行所需要的时间。而实际上文件读取操作中主要的瓶颈应该是磁盘存取速度(如果不涉及到更多的后续处理过程的话。),你读取的内容越多,则存取时间就应该越长,当处理小文件(存取内容相差不大)时,应该不会感觉到有什么问题,但如果文件比较大的话,这种时间的差距应该比较明显。  
---------------------------------------------------------------  
 
同一条件下,两个函数的快慢是不一定的  :)  
客观是磁盘存储原理!  
为什么不一定?:)呵呵浪湾绕口令!  
同一条件是同一条件,但是任何状态下的同一条件不是同一条件!  
所以你应该研究出一条曲线,一条这些函数效率的曲线!  
客观是存在这样一条曲线!除非你遇到的文本数据永远沿着一条直线!  
而客观是数据的状态是曲线!  
呵呵祝你成功!如果成功了告诉我一声!  
因为浪湾从来没用过php+mysql,我的网站缴费少!:-(  如果你解决了,最大的受益者浪湾耳!  
===================  
任何状态下的同一条件不是同一条件!  
---------------------------------------------------------------  
 
现在是浪湾讲故事时间:  
曾经有个很厉害的人,他说:光是波。后来又有个很厉害的人,他说:光嘛?不是波,光是粒子。两种思想在学术界打了起来!爱因斯坦狡猾的说:“说得好,你们的研究都对,光具有“波粒二像性”!世界终于不争吵了!  
浪湾开始嚷嚷了!fseek,fgets,file,文本数据库具有多像性,哈哈!  
别吵这个了,聪明人都用!不同地方,用不同的函数!  
文本就一个地方需要好好的讨论!  
==============================  
文本数据库的效率的确不高.  除非与很好的数据结构相配合(sigh,  我还没找到很好的相关资料)  
==============================  
 
为什么找不到很好的相关资料  
==============================  
浪湾讲故事时间二:  
一天浪湾的同学来我这里玩,他问浪,你那些奇形怪状的软件,显示速度不慢呀!你怎么弄的?别的软件弄成这样速度都慢了!算法教教我吧!  
浪湾对他说:“嗨,容易的很,没有任何算法,用的最笨的办法!用长头发的脑袋算出400多个轮廓点,放到数组里。计算机这个不长头发的脑袋就好了,它不用算了!所以就快了!同学疑惑的说:那?,哎呀你那什么那,每一个不同的形状我都各自算做了一个数组,这么傻瓜的做法,能不快吗?  
===============================  
总结:针对你要做的脚本程序,设计最直接的最符合客观的数据结构,就是最快的!无法通用所有客观,让所有客观都好用的理论上不存在!  
===============================  
如果你想穿最舒服的衣服,只能找人量审定做,这个问题!太。。。。  
===============================  
通用的办法理论上不好找  
呵呵,百花齐放,不断创新!
0 0

相关博文

我的热门文章

img
取 消
img