SimpleXML を使用して PHP_PHP チュートリアルで XML ファイルを処理する

WBOY
リリース: 2016-07-21 15:40:00
オリジナル
849 人が閲覧しました

1 SimpleXML の概要
XML ファイルを処理するには、SAX と DOM という 2 つの従来の処理アイデアがあります。イベント トリガー メカニズムに基づいて、SAX は XML ファイルを 1 回スキャンして処理を完了します。DOM は XML ファイル全体を DOM ツリーに構築し、DOM ツリーを走査して処理を完了します。どちらの方法にも独自の長所と短所があり、SAX の処理概念は比較的抽象的であり、
DOM の処理プロセスは比較的面倒なので、どちらも初心者が始めるにはあまり適していません。
PHP5 では、新しい XML 処理関数セット、つまり SimpleXML が導入されています。名前が示すように、SimpleXML 自体は小さくてコンパクトで、いくつかのメソッドと関数しか提供していませんが、XML ファイルの処理には非常に強力であり、操作は非常に簡単です。
まず、XML ドキュメント、文字列、または DOM オブジェクトから
SimpleXMLElement オブジェクトを直接構築するための単純な関数が提供されます。次に、SimpleXMLElement は属性、サブセクション、ポイント、および XPath を操作するための単純なメソッドを提供します。この処理のアイデアにより、PHP での XML ドキュメントの処理が大幅に簡素化されます。

2 SimpleXML 入門例

以下では、SimpleXML の能力とシンプルさについて少し理解するために、いくつかの小さなコード スニペットを使用します。例の便宜上、
次の XML コードを含む Messages.xml ファイルを使用します:
Messages.xml

コードをコピーします

コードは次のとおりです:

ここはコンテンツ <返信 id='11'>返信 1
<返信 id='12'>返信 2< /返信>


これは、メッセージ情報を保存する XML ドキュメントです。各情報には、属性 ID、サブノードのタイトル、コンテンツ、時刻が含まれており、各返信には属性 ID と返信コンテンツが含まれます。
SimpleXMLを利用してこのXML文書の内容を加工・出力する手順と方法は以下の通りです。
(1) SimpleXMLElement オブジェクトを構築します

コード スニペット
$xml = simplexml_load_file('Messages.xml');
この XML が文字列 $messages に読み込まれている場合は、次のステートメントを使用できます:
コード スニペット
$ xml = simplexml_load_string('Messages.xml');
(2) メッセージ 1 のタイトルを出力します
コード スニペット
//属性を使用して子ノードにアクセスでき、ノードのコンテンツはノードのラベルから直接取得できます。 name
echo $xml->msg->title;
(3) メッセージ 1 の最初の応答メッセージを出力します
コード スニペット
//同じレベルにある同じ名前の複数のノードは自動的に配列になり、その内容はインデックスの添字を通じてアクセスできます
echo $xml->msg->reply[0];
(4) メッセージの ID を出力します
コード スニペット
//ノードの属性と値は、連想配列のキーと値
echo $xml-> msg['id'];
(5) 2番目の応答のidを出力
コードスニペット
//1次元目の2次元配列になりますはノードを表し、2 番目の次元は属性を表します
echo $xml->msg-> ;reply[1][ 'id'];
(6) すべての返信の ID を順番に出力します
コード スニペット
// foreach を使用して同じ名前のノードを走査します
foreach ($xml->msg->reply as $reply ){
echo $reply['id'];
}
(7) XPath を使用してすべての応答を取得します情報
コードスニペット
//xpath メソッドは位置を直接取得します (//任意の深さを示します)
foreach ($xml-> ;xpath('//reply') as $reply){
echo $reply.'}

(8) メッセージ 1
コード スニペット
//children メソッドのすべての子ノードを走査して、すべての子ノード
foreach ($xml->msg->children() as $field){
echo $field.'
';
}
(9) メッセージ 1 の公開時間をリセットします
コード スニペット
//属性を直接設定します
$xml->msg->time = '2008- 03-21 00:53:12';
(10) Reply 2 の id 属性を設定します
コード スニペット
//管理配列を設定します
$xml->msg->reply[1][' id'] = '222';
(11) メッセージ作成者を説明するフィールドを追加します
コード スニペット
//属性を直接設定します
$xml ->msg->author = 'zhangsan';メッセージの作成者を属性として指定する
コード スニペット
//関連付けられた配列のキーを設定する
$xml->msg['author'] = 'zhangsan ';
(13) オブジェクトをファイルに再保存する
コード スニペット
//Save
$xml->asXML('MessagesNew.xml');
SimpleXML がいかにシンプルであるかがわかるはずです。
3 例: XML ファイルとデータベース間のデータ対話
上記の例に示すように、MySQL データベースからメッセージ情報をクエリし、それを
XML ファイルとして保存する比較的完全な例を以下に示します。メッセージ情報と返信情報は 2 つのテーブルに独立して保存されます。MySQL 関数パッケージを使用すると、次のように非常に簡単に実装できます:

コードは次のとおりです:



コードをコピーします。

//cong work atWed Mar 20 19:59:04 CST 2008
//MySQL データベースからデータを XML ファイルに保存します
//次のメソッドを使用して初期 SimpleXMLElement オブジェクトを構築できます
//1. DOM オブジェクトから構築します
//$dom = new DOMDocument();//$dom->loadXML(""); $dom);
//2. ルート タグのみを含む XML ファイルから構築します
//$xml = simplexml_load_file('messages.xml');
//3. ルート タグ文字列の構築を直接記述します
// $ xml = simplexml_load_string("");
//4. SimpleXMLElement クラスのコンストラクターを使用して
$xml = new SimpleXMLElement('') ;
//データベースに接続します
mysql_connect('localhost','root','root');
mysql_query('set names utf8'); = mysql_query( "select * frommessages");
$i = 0; //複数のメッセージの配列インデックスの添字として使用されます
while($row = mysql_fetch_assoc($rs)){
$xml->message[$i ] = ''; //… … … … … … … … … … … ①
$xml->message[$i]['id'] = $row['id']; ->メッセージ[$i]->タイトル = $row['タイトル']
$xml->メッセージ[$i]->コンテンツ = $row['コンテンツ']; ;message[ $i]->time = $row['time'];
//メッセージ ID に関連する返信情報をクエリします
$rsReply = mysql_query("select * from replies where Mid={$row[' id'] }");
$j = 0; //複数の返信のインデックス添字
while($rowReply = mysql_fetch_assoc($rsReply)){
$xml->message[$i]->reply [$ j] = $rowReply['reply'];
$xml->メッセージ[$i]->返信[$j]['id'] = $rowReply['id']
}
$i++;
}
$xml->asXML('messages.xml');


上記のコードで言及する価値があるのは、①でマークされた行だけです。新しいノードまたは属性を SimpleXML オブジェクトに追加する場合は、その親ノードが存在することを確認する必要があります。そうでない場合は、次のようなプロンプト メッセージが表示されます。ポスト/プレ インクリメント/デクリメントで配列として使用されるオブジェクトは返される必要があります。値は参考値です。皆さん

がこの理解できない通知に混乱しないことを願っています。読者は上記のコードを理解すれば、XML ファイルから MySQL へのコードを書くことができると思います。



http://www.bkjia.com/PHPjc/321422.html
www.bkjia.com

tru​​e

http://www.bkjia.com/PHPjc/321422.html
技術記事

1 SimpleXML の概要 XML ファイルを処理するには、SAX と DOM という 2 つの従来の処理アイデアがあります。イベントトリガーメカニズムに基づいて、SAX は XML ファイルを 1 回スキャンして処理を完了します。...
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート