PHP中对文本文件操作很好的类

原创 2004年08月02日 16:29:00
class  CtbClass  {  
 
           var  $file;          
           var  $index;      
 
       //建立一个文件并写入输入  
           function  null_write($new)  
           {  
                       $f=fopen($this->file,"w");          
                       flock($f,LOCK_EX);  
                       fputs($f,$new);          
                       fclose($f);    
           }  
           //  添加数据记录到文件末端  
           function  add_write($new)  {            
                       $f=fopen($this->file,"a");          
                       flock($f,LOCK_EX);  
                       fputs($f,$new);            
                       fclose($f);    
           }    
           //  配合readfile()的返回一起使用,把一行数据转换为一维数组  
           function  make_array($line)  {  
                       $array  =  explode("/x0E",$line);  
                       return  $array;  
           }  
             
           //把为一维数组转换一行数据  
           function  join_array($line)  {  
                       $array  =  join("/x0E",$line);  
                       return  $array;  
           }  
           //  返回数据文件的总行数  
           function  getlines()  {  
                       $f=file($this->file);          
                       return  count($f);          
           }  
           //  返回下一行的数据记录(备用)  
           function  next_line()  {  
                       $this->index=$this->index++;          
                       return  $this->get();          
           }  
 
           //  返回上一行的数据记录(备用)  
           function  prev_line()  {  
                       $this->index=$this->index--;          
                       return  $this->get();          
           }      
           //  返回当前行的数据记录数据较小  
           function  get()  {  
                       $f=fopen($this->file,"r");          
                       flock($f,LOCK_SH);  
                       for($i=0;$i<=$this->index;$i++)  {  
                                   $rec=fgets($f,1024);          
                       }  
                       $line=explode("/x0E",$rec);  
                       fclose($f);  
                       return  $line;          
           }      
           //  返回当前行的数据记录数据较大  
           function  get_big_file()  {  
                       $f=fopen($this->file,"r");          
                       flock($f,LOCK_SH);  
                       for($i=0;$i<=$this->index;$i++)  {  
                                   $rec=fgets($f,1024*5);          
                       }  
                       $line=explode("/x0E",$rec);  
                       fclose($f);  
                       return  $line;          
           }      
           //  打开数据文件---以一维数组返回文件内容  
           function  read_file()  {  
                       if  (file_exists($this->file))  {  
                                   $line  =file($this->file);  
                       }  
                       return  $line;  
           }  
           //  打开数据文件---以二维数组返回文件内容  
           function  openFile()  {  
                       if  (file_exists($this->file))  {  
                                   $f  =file($this->file);  
                                   $lines  =  array();  
                                   foreach  ($f  as  $rawline)  {  
                                               $tmpline  =  explode("/x0E",$rawline);  
                                               array_push($lines,  $tmpline);  
                                   }  
                       }  
                       return  $lines;  
           }  
           //  传入一个数组,合并成一行数据,重写整个文件  
           function  overwrite($array){  
                       $newline  =  implode("/x0E",$array);              
                       $f  =  fopen($this->file,"w");  
                       flock($f,LOCK_EX);  
                       fputs($f,$newline);  
                       fclose($f);  
           }  
     
           //  添加一行数据记录到文件末端  
           function  add_line($array,$check_n=1)  {      
                       $s=implode("/x0E",$array);          
                       $f=fopen($this->file,"a");          
                       flock($f,LOCK_EX);  
                       fputs($f,$s);          
                       if  ($check_n==1)  fputs($f,"/n");          
                       fclose($f);    
           }          
 
           //  插入一行数据记录到文件最前面  
           function  insert_line($array)  {  
                       $newfile  =  implode("/x0E",$array);  
                       $f  =  fopen($this->file,"r");  
                       flock($f,LOCK_SH);  
                       while  ($line  =  fgets($f,1024))  {  
                                   $newfile  .=  $line;  
                       }  
                       fclose($f);  
                       $f  =  fopen($this->file,"w");  
                       flock($f,LOCK_EX);  
                       fputs($f,$newfile);  
                       fclose($f);  
           }  
 
           //  更新所有符合条件的数据记录,适用于每行字节数据较大的情况  
           function  update($column,$query_string,$update_array)  {  
                       $update_string  =  implode("/x0E",$update_array);        
                       $newfile  =  "";              
                       $fc=file($this->file);  
                       $f=fopen($this->file,"r");  
                       flock($f,LOCK_SH);  
                       for  ($i=0;$i<count($fc);$i++)  {  
                                   $list  =  explode("/x0E",$fc[$i]);  
                                   if  ($list[$column]  !=  $query_string)  {  
                                               $newfile  =  $newfile.chop($fc[$i])."/n";  
                                   }  else  {  
                                               $newfile  =  $newfile.$update_string;  
                                   }  
                       }  
                       fclose($f);  
                       $f=fopen($this->file,"w");  
                       flock($f,LOCK_EX);  
                       fputs($f,$newfile);  
                       fclose($f);  
           }  
 
           //  更新所有符合条件的数据记录,适用于每行字节数据较小的情况  
           function  update2($column,$query_string,$update_array)  {  
                       $newline  =  implode("/x0E",$update_array);        
                       $newfile  =  "";  
                       $f  =  fopen($this->file,"r");  
                       flock($f,LOCK_SH);  
                       while  ($line  =  fgets($f,1024))  {  
                                   $tmpLine  =  explode("/x0E",$line);  
                                   if  ($tmpLine[$column]  ==  $query_string)  {  
                                               $newfile  .=  $newline;  
                                   }  else  {  
                                               $newfile  .=  $line;  
                                   }  
                       }  
                       fclose($f);  
                       $f  =  fopen($this->file,"w");  
                       flock($f,LOCK_EX);  
                       fputs($f,$newfile);  
                       fclose($f);  
           }  
 
           //  删除所有符合条件的数据记录,适用于每行字节数据较大的情况  
           function  delete($column,$query_string)  {  
                       $newfile  =  "";              
                       $fc=file($this->file);  
                       $f=fopen($this->file,"r");  
                       flock($f,LOCK_SH);  
                       for  ($i=0;$i<count($fc);$i++)  {  
                                   $list  =  explode("/x0E",$fc[$i]);  
                                   if  ($list[$column]  !=  $query_string)  {  
                                               $newfile  =  $newfile.chop($fc[$i])."/n";  
                                   }  
                       }  
                       fclose($f);  
                       $f=fopen($this->file,"w");  
                       flock($f,LOCK_EX);  
                       fputs($f,$newfile);  
                       fclose($f);  
           }          
 
           //  删除所有符合条件的数据记录,适用于每行字节数据较小的情况  
           function  delete2($column,$query_string){      
                       $newfile  =  "";  
                       $f  =  fopen($this->file,"r");  
                       flock($f,LOCK_SH);  
                       while  ($line  =  fgets($f,1024))  {  
                                   $tmpLine  =  explode("/x0E",$line);  
                                   if  ($tmpLine[$column]  !=  $query_string)  {  
                                               $newfile  .=  $line;  
                                   }  
                       }  
                       fclose($f);  
                       $f  =  fopen($this->file,"w");  
                       flock($f,LOCK_EX);  
                       fputs($f,$newfile);  
                       fclose($f);  
           }  
 
       //取得一个文件里某个字段的最大值  
           function  get_max_value($column)  {  
                       $tlines  =  file($this->file);  
                       for  ($i=0;$i<=count($tlines);$i++)  {  
                                   $line=explode("/x0E",$tlines[$i]);  
                                   $get_value[]=$line[$column];  
                       }  
               $get_max_value  =  max($get_value);  
                       return  $get_max_value;  
           }  
 
 
           //  根据数据文件的某个字段是否包含$query_string进行查询,以二维数组返回所有符合条件的数据  
           function  select($column,  $query_string)  {  
                       $tline  =  $this->openfile();  
                       $lines  =  array();  
                       foreach  ($tline  as  $line)  {  
                                   if  ($line[$column]  ==  $query_string)  {  
                                               array_push($lines,  $line);  
                                   }  
                       }  
 
                       return  $lines;  
           }  
 
           //  功能与function  select()一样,速度可能略有提升  
           function  select2($column,  $query_string)  {  
                       if  (file_exists($this->file))  {  
                                   $tline  =  $this->read_file();  
                                   foreach  ($tline  as  $tmpLine)  {  
                                               $line  =  $this->make_array($tmpLine);  
                                               if  ($line[$column]  ==  $query_string)  {  
                                                           $lines[]=$tmpLine;  
                                               }  
                                   }  
                       }  
 
                       return  $lines;  
           }  
 
