程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 用php實現動態產生xml文件以及從xml文件中抽取數據轉化成html的小程序

用php實現動態產生xml文件以及從xml文件中抽取數據轉化成html的小程序

編輯:關於PHP編程

這個東東搞了我一天。。。可是到最後發現卻無法實現自己想像中的那種效果。。。真是可惜。。。看來php(做為現在的主流開發語言)對xml(標准化越來越近了)還需要加強。。。如果哪位對此有研究。歡迎來信探討。。。

首先建表:
CREATE TABLE books (
bookid int(4) NOT NULL auto_increment,
bookname varchar(100) NOT NULL,
bookauth varchar(50) NOT NULL,
bookpublisher varchar(50) NOT NULL,
bookpubdate datetime NOT NULL,
bookurl varchar(50) NOT NULL,
KEY bookid (bookid),
);

然後。。。這段是從MySQL(和PHP搭配之最佳組合)裡取數據轉化成xml(標准化越來越近了)的源代碼:
<?
$connect_id=MySQL(和PHP搭配之最佳組合)_connect("localhost","root","");
MySQL(和PHP搭配之最佳組合)_select_db("bbs",$connect_id);
$query="select * from books order by bookid";
$rs=MySQL(和PHP搭配之最佳組合)_query($query,$connect_id);
$numfields=MySQL(和PHP搭配之最佳組合)_num_fields($rs);
$xml(標准化越來越近了)file="<?xml(標准化越來越近了) version="1.0" encoding="GB2312"?>n";
$xml(標准化越來越近了)file.="<books>n";

while($row=MySQL(和PHP搭配之最佳組合)_fetch_array($rs)){
for($i=0;$i<$numfields;$i ){
$fieldname=MySQL(和PHP搭配之最佳組合)_field_name($rs,$i);
$xml(標准化越來越近了)file.="<" . $fieldname . ">" . $row[$i] . "</" . $fieldname . ">n";
}
}
MySQL(和PHP搭配之最佳組合)_free_result($rs);
MySQL(和PHP搭配之最佳組合)_close($connect_id);
$xml(標准化越來越近了)file.="</books>n";
$fp=fopen("xml(標准化越來越近了)doc/xml(標准化越來越近了)doc.xml(標准化越來越近了)","w");
if(fwrite($fp,$xml(標准化越來越近了)file)){
echo "寫入文件成功!";
}
else{
echo "寫入文件失敗!";
}
?>

這段是從xml(標准化越來越近了)裡取數據轉化成HTML的源代碼。。。
<?
class xml(標准化越來越近了){
var $parser;

function xml(標准化越來越近了)(){
$this->parser = xml(標准化越來越近了)_parser_create();
xml(標准化越來越近了)_set_object($this->parser,&$this);
xml(標准化越來越近了)_set_element_handler($this->parser,"tag_on","tag_off");
xml(標准化越來越近了)_set_character_data_handler($this->parser,"cdata");
}

function parse($data){
xml(標准化越來越近了)_parse($this->parser,$data);
}

function tag_on($parser,$tag,$attributes){
if(xml(標准化越來越近了)_get_current_line_number($parser)==2){
echo "<tr><td colspan="2" align="center">" . $tag . "</td>";
}
else{
switch ((xml(標准化越來越近了)_get_current_line_number($parser)-2)%6){
case 0:
echo "<tr><td>下載<td>";
break;
case 1:
echo "<tr><td>ID號<td>";
break;
case 2:
echo "<tr><td>書名<td>";
break;
case 3:
echo "<tr><td>作者<td>";
break;
case 4:
echo "<tr><td>出版社<td>";
break;
case 5:
echo "<tr><td>出版日期<td>";
break;
}
}
}

function cdata($parser,$cdata){
echo $cdata;
}

function tag_off($parser,$tag){
echo "n";
}
}

$xml(標准化越來越近了)_parser = new xml(標准化越來越近了)();
$xml(標准化越來越近了)filename="xml(標准化越來越近了)doc/xml(標准化越來越近了)doc.xml(標准化越來越近了)";
$fp=fopen($xml(標准化越來越近了)filename,"r");
$xml(標准化越來越近了)data=fread($fp,filesize($xml(標准化越來越近了)filename));
?>
<HTML><head><title>圖書信息</title></head>
<body>
<table border="0" cellspacing="1" cellpadding="2" width="80%" bgcolor="#b0d8fF" align="center">
<?
$xml(標准化越來越近了)_parser->parse($xml(標准化越來越近了)data);
?>
</table>

其實你們應該看得出。。這個例子是個失敗的東東。。。因為效果不大。。根本不能得到自己想要的東東。。。唉。。。苦。。。。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved