日期:2014-05-16  浏览次数:20422 次

php_txt_db 转转转

用文本作数据处理
作者:admin 浏览:215次 时间:2010-10-13 13:40
用文本作数据处理,阅读用文本作数据处理,作者:redfox邮件:ask4more@163.net主页:http://netnote.oso.com.cn 相信大家在网上申请的免费PHP空间,如果是初级用户,一般都是没得MySQL可供使用,那

?
?
作者:redfox? 邮件:ask4more@163.net??
主页:http://netnote.oso.com.cn

??? 相信大家在网上申请的免费PHP空间,如果是初级用户,一般都是没得MySQL可供使用,那么我们解决数据处理的方法之一就是用文本文件了。但是用什么方法才可以最快最方便的处理文本数据呢?
??? 按我的经验,本人认为,以下列文件结构为最优:
----------------------------------
文件扩展名:.php
<? die('ACCESS DENIED!');?>
email=ask4more@13.net & nickname=redfox & realname=阿鼎 & url=http://NetNote.oso.com.cn & ...
...
----------------------------------
??? 也许大家都看出来了,以.php做扩展名,并且文件的第一行是<? die('ACCESS DENIED!');?>,这样就有效的阻止了对数据文件的非法访问。文件的第二行的格式都是:? 变量名1=值1 & 变量名2=值2 & ...
??? 提出所有的变量很简单,就是用函数 parse_str();
例如:
<?
$theline="email=ask4more@13.net&nickname=redfox&realname=阿鼎&url=http://NetNote.oso.com.cn";
parse_str($theline);//分离出变量$email,$nickname,$realname,$url
echo "I am $nickname,my real name is $realname<br>";
echo "welcome to visit my website:$url<br>";
echo "email me at:$email";
?>
运行结果:
I am redfox,my real name is 阿鼎
welcome to visit my website:http://NetNote.oso.com.cn
email me at:ask4more@13.net?

??? 因此,本文约定,数据文本结构为:
----------------------------------------
<? die('ACCESS DENIED!');?>
变量名1=值1 & 变量名2=值2 & ...

文件扩展名: .php
----------------------------------------

??? 真正的数据从第二行开始。好了,用这样的文件结构就可以很容易的实现GuestBook,BBS,甚至是社区的数据处理了:)我的主页“网络便签” http://netnote.oso.com.cn ,就是这样实现的。
??? 为了方便广大网友,我编了几个函数,下面将作出必要的解释。当然你可以随便的修改和挎贝,但你必须保证功能的完整性。请将下面的代码存为 textfun.inc (当然取其它的名字也是一样的),在你要使用的文件的开始部分加入一行语句<?include("textfun.inc");?>,你就可 以使用我为你编的函数了。
下面一共一个db对象,一个函数p2row();

-------------textfun.inc----------------
<?
class db{
? var $dbfile;
? function createdb($dbName){
??? $f=$dbName;
??? $this->$dbfile=$f;
??? $headInfo="<?die('ACCESS DENIED!');?>\n";
??? $fp=fopen($f,"w");
??? fputs($fp,$headInfo);
??? fclose($fp);
??? chmod($f,0777);//修改文件的模式,在Unix下也可用
??? return(1);
? }
? function opendb($f){
??? $this->$dbfile=$f;
??? if(file_exists($f)){
????? return true;
??? }else{
????? $this->createdb($f);
??? }
? }
? function insertline($info){
??? $fields=explode("|",$info);
??? while(list($key,$val)=each($fields)){
????? $therow.="$val=\$".$val."&";
????? $var1.="\$".$val.",";
??? }
??? $var1.='$tail';
??? eval("global $var1;"); //为了取得环境变量
??? eval("\$therow=\"$therow\";");
??? $fp=fopen($this->$dbfile,"a");
??? fputs($fp,"$therow\n");
??? fclose($fp);
? }
? function readall($f){
??? if(file_exists($f)){
????? $this->$dbfile=$f;
????? $rows=file($f);
????? for($i=1;$i<count($rows);$i++){
??????? $temp[]=$rows[$i];
????? }
????? return $temp;
??? }
? }
? //以倒序的方式读入所有的数据行
? function revread($f){
??? if(file_exists($f)){
????? $this->$dbfile=$f;
????? $rows=file($f);
????? $d=count($rows);
????? $j=$d-1;
????? for($i=0;$i<$d;$i++){
??????? if($i<$j){
????????? $temprow=$rows[$i];
????????? $rows[$i]=$rows[$j];
????????? $rows[$j]=$temprow;
????????? $j--;
??????? }
????? }
????? for($i=0;$i<count($rows)-1;$i++){? //去掉首行
??????? $temp[]=$rows[$i];
????? }
????? return $temp;
??? }
? }

? function close(){
? $this=$nothing;
? }
}

//把段落文本格式化为一行文本,便于存储
function p2row($t){??
? $t=nl2br(stripslashes(htmlspecialchars($t)));
? for($i=0;$i<strlen($t);$i++){
??? $c=substr($t,$i,1);
??? if(ord($c)==10) $c=" ";
????? $tempstr.=$c;
??? }
??? return $tempstr;
? }
?>
----------------------------------
<