通过PHP获得txt文件中的一行数据的方法

通过PHP获得txt文件中的一行数据的方法

我看了很多单文本数据的留言簿程序,发现这些程序效率很低,每次都要完全读入整个文件,
现求一种方法,可以获得我想要的一行数据,而又只读取那一行数据!
只能使用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多个轮廓点,放到数组里。计算机这个不长头发的脑袋就好了,它不用算了!所以就快了!同学疑惑的说:那?,哎呀你那什么那,每一个不同的形状我都各自算做了一个数组,这么傻瓜的做法,能不快吗?
===============================
总结:针对你要做的脚本程序,设计最直接的最符合客观的数据结构,就是最快的!无法通用所有客观,让所有客观都好用的理论上不存在!
===============================
如果你想穿最舒服的衣服,只能找人量审定做,这个问题!太。。。。
===============================
通用的办法理论上不好找
呵呵,百花齐放,不断创新!