1. はじめに
XML は明確なツリー状の階層構造を持ち、設定ファイルとして非常に適しています。 DOM XML を PHP で使用して XML を操作できます。この記事では、PHP が DOM XML を使用して XML ファイルを作成、追加し、クエリを実行する方法について概要を説明します。
2. DOM XML を使用する
XML のノードは要素とテキストに分かれています。DOMDocument 型はドキュメント型であり、要素とテキストを操作するためのメンバー関数と属性を提供します。
DOMDocument クラスは次のとおりです:
コードをコピー
DOMDocument は DOMNode を拡張します {
/* プロパティ */
読み取り専用パブリック文字列 $actualEncoding ;
readonly public DOMConfiguration $config ;
読み取り専用 public DOMDocumentType $doctype ;
readonly public DOMElement $documentElement ;
パブリック文字列 $documentURI ;
パブリック文字列 $encoding ;
パブリック ブール $formatOutput ;
readonly public DOMImplementation $implementation ;
public bool $preserveWhiteSpace =true ;
パブリックブール $recover ;
public bool $resolveExternals ;
パブリックブール $スタンドアロン ;
public bool $strictErrorChecking =true ;
パブリック ブール $substituteEntities ;
パブリックブール $validateOnParse =false ;
パブリック文字列 $version ;
読み取り専用パブリック文字列 $xmlEncoding ;
パブリック ブール $xmlStandalone ;
パブリック文字列 $xmlVersion ;
/* メソッド */
__construct ([ string $version [, string $encoding ]] )
DOMAttr createAttribute ( string $name )
DOMAttr createAttributeNS ( string $namespaceURI , string $qualifiedName )
DOMCDATASection createCDATASection ( string $data )
DOMComment createComment ( string $data )
DOMDocumentFragment createDocumentFragment (void)
DOMElement createElement ( string $name [, string $value ] )
DOMElement createElementNS ( string $namespaceURI , string $qualifiedName [, string $value ] )
DOMEntityReference createEntityReference ( string $name )
DOMProcessing命令 createProcessing命令 ( string $target [, string $data ] )
DOMText createTextNode ( string $content )
DOMElement getElementById ( string $elementId )
DOMNodeList getElementsByTagName ( string $name )
DOMNodeList getElementsByTagNameNS ( string $namespaceURI , string $localName )
DOMNode importNode ( DOMNode $importedNode [, bool $deep ] )
混合ロード ( string $filename [, int $options=0 ] )
bool loadHTML ( string $source )
bool loadHTMLFile ( string $filename )
混合ロードXML ( string $source [, int $options=0 ] )
void NormalizeDocument ( void )
bool registerNodeClass ( string $baseclass , string $extendedclass )
bool RelaxNGValidate ( string $filename )
bool RelaxNGValidateSource ( string $source )
int save ( string $filename [, int $options ] )
文字列 saveHTML (void)
int saveHTMLFile ( string $filename )
string saveXML ([ DOMNode $node [, int $options ]] )
bool schemaValidate ( string $filename )
bool schemaValidateSource ( string $source )
bool validate (void)
int xinclude ([ int $options ] )
/* 継承されたメソッド */
DOMNode DOMNode::appendChild ( DOMNode $newnode )
DOMNode DOMNode::cloneNode ([ bool $deep ] )
bool DOMNode::hasAttributes (void)
bool DOMNode::hasChildNodes (void)
DOMNode DOMNode::insertBefore ( DOMNode $newnode [, DOMNode $refnode ] )
bool DOMNode::isDefaultNamespace ( string $namespaceURI )
bool DOMNode::isSameNode ( DOMNode $node )
bool DOMNode::isSupported ( string $feature , string $version )
string DOMNode::lookupNamespaceURI ( string $prefix )
string DOMNode::lookupPrefix ( string $namespaceURI )
void DOMNode::normalize ( void )
DOMNode DOMNode::removeChild ( DOMNode $oldnode )
DOMNode DOMNode::replaceChild ( DOMNode $newnode , DOMNode $oldnode )
}
コードをコピー
要素ノード クラスの DOMElement タイプは次のように定義されます:
コードをコピー
1 DOMElement は DOMNode を拡張します {
2 /* プロパティ */
3 読み取り専用 public bool $schemaTypeInfo ;
4 読み取り専用パブリック文字列 $tagName ;
5 /* メソッド */
6 __construct ( string $name [, string $value [, string $namespaceURI ]] )
7 文字列 getAttribute ( string $name )
8 DOMAttr getAttributeNode ( string $name )
9 DOMAttr getAttributeNodeNS ( string $namespaceURI , string $localName )
10 string getAttributeNS ( string $namespaceURI , string $localName )
11 DOMNodeList getElementsByTagName ( string $name )
12 DOMNodeList getElementsByTagNameNS ( string $namespaceURI , string $localName )
13 bool hasAttribute ( string $name )
14 bool hasAttributeNS ( string $namespaceURI , string $localName )
15 bool RemoveAttribute ( string $name )
16 bool RemoveAttributeNode ( DOMAttr $oldnode )
17 bool RemoveAttributeNS ( string $namespaceURI , string $localName )
18 DOMAttr setAttribute ( string $name , string $value )
19 DOMAttr setAttributeNode ( DOMAttr $attr )
20 DOMAttr setAttributeNodeNS ( DOMAttr $attr )
21 void setAttributeNS ( string $namespaceURI , string $qualifiedName , string $value )
22 void setIdAttribute ( string $name , bool $isId )
23 void setIdAttributeNode ( DOMAttr $attr , bool $isId )
24 void setIdAttributeNS ( string $namespaceURI , string $localName , bool $isId )
25 /* 継承されたメソッド */
26 DOMNode DOMNode::appendChild ( DOMNode $newnode )
27 DOMNode DOMNode::cloneNode ([ bool $deep ] )
28 bool DOMNode::hasAttributes ( void )
29 bool DOMNode::hasChildNodes ( void )
30 DOMNode DOMNode::insertBefore ( DOMNode $newnode [, DOMNode $refnode ] )
31 bool DOMNode::isDefaultNamespace ( string $namespaceURI )
32 bool DOMNode::isSameNode ( DOMNode $node )
33 bool DOMNode::isSupported ( string $feature , string $version )
34 string DOMNode::lookupNamespaceURI ( string $prefix )
35 string DOMNode::lookupPrefix ( string $namespaceURI )
36 void DOMNode::normalize ( void )
37 DOMNode DOMNode::removeChild ( DOMNode $oldnode )
38 DOMNode DOMNode::replaceChild ( DOMNode $newnode , DOMNode $oldnode )
39 }
复制代
文本型 DOMText 定義如下:
复制代
DOMText は DOMCharacterData を拡張します {
/* プロパティ */
読み取り専用パブリック文字列 $wholeText ;
/* メソッド */
__construct ([ string $value ] )
bool isWhitespaceInElementContent ( void )
DOMText SplitText ( int $offset )
/* 継承されたメソッド */
void DOMCharacterData::appendData ( string $data )
void DOMCharacterData::deleteData ( int $offset , int $count )
void DOMCharacterData::insertData ( int $offset , string $data )
void DOMCharacterData::replaceData ( int $offset , int $count , string $data )
string DOMCharacterData::substringData ( int $offset , int $count )
}
复制代
DOMNode 点の定義は以下の通り:
复制代
DOMNode {
/* プロパティ */
パブリック読み取り専用文字列 $nodeName ;
パブリック文字列 $nodeValue ;
パブリック readonly int $nodeType ;
パブリック読み取り専用 DOMNode $parentNode ;
パブリック読み取り専用 DOMNodeList $childNodes ;
パブリック読み取り専用 DOMNode $firstChild ;
パブリック読み取り専用 DOMNode $lastChild ;
public readonly DOMNode $previousSibling ;
パブリック読み取り専用 DOMNode $nextSibling ;
パブリック読み取り専用 DOMNamedNodeMap $attributes ;
パブリック読み取り専用 DOMDocument $ownerDocument ;
パブリック読み取り専用文字列 $namespaceURI ;
パブリック文字列 $prefix ;
パブリック読み取り専用文字列 $localName ;
パブリック読み取り専用文字列 $baseURI ;
パブリック文字列 $textContent ;
/* メソッド */
DOMNode appendChild ( DOMNode $newnode )
DOMNode cloneNode ([ bool $deep ] )
bool hasAttributes ( void )
bool hasChildNodes ( void )
DOMNode insertBefore ( DOMNode $newnode [, DOMNode $refnode ] )
bool isDefaultNamespace ( string $namespaceURI )
bool isSameNode ( DOMNode $node )
bool isSupported ( string $feature , string $version )
文字列 lookupNamespaceURI ( string $prefix )
文字列 lookupPrefix ( string $namespaceURI )
void 正規化 ( void )
DOMNode deleteChild ( DOMNode $oldnode )
DOMNode replaceChild ( DOMNode $newnode 、 DOMNode $oldnode )
}
复制代
3、测试程序
复制代
1
2
3 const INDEX_FILE_NAME = "student_file_index.xml";
4
5 //文件インデックス类
6 クラス file_index
7 {
8 パブリック関数 set_file_index($file_name, $cur_count, $total_count)
9 {
10 $this->file_name = $file_name;
11 $this->cur_count = $cur_count;
12 $this->total_count = $total_count;
13 }
14 パブリック関数 get_file_name()
15 {
16 return $this->file_name;
17 }
18 パブリック関数 get_cur_count()
19 {
20 return $this->cur_count;
21 }
22 パブリック関数 get_total_count()
23 {
24 return $this->total_count;
25 }
26
27 プライベート $file_name; //文件名
28 private $cur_count; //現在のレコード数
29 private $total_count; //レコードの総数
30}
31
32 関数 create_file_index(array $params)
33 {
34 $index = new file_index();
35 $index->set_file_index($params['file_name'],
36 $params['cur_count'], $params['total_count']);
37 return $index;
38}
39
40 function create_file_node(DOMDocument $doc, file_index $index)
41 {
42 //ファイル要素を作成します
43 $file = $doc->createElement("file");
44 //属性要素を作成します
45 $name_attr = $doc->createAttribute("name");
46 //この属性をファイル要素に追加します
47 $file->appendChild($name_attr);
48
49 //テキスト要素を作成します
50 $file_name = $doc->createTextNode($index->get_file_name());
51 //name_attr 属性をテキスト要素に追加します
52 $name_attr->appendChild($file_name);
53
54 //cur_count 要素を作成します
55 $cur_count = $doc->createElement("cur_count", strval($index->get_cur_count()));
56 //ファイル要素に cur_count を追加します
57 $cur_count = $file->appendChild($cur_count);
58
59 //total_count 要素を作成します
60 $total_count = $doc->createElement("total_count",
61 strval($index->get_total_count()));
62 //total_count をファイル要素に追加します
63 $total_count = $file->appendChild($total_count);
64
65 return $file;
66 }
67
68 関数 create_index_file($index_file_name, array $params)
69 {
70 //ドキュメントを作成します
71 $doc = new DOMDocument("1.0", "utf-8");
72 //ルート要素を作成
73 $root = $doc->createElement("index");
74 $root = $doc->appendChild($root);
75
76 //インデックス構造を作成します
77 $index = create_file_index($params);
78 $file = create_file_node($doc, $index);
79
80 //ルート要素以下のファイルを表示
81 $root->appendChild($file);
82 $doc->save($index_file_name);
83 true を返します
84 }
85
86 関数 add_index_file($index_file_name, array $params)
87 {
88 //ドキュメントを作成します
89 $doc = 新しい DOMDocument();
90 //xml ファイルをロード
91 $doc->load($index_file_name);
92 //インデックス要素リストを取得します
93 $node_list = $doc->getElementsByTagName('index');
94 //ルート要素を取得します
95 $root = $node_list->item(0);
96 //インデックス構造を作成します
97 $index = create_file_index($params);
98 $file = create_file_node($doc, $index);
99 //ルート要素の下のファイルを参照
100 $root->appendChild($file);
101 $doc->save($index_file_name);
102}
103
104 関数 traverse_file_index($index_file_name)
105 {
106 $file_index = array();
107 $doc = new DOMDocument();
108 $doc->load($index_file_name);
109 //ファイル要素のコレクションを取得します
110 $file_list = $doc->getElementsByTagName('file');
111 //cur_count 要素コレクションを取得
112 $cur_count_list = $doc->getElementsByTagName('cur_count');
113 //total_count 要素コレクションを取得します
114 $total_count_list = $doc->getElementsByTagName('total_count');
115 for ($i = 0; $i length; $i++) {
116 $index = new file_index();
117 //ファイル要素のname属性値を取得します
118 $file_name = $file_list->item($i)->attributes->getNamedItem("name")->nodeValue;
119 $index->set_file_index($file_name, $cur_count_list->item($i)->nodeValue,
120 $total_count_list->item($i)->nodeValue);
121 $file_index[$i] = $index;
122 }
123
124 return $file_index;
125 }
126
127 /*****************テスト用*********************/
128 $params = array();
129 $index_file_name = INDEX_FILE_NAME;
130
131 if (file_exists($index_file_name)) {
132 $params['file_name'] = "student_info_2014_02_12";
133 $params['cur_count'] = 10;
134 $params['total_count'] = 10;
135 echo "file.n にインデックスを追加";
136 add_index_file($index_file_name, $params);
137 }
138 他 {
139 $params['file_name'] = "student_info_2014_02_11";
140 $params['cur_count'] = 23;
141 $params['total_count'] = 33;
142 echo "インデックスファイルを作成.n";
143 create_index_file($index_file_name, $params);
144 }
145
146 //测试读取xm文件
147 echo "「.$index_file_name."n からインデックスの内容を読み取ります」;
148 echo "file_nametttcur_countttotal_count.n";
149 $file_index = traverse_file_index($index_file_name);
150 foreach($file_index as $index) {
151 echo $index->get_file_name();
152 echo "tt ";
153 echo $index->get_cur_count();
154 echo strval($cur_count);
155 echo "tt ";
156 echo $index->get_total_count();
157 echo "n";
158 }