xml
/*
(c) 2000 Hans Anderson Corporation. 無断転載を禁じます。
このクラスは、PHP ライセンスにあるのと同じ
ガイドラインに基づいて自由に使用および変更できます。
-----------
バグ/私:
http://www.hansanderson.com/php/
me@hansanderson.com
showstv@163.com
---- -------
バージョン 1.0
- 1.0 は、クラスの最初の実際のリリースです。
ついに私が望んでいたものになりましたが、
まだいくつかのバグがある可能性があります。 これは
大幅に変更されたバージョンです。
以前のバージョンをダウンロードしている場合、これは既存の
スクリプトでは動作しません。 いくつかの簡単な変更を加える必要があります。
- .92 ではタグ属性が含まれていないバグが修正されました
(属性を使用するには、問題のタグの末尾に _attributes[array_index]
$xml_html_head_body_im を追加します。 g は
$xml_html_head_body_img_attributes[0],
になります例)
-- Nick Winfield
このバグを報告してください。
- .91 では PHP4 は不要になりました。
- .91 では、すべての要素が配列になりました。 オブジェクトの使用は
廃止されました。
*/
class xml_container{
function store($k,$v) {
$this->{$k}[] = $v;
}
}
/* 情報を解析します */
/**********************************
* クラス定義が始まります
*
*********** **********************/
class xml{
// いくつかの変数を初期化します
var $current_tag=array();
var $xml_parser;
var $Version = 1.0;
var $tagtracker = array();
/* expat に必要な XML 関数は次のとおりです */
/* expat が開始タグにヒットすると、この関数が起動されます */
function startElement($parser, $name, $attrs){
array_push ($this->current_tag, $name); // cur にタグを追加します。タグ配列
$curtag = implode("_",$this->current_tag); // タグを結合します
/* これは、このタグの配列インデックスを追跡します */
if(isset($this->tagtracker["$curtag"])) {
$this->tagtracker ["$curtag"]++;
}
else{
$this->tagtracker["$curtag"]=0;
}
/* このタグに属性がある場合は、ここで設定します。 */
if(count($attrs)>0) {
$j = $this->tagtracker["$curtag"];
if(!$j) $j = 0;
if(!is_object($GLOBALS[$this->identifier]["$curtag"][$j])) {
$GLOBALS[$this->identifier]["$curtag"][$j] =新しいxml_container;
}
$GLOBALS[$this->identifier]["$curtag"][$j]->store("attributes",$attrs);
}
} // end関数startelement ,$this->current_tag); // タグ
// 外す前に
// 正しい
// cdata
if(!$this->tagdata["$curtag"])
{ $ポップ= array_pop($this->current_tag); // そうしないと、今いる場所が台無しになってしまいます
return; // タグのデータがない場合
}
else{
$TD = $this->tagdata["$curtag"];
unset($this->tagdata["$curtag"]);
}
$popped = array_pop($this->current_tag);
//
// この上のタグを指定する必要があります。これにより、
//
// より直感的な方法で
タグをグループ化できます。
if(sizeof($this->current_tag) == 0) return; // タグ内にない場合
$curtag = implode("_",$this->current_tag); // タグ
// 今回は配列
$j = $this->tagtracker["$curtag"];
if(!$j) $j = 0;
if(!is_object($GLOBALS[$this->identifier]["$curtag"][$j])) {
$GLOBALS[$this->identifier]["$curtag"][$j] ] = 新しい xml_container;
}
$GLOBALS[$this->identifier]["$curtag"][$j]->store($name,$TD);
#$this->tagdata["$curtag"] );
設定解除($TD);
TRUE を返します。
} // 関数 endElement
/* expat が内部タグ文字データを見つけると、
この関数が起動されます */
function CharacterData($parser, $cdata) {
$curtag = implode("_" ,$this->current_tag); // タグ
$this->tagdata["$curtag"] .= $cdata; を結合します。
}
関数 xml($data,$identifier='xml') {
$this->identifier = $identifier;
// パーサーオブジェクトを作成します
$this->xml_parser = xml_parser_create();
// いくつかのオプションとハンドラーを設定します
xml_set_object($this->xml_parser,$this);
xml_parser_set_option($this->xml_parser,XML_OPTION_CASE_FOLDING,0);
xml_set_element_handler($this->xml_parser, "startElement", "endElement");
xml_set_character_data_handler($this->xml_parser, "characterData");
if (!xml_parse($this->xml_parser, $data, TRUE)) {
sprintf("XML エラー: %d 行目 %s"
xml_error_string(xml_get_error_code($this-> xml_parser))、
xml_get_current_line_number($this->xml_parser));
}
// パーサーの使用は完了したので、解放しましょう
xml_parser_free($this->xml_parser);
}//コンストラクターの終了: function xml()
}//こうして、クラス xml を終了します
?>
操作方法:
require('class.xml.php');
$file = "data.xml";
$data = implode("",file($file)) または die("XML 入力ファイルを開けませんでした");
$obj = 新しい xml($data,"xml");
print $xml["hans"][0]->num_results[0];
for($i=0;$i
}
URL 属性を出力するには (存在する場合):
print $xml["hans"][0]->attributes[0]["size"];