【问题标题】:Nested Object write to mysql with php嵌套对象使用 php 写入 mysql
【发布时间】:2017-03-26 03:45:21
【问题描述】:

我想加载一个 xml 文件,过滤并将几行放入数据库。到目前为止,它可以加载、解析为字符串、过滤。但是我怎样才能正确访问对象的第二级呢?

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:

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;}
        }; 
};

它适用于 $litm 但不适用于其他值。如何将最后一个更改为部分以获得第二级的正确值?非常感谢您花时间帮助我。

【问题讨论】:

    标签: php mysql object multidimensional-array


    【解决方案1】:

    最后三个变量是价格的子项。所以你需要改变

    $inpr = $row -> INPR;
    $expr = $row -> EXPR;
    $ecpr = $row -> ECPR;
    

    $inpr = $row -> price -> INPR;
    $expr = $row -> price -> EXPR;
    $ecpr = $row -> price -> ECPR;
    

    【讨论】:

    • 这么简单的解决方案?你太棒了,它有效 :) 再给我 8 分钟来接受你的答案!非常感谢!!
    猜你喜欢
    • 1970-01-01
    • 2015-07-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-12-29
    • 2018-06-19
    • 2013-04-07
    相关资源
    最近更新 更多