首頁 > 後端開發 > php教程 > 用文字作資料處理_PHP教程

用文字作資料處理_PHP教程

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-07-21 16:07:21
原創
810 人瀏覽過

作者: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
";
echo "welcome to visit my website:$url
";
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 (當然取其它的名字也是一樣的),在你要使用的文件的開始部分加入一行語句,你就可以使用我為你編的函數了。
下面一共一個db對象,一個函數p2row();

-------------textfun.inc-------------- ---

class db{
  var $dbfile;
  function createdb($dbName){
    $ $f;
    $headInfo="n";
    $fp=fopen($f,"w");
   $fp=fopen($f,"w");
 $headInfo);
    fclose($fp);
    chmod($f,0777);//修改文件的模式,在Unix下也可使用  >  function opendb($f){
    $this->$dbfile=$f;
    if(file_exists($f)){ createdb($f);
    }
  }
  function insertline($info){
    $fields=explode("|",$$"|"); key,$val)=each($fields)){
      $therow.="$val=$".$val."&";
      $var1.="$".$val.", ";
    }
    $var1.='$tail';
    eval("global $var1;"); //為了取得環境變數
  ("global $var1;"); //為了取得環境變數
  ;");
    $fp=fopen($this->$dbfile,"a");
    fputs($fp,"$therown");
   fputs($fp,"$therown");
   fputs($fp,"$therown");
   fputs($fp,"$therown");
  }
  function readall($f){
    if(file_exists($f)){
      $ >      for($i=1;$i        $temp[]=$rows[$ }
  }
  //以倒序的方式讀入所有的資料行
  function revread($f){
    if(file_exists($f)){
    if(file_exists($f)){
    if(file_exists($f)){       $rows=file($f);
      $d=count($rows);
   $i        if($i          ];
          $rows[$j]=$temprow;
              for($i=0;$i        $temp[]=$rows[$i];
      }
  function close(){
  $this=$nothing;
  }
}

//將段落文字格式化為一行文本,以便於儲存
function🎜>//把段落文字格式化為一行文本,以便於儲存
function🎜($t ){   
  $t=nl2br(stripslashes(htmlspecialchars($t)));
  for($i=0;$i ($t,$i,1);
    if(ord($c)==10) $c=" ";
      $tempstr.=$c;
      $tempstr.=$c;
  ;
  }
?>
----------------------------------
    db是我們自訂的本文資料對象,包含六個方法:createdb(),opendb(),insertline(),readall().revread(),close();

db->createdb(string filename )
用法例:
    include("textfun.inc");
    $mydb=new db;
       ? >
這個方法建立了一個檔案UserInfo.php,首行是 die('ACCESS DENIED!');?>

db->opendb(string filename)
用法例:
    include("textfun.inc");
    $mydb=new db;
         追加模式「開啟」了資料檔案UserInfo.php,如果這個檔案不存在,則被建立。
    因此,此方法可以取代createdb()方法。 (但千萬別刪除了class db{  }裡面的createdb()函數喔:P)

db->insertline(string VarString)
用法例:
    include("textfun .inc");
    $theline="email=ask4more@13.net&nickname=redfox&realname=阿鼎&url=http://NetNote.oso.com.cn";
    parse_str($theline);////$建構環境變數
    $mydb=new db;
           $mydb->opendb("UserInfo.php");
  $mydb->opendb("UserInfo.php");
>    ?>
db->insertline()可以將形如"nickname|realname|email|url"的字串,分離出對應的環境變量,並以本文約定的形式存入文件。 傳入insertline()的參數,一定要用「|」把環境變數名稱連成字串,個數不限,但千萬別在前面加"$"哦,嗯,就是要形如"nickname|realname |email|url"這樣的字串  :~)

array db->readall(string filename)
用法範例:
    include("textfun.inc")
    include("textfun.inc")
; $mydb=new db;
    $allrec=$mydb->readall("UserInfo.php");
    ?>
readall()方法傳回除首行( die('ACCESS DENIED! ');?>)外所有資料的數組,每行對應於數組的一個元素。

array db->revread(string filename)
用法例:
    include("textfun.inc");
   all$mydb=newdb; $mydb->revread("UserInfo.php");
    ?>
revread()方法以倒序方式讀入除首行( die('ACCESS DENIED!');?>)外所有數據,傳回數組。這對我們在編留言本等時候特別有用。

void db->close()
        關閉db物件。

好了,我們現在就用db物件編一個最簡單的留言本。
——————————guestbook.php----------------------------------- -------------
我的留言本


>>
暱稱:

電子郵件:

首頁:

訊息:



表格>

include("textfun.inc");
if($Submit){
  $thetime=date("Y-m-d h:m:s A");
  $ message=p2row($message);
  $mydb=新資料庫;
  $mydb->opendb("msg.php");
  $mydb->insertline("暱稱|電子郵件|網址|訊息|時間");

  //以下寫入所有的資料
  $allrecs=$mydb->revread("msg.php");
  while(list($key,$ theline)=each($allrecs)){
    parse_str($theline);
    ? >
    < ;br>
    網址:

    訊息:

      }
  $mydb->close();
}
? >
---------------------------- 好了,雖然這篇留言本不是很漂亮,但主要是為了舉例說明db物件的用法~:)
在WIN98 PWS PHP4下調試通過!

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/315137.htmlTechArticle作者:redfox mail:ask4more@163.net 首頁:http://netnote.oso.com.cn 相信大家在網路上申請的免費PHP空間,如果是初級用戶,一般都不會得到MySQL供給使用...

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
hook使用用
來自於 1970-01-01 08:00:00
0
0
0
使用用戶ID進行API調用
來自於 1970-01-01 08:00:00
0
0
0
切換用戶
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板