1
xmlファイルを読み込んでフィルターにかけ、データベースにいくつかの行を入れたいと思います。これまでは、文字列を解析して読み込み、解析します。しかし、どのようにしてオブジェクトの第2レベルに正しくアクセスできますか?ネストされたオブジェクトphpでmysqlに書き込む
object(SimpleXMLElement)#2 (2) {
["message_header"]=> object(SimpleXMLElement)#3 (1){
["@attributes"]=> array(6) {
["source"]=> string(10) "Alltron AG"
["message_type"]=> string(5) "price"
["document_version_date"]=> string(10) "12.07.2013"
["document_version"]=> string(4) "2.00"
["generation_date"]=> string(10) "11.11.2016"
["generation_time"]=> string(8) " 2:58:02" } }
["item"]=> array(85715) {
[0]=> object(SimpleXMLElement)#4 (2) {
["LITM"]=> string(4) "1289"
["price"]=> object(SimpleXMLElement)#85719 (4) {
["INPR"]=> string(5) "34.25"
["EXPR"]=> string(5) "31.71"
["VATR"]=> string(1) "8"
["ECPR"]=> string(2) "45" } }
[1]=> object(SimpleXMLElement)#5 (2) {
["LITM"]=> string(4) "1510"
and so on...
は、今私は、負荷で始まり、解析:
$data = file_get_contents("../cache/PreisdatenV2.xml");
$xml = simplexml_load_string($data);
とのforeachと:それは他の値のための$ litmではなく罰金働いて
foreach ($xml -> item as $row){
$litm = $row -> LITM;
$inpr = $row -> INPR;
$expr = $row -> EXPR;
$ecpr = $row -> ECPR;
if ($litm == 1289)
{
$sql = "INSERT INTO `preisdaten`(`litm`,`inpr`,`expr`,`ecpr`)" .
"VALUES ('$litm','$inpr','$expr','$ecpr')";
if ($conn->query($sql) === FALSE) {echo "Error: " . $sql . "
<br>" . $conn->error;}
};
};
。 2番目のレベルの正しい値を得るために最後の部分をどのように変更できますか?私を助けるためにあなたの時間を費やしてくれてありがとう。
、このような簡単な解決策を変更する必要がありますか?あなたの偉大な、それは動作します:)あなたの答えを受け入れるために私に8分を与える!どうもありがとうございました!! –