将属性与opencart中的产品相关联以生成xml文件

时间:2014-04-14 23:32:32

标签: php xml opencart

过去几个小时我试图生成像这样的

的xml文件
<?xml version="1.0" encoding="UTF-8"?>
<mywebstore>
   <created_at>2010-04-08 12:32</created_at>
   <products>
      <product>
          <id>322233</id>
          <name><![CDATA[MadBiker 600 Black Polarized]]></name>
          <link><![CDATA[http://www.mywebstore.gr/product/322233]]></link>
          <image><![CDATA[http://www.mywebstore.gr/product/322233.jpg]]></image>
          <category id="23"><![CDATA[Sports > Extreme Sports]]></category>
          <price_with_vat>322.33</price_with_vat>
          <manufacturer><![CDATA[SuperGlasses]]></manufacturer>
          <description><![CDATA[This is the description.....]]></description>
          <weight>350</weight>
          <mpn>ZHD332</mpn>
          <instock>N</instock>
          <availability>Pre-order</availability>
      </product>
      <product>
       ...
      </product>
   </products>
</mywebstore>

来自opencart。

我写了这段代码

<?php
class ControllerFeedSkroutzXml extends Controller {
    public function index() {
        $this->language->load('feed/skroutz_xml');

        if ($this->config->get('skroutz_xml_status')) {
            $output  = '<?xml version="1.0" encoding="UTF-8"?>';
            $output .= '<mywebstore>';
            $output .= '<created_at>' . date('Y-m-d H:i') . '</created_at>';
            $output .= '<products>';

            $this->load->model('catalog/product');

            $products = $this->model_catalog_product->getProducts();

            foreach ($products as $product) {

                $attribute_groups = $this->model_catalog_product->getProductAttributes($product['product_id']);
                //print_r($attribute_groups);
                if (!empty($attribute_groups)) {
                    foreach ($attribute_groups as $attribute_group) {
                        if (!empty($attribute_group)) {
                            foreach ($attribute_group['attribute'] as $attribute) {
                                $attribute = array_filter($attribute);
                                if (!empty($attribute)) {
                                    // [attribute_id] => 13, Color
                                    if ($attribute['attribute_id'] == 13 && $attribute['text'] != '') {
                                        $attribute_color = $attribute['text'];
                                    }
                                    // [attribute_id] => 16, Lens Technology
                                    if ($attribute['attribute_id'] == 16 && $attribute['text'] != '') {
                                        $attribute_lens_technology = $attribute['text'];
                                    }
                                }
                            }                           
                        }
                    }
                }

                if ($product['special']) {
                    $final_price = number_format((float)$product['special'], 2, '.', '');
                } else {
                    $final_price = number_format((float)$product['price'], 2, '.', '');
                }
                if ($product['quantity'] > 0) {
                    $instock = $this->language->get('instock_Y');
                } else {
                    $instock = $this->language->get('instock_N');
                }

                $output .= '<product>';
                $output .= '<id>' . $product['product_id'] . '</id>';
                $output .= '<name><![CDATA[' . $this->language->get('category_name') . ' ' . $product['name'] . ' ' . $attribute_color . ' ' . $attribute_lens_technology . ']]></name>';
                $output .= '<link><![CDATA[' . $this->url->link('product/product', 'product_id=' . $product['product_id']) . ']]></link>';
                $output .= '<image><![CDATA['. HTTP_IMAGE . $product['image'] . ']]></image>';
                $output .= '<category id="' . $product['manufacturer_id'] . '"><![CDATA[ ' . $this->language->get('category_name') . ' > ' . $product['manufacturer'] . ' ]]></category>';
                $output .= '<price_with_vat>' . $final_price . '</price_with_vat>';
                $output .= '<manufacturer><![CDATA[' . $product['manufacturer'] . ']]></manufacturer>';
                $output .= '<description><![CDATA[' . $product['meta_description'] . ']]></description>';
                $output .= '<instock>' . $instock . '</instock>';
                $output .= '<availability>' . $product['stock_status'] . '</availability>';
                $output .= '</product>';
            }

            $output .= '</products>';
            $output .= '</mywebstore>';

            $this->response->addHeader('Content-Type: application/xml');
            $this->response->setOutput($output);
        }
    }
}
?>

但是生成属性的代码块并没有像预期的那样工作 我的很多产品都没有属性(至少现在还没有),所以我想要完成的是在产品名称旁边显示属性

示例
姓名: MadBiker 600
属性 - 颜色:黑色
属性 - 镜头技术:极化

全部<name>MadBiker 600 Black Polarized</name>

仅当产品具有属性时 上面的php代码为所有空属性产品生成<name>MadBiker 600 Black Polarized</name>,直到找到具有属性的下一个产品!

有人可以指出问题在哪里吗?

谢谢!

2 个答案:

答案 0 :(得分:3)

您没有在foreach的每次迭代中重置$attribute_lens_technology$attribute_color。您需要在foreach循环定义

之后重置这些

新的foreach循环:

        foreach ($products as $product) {
            $attribute_lens_technology = false;
            $attribute_color = false;

            $attribute_groups = $this->model_catalog_product->getProductAttributes($product['product_id']);
            //print_r($attribute_groups);
            if (!empty($attribute_groups)) {
                foreach ($attribute_groups as $attribute_group) {
                    if (!empty($attribute_group)) {
                        foreach ($attribute_group['attribute'] as $attribute) {
                            $attribute = array_filter($attribute);
                            if (!empty($attribute)) {
                                // [attribute_id] => 13, Color
                                if ($attribute['attribute_id'] == 13 && $attribute['text'] != '') {
                                    $attribute_color = $attribute['text'];
                                }
                                // [attribute_id] => 16, Lens Technology
                                if ($attribute['attribute_id'] == 16 && $attribute['text'] != '') {
                                    $attribute_lens_technology = $attribute['text'];
                                }
                            }
                        }                           
                    }
                }
            }

            if ($attribute_lens_technology === false || $attribute_color === false) {
                // Code here such as continue; if you want to skip products without both attributes
            }

            if ($product['special']) {
                $final_price = number_format((float)$product['special'], 2, '.', '');
            } else {
                $final_price = number_format((float)$product['price'], 2, '.', '');
            }
            if ($product['quantity'] > 0) {
                $instock = $this->language->get('instock_Y');
            } else {
                $instock = $this->language->get('instock_N');
            }

            $output .= '<product>';
            $output .= '<id>' . $product['product_id'] . '</id>';
            $output .= '<name><![CDATA[' . $this->language->get('category_name') . ' ' . $product['name'] . ' ' . $attribute_color . ' ' . $attribute_lens_technology . ']]></name>';
            $output .= '<link><![CDATA[' . $this->url->link('product/product', 'product_id=' . $product['product_id']) . ']]></link>';
            $output .= '<image><![CDATA['. HTTP_IMAGE . $product['image'] . ']]></image>';
            $output .= '<category id="' . $product['manufacturer_id'] . '"><![CDATA[ ' . $this->language->get('category_name') . ' > ' . $product['manufacturer'] . ' ]]></category>';
            $output .= '<price_with_vat>' . $final_price . '</price_with_vat>';
            $output .= '<manufacturer><![CDATA[' . $product['manufacturer'] . ']]></manufacturer>';
            $output .= '<description><![CDATA[' . $product['meta_description'] . ']]></description>';
            $output .= '<instock>' . $instock . '</instock>';
            $output .= '<availability>' . $product['stock_status'] . '</availability>';
            $output .= '</product>';
        }

答案 1 :(得分:1)

使用simplexml编写xml文件比手动尝试输出自己的文件更容易。

尽管如此,这里有一个简单的简写if if语句来解决你的问题(如果属性颜色为空,它会附加一个空字符串代替:

$output .= !empty($attribute_color) ? '<name><![CDATA[' . $this->language->get('category_name') . ' ' . $product['name'] . ' ' . $attribute_color . ' ' . $attribute_lens_technology . ']]></name>' : '';