           //  根据数据文件的某个字段是否包含$query_string进行查询,以一维数组返回第一个符合条件的数据  
           function  select_line($column,  $query_string)  {  
                       $tline  =  $this->read_file();  
                       foreach  ($tline  as  $tmpLine)  {  
                                   $line  =  $this->make_array($tmpLine);  
                                   if  ($line[$column]  ==  $query_string)  {  
                                       return  $line;  
                                               break;  
                                   }  
                       }  
           }  
           //  select  next/prev  line(next_prev  ==>  1/next,  2/prev)  by  cx  
           function  select_next_prev_line($column,  $query_string,  $next_prev)  {  
                       $tline  =  $this->read_file();  
                       $line_key_end  =  count($tline)  -  1;  
                       $line_key  =  -1;  
                       foreach  ($tline  as  $tmpLine)  {  
                                   $line_key++;  
                                   $line  =  $this->make_array($tmpLine);  
                                   if  ($next_prev  ==  1)  {    //  next?  
                                               if  ($line[$column]  ==  $query_string)  {  
                                                           if  ($line_key  ==  0)  {  
                                                                       return  0;  
                                                           }  else  {  
                                                                       $line_key_up  =  $line_key  -  1;  
                                                                       return  $up_line;  
                                                           }  
                                               }  else  {  
                                                           $up_line  =  $line;  
                                               }  
                                   }  elseif  ($next_prev  ==  2)  {    //  prev?  
                                               if  ($line[$column]  ==  $query_string)  {  
                                                           if  ($line_key  ==  $line_key_end)  {  
                                                                       return  0;  
                                                           }  else  {  
                                                                       $line_key_down  =  $line_key  +  1;  
                                                                       break;  
                                                           }  
                                               }  
                                   }  else  {  
                                               return  0;  
                                   }  
                       }  
                       $down_line  =  $this->make_array($tline[$line_key_down]);  
                       return  $down_line;  
           }  
 
 
 
}  

MySQL数据库操作类(PHP实现,支持连贯操作)

使用过ThinkPHP框架的同学可能会对于其中数据库模型操作特别有好感,ThinkPHP提供了数据库操作的简单的操作,对于连接数据库,数据库的增删改查等数据操作都非常的nice,同时支持连贯操作,对于...
  • helencoder
  • helencoder
  • 2016年04月17日 11:27
  • 12338

php mysql数据库操作类,功能很强大

  • dongsg11200
  • dongsg11200
  • 2014年03月25日 13:23
  • 2872

PHP高效文件缓存类FCache

自己用的阿里云低配置,最近访问不错,经常出现mysql崩溃的问题,提单说请加内存,这回复还不如直接说:请交钱! 于是自己在git找了php的文件缓存,发现都是将缓存放到一个缓存文件!!!意味着:...
  • rrr4578
  • rrr4578
  • 2015年08月27日 17:44
  • 808

PHP操作redis完整类

php /**  * redis操作类  * 说明,任何为false的串,存在redis中都是空串。  * 只有在key不存在时,才会返回false。  * 这点可用于防止缓存穿透  *  */ c...
  • lmjy102
  • lmjy102
  • 2017年04月17日 10:07
  • 3570

一个简洁的PHP操作Access类

一个简洁的PHP操作Access类 09 April 2010 12:53 Fridayby Sjolzy /* FileName:cls_access.php Summary: Ac...
  • lukaixiao
  • lukaixiao
  • 2016年12月02日 19:47
  • 2273

PHP操作MSSQL数据库的类

http://yige.org/p/88
  • zunguitiancheng
  • zunguitiancheng
  • 2014年05月23日 00:18
  • 482

PHP操作MySql封装类

mysqlconfig.php mysqlfunction.ph
  • caiandyong
  • caiandyong
  • 2015年08月24日 14:59
  • 4182

CH13,拍42,练习一。通过文本文件统计页面访问量

index.php
  • qq_34242581
  • qq_34242581
  • 2016年12月20日 22:33
  • 151

php文件操作类

  • daditao
  • daditao
  • 2013年02月07日 23:06
  • 2235

PHP操作mysql类的封装

版本一:
  • qq_15096707
  • qq_15096707
  • 2016年03月02日 11:11
  • 2399
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PHP中对文本文件操作很好的类
举报原因:
原因补充:

(最多只允许输入30个字)