"/>
ホームページ >バックエンド開発 >PHPチュートリアル >PHPを介したXMLデータの抽出に関連する問題
php を介して xml からデータを抽出する問題
php には xml からデータを取得する方法がたくさんあることはわかっていますが、最も便利な方法は正規表現を使用することですが、DOM メソッドを使用する場合はどうすればよいですか?
百度で調べたのですがよく分かりません神様に教えて下さい。
例:
c864734421efd9a00df58f7b8521d7a5
04d935e74d336086d9e64c3b6a5b17abe014ece7d12df732a4e3dd019e3e87f320110524fc270db6b7c3b1cf107e6ade50d25b3e
09073e174b952eabc4abd78dd75aedf5
b11e21885d926e706e6b12d79ae6d198
9f277a99d996bf85f76cb316e6c2fad72a12cc85bc2d6ead78baa7096b03a4a313.79cb8e0afa29105ae9463e55473c96400f
5f71d47c48e69338ac457f65b7b21814
c0859a6f2cc2c5802f803f06a13f8b5c<値>13.85値>
アイテム>
レコード>
20110525値>
09073e174b952eabc4abd78dd75aedf5
1b0ae0c24db67e00cb14d27620c58584e014ece7d12df732a4e3dd019e3e87f313.82fc270db6b7c3b1cf107e6ade50d25b3e
09073e174b952eabc4abd78dd75aedf5
6e5516fd43d64e281c31f7686371816813.86値>
アイテム>
13.58
アイテム> ;
7d5cfa523801dfba0a72a055b4f15a88e014ece7d12df732a4e3dd019e3e87f313.60fc270db6b7c3b1cf107e6ade50d25b3e
09073e174b952eabc4abd78dd75aedf5
598d07110c9eebaa994d52351404d20a
xml のこの段落が必要ですid 属性を通じて対応する値を取得するにはどうすればよいですか?
私は現在最初のカテゴリにいます:
preg_match_all( "/e014ece7d12df732a4e3dd019e3e87f3(.*?)fc270db6b7c3b1cf107e6ade50d25b3e/", $Result, $array ); 値を取得した後に動作します。 >いいえ、2 つのタイプがあります:
$doc = new DOMDocument();
$doc->load('sixx.xml'); //XML ファイルを読み込みます
$Results = $doc-> getElementsByTagName( "レコード" );
foreach($Results as $Result){
$Records = $Result->getElementsByTagName("Item");
$times = $Records->item( 0) ->nodeValue;
}
ID を使用せずに操作を続行します
XML ID を使用してデータを取得するとどうなるかを知りたいです。
getElementById() を使用して取得しようとしましたが、そのようなメソッドはないと言われました。 。 。
未定義のメソッド DOMElement::getElementById() を呼び出します。
この質問に答えることができるよう神様にお願いしてください、ありがとう。
------解決策のアイデア----------------------
$s =<<< XML<br /><root><br /><Record><br /><Item Id="1"><Value>20110524</Value><br /></Item><br /><Item Id="7"><Value>13.82</Value><br /></Item><br /><Item Id="8"><Value>13.94</Value><br /></Item><br /><Item Id="9"><Value>13.79</Value><br /></Item><br /><Item Id="11"><Value>13.85</Value><br /></Item><br /></Record><br /><Record><Item Id="1"><Value>20110525</Value><br /></Item><br /><Item Id="7"><Value>13.82</Value><br /></Item><br /><Item Id="8"><Value>13.86</Value><br /></Item><br /><Item Id="9"><Value>13.58</Value><br /></Item><br /><Item Id="11"><Value>13.60</Value><br /></Item><br /></Record><br /></root><br />XML;<br />$xml = simplexml_load_string($s);<br />$t = $xml->xpath('//*[@Id="8"]');<br />print_r($t);
Array<br />(<br /> [0] => SimpleXMLElement Object<br /> (<br /> [@attributes] => Array<br /> (<br /> [Id] => 8<br /> )<br /><br /> [Value] => 13.94<br /> )<br /><br /> [1] => SimpleXMLElement Object<br /> (<br /> [@attributes] => Array<br /> (<br /> [Id] => 8<br /> )<br /><br /> [Value] => 13.86<br /> )<br /><br />)<br /><br />
<?php<br />$xml = simplexml_load_file('6.xml');<br />foreach( $xml->Item as $a ){<br /> echo $a->Value . '<br>';<br />}
20110524<br />13.82<br />13.94<br />13.79<br />13.85<br />20110525<br />13.82<br />13.86<br />13.58<br />13.60<br />