Jump to content
Sign in to follow this  
Briz

google base

Recommended Posts

Подскажите как можно сделать чтобы в файле google_base показывало только 200 шт товаров, а не все ( потому как их ооочень много). Что нужно дописать в коде? осторе 1.5.4.1 . спасибо большое

Share this post


Link to post
Share on other sites
33 минуты назад, Briz сказал:

Подскажите как можно сделать чтобы в файле google_base показывало только 200 шт товаров, а не все ( потому как их ооочень много). Что нужно дописать в коде? осторе 1.5.4.1 . спасибо большое

Можете скинуть код файла контроллера google base?

Share this post


Link to post
Share on other sites
6 минут назад, flai0616 сказал:

Можете скинуть код файла контроллера google base?

Спойлер

<?php 
class ControllerFeedGoogleBase extends Controller {
    public function index() {
        if ($this->config->get('google_base_status')) { 
            $output  = '<?xml version="1.0" encoding="UTF-8" ?>';
            $output .= '<rss version="2.0" xmlns:g="http://base.google.com/ns/1.0">';
            $output .= '<channel>';
            $output .= '<title>' . $this->config->get('config_name') . '</title>'; 
            $output .= '<description>' . $this->config->get('config_meta_description') . '</description>';
            $output .= '<link>' . HTTP_SERVER . '</link>';
            
            $this->load->model('catalog/category');
            
            $this->load->model('catalog/product');
            
            $this->load->model('tool/image');
            
            $products = $this->model_catalog_product->getProducts();
            
            foreach ($products as $product) {
                if ($product['description']) {
                    $output .= '<item>';
                    $output .= '<title>' . html_entity_decode($product['name'], ENT_QUOTES, 'UTF-8') . '</title>';
                    $output .= '<link>' . str_replace('&', '&amp;', str_replace('&amp;', '&', $this->url->link('product/product', 'product_id=' . $product['product_id']))) . '</link>';
                    $output .= '<description><![CDATA[' . strip_tags(html_entity_decode($product['description'], ENT_QUOTES, 'UTF-8')) . ']]></description>';
                    $output .= '<g:brand>' . html_entity_decode($product['manufacturer'], ENT_QUOTES, 'UTF-8') . '</g:brand>';
                    $output .= '<g:condition>new</g:condition>';
                    $output .= '<g:id>' . $product['product_id'] . '</g:id>';
                    
                    if ($product['image']) {
                        $output .= '<g:image_link>' . $this->model_tool_image->resize($product['image'], 500, 500) . '</g:image_link>';
                    } else {
                        $output .= '<g:image_link>' . $this->model_tool_image->resize('no_image.jpg', 500, 500) . '</g:image_link>';
                    }
                    
                    $output .= '<g:mpn>' . $product['model'] . '</g:mpn>';

                    $supported_currencies = array('UAH', 'USD', 'EUR', 'GBP');

                    if (in_array($this->currency->getCode(), $supported_currencies)) {
                        $currency = $this->currency->getCode();
                    } else {
                        $currency = ($this->config->get('google_base_status')) ? $this->config->get('google_base_status') : 'UAH';
                    }
                                    
                    if ((float)$product['special']) {
                        $output .= '<g:price>' .  $this->currency->format($this->tax->calculate($product['special'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                    } else {
                        $output .= '<g:price>' . $this->currency->format($this->tax->calculate($product['price'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                    }
               
                    $categories = $this->model_catalog_product->getCategories($product['product_id']);
                    
                    foreach ($categories as $category) {
                        $path = $this->getPath($category['category_id']);
                        
                        if ($path) {
                            $string = '';
                            
                            foreach (explode('_', $path) as $path_id) {
                                $category_info = $this->model_catalog_category->getCategory($path_id);
                                
                                if ($category_info) {
                                    if (!$string) {
                                        $string = $category_info['name'];
                                    } else {
                                        $string .= ' &gt; ' . $category_info['name'];
                                    }
                                }
                            }
                         
                            $output .= '<g:product_type>' . $string . '</g:product_type>';
                        }
                    }
                    
                    $output .= '<g:quantity>' . $product['quantity'] . '</g:quantity>';
                    $output .= '<g:upc>' . $product['upc'] . '</g:upc>'; 
                    $output .= '<g:weight>' . $this->weight->format($product['weight'], $product['weight_class_id']) . '</g:weight>'; 
                    $output .= '<g:availability>' . ($product['quantity'] ? 'in stock' : 'out of stock') . '</g:availability>';
                    $output .= '</item>';
                }
            }
            
            $output .= '</channel>'; 
            $output .= '</rss>';    
            
            $this->response->addHeader('Content-Type: application/rss+xml; charset=utf-8');
            $this->response->setOutput($output);
        }
    }
    
    protected function getPath($parent_id, $current_path = '') {
        $category_info = $this->model_catalog_category->getCategory($parent_id);
    
        if ($category_info) {
            if (!$current_path) {
                $new_path = $category_info['category_id'];
            } else {
                $new_path = $category_info['category_id'] . '_' . $current_path;
            }    
        
            $path = $this->getPath($category_info['parent_id'], $new_path);
                    
            if ($path) {
                return $path;
            } else {
                return $new_path;
            }
        }
    }        
}
?>

 

Share this post


Link to post
Share on other sites
48 минут назад, Briz сказал:

Подскажите как можно сделать чтобы в файле google_base показывало только 200 шт товаров, а не все ( потому как их ооочень много). Что нужно дописать в коде? осторе 1.5.4.1 . спасибо большое

Попробуйте этот код (сохраните исходник только:-)). Должно помочь

 

 

<?php 
class ControllerFeedGoogleBase extends Controller {
    public function index() {
        if ($this->config->get('google_base_status')) { 
            $output  = '<?xml version="1.0" encoding="UTF-8" ?>';
            $output .= '<rss version="2.0" xmlns:g="http://base.google.com/ns/1.0">';
            $output .= '<channel>';
            $output .= '<title>' . $this->config->get('config_name') . '</title>'; 
            $output .= '<description>' . $this->config->get('config_meta_description') . '</description>';
            $output .= '<link>' . HTTP_SERVER . '</link>';
            
            $this->load->model('catalog/category');
            
            $this->load->model('catalog/product');
            
            $this->load->model('tool/image');
            
            $products = $this->model_catalog_product->getProducts();
            
                foreach ($products as $product) {
                    for ($i = 0; $i <= 199; $i++) {    
                        if ($product['description']) {
                            $output .= '<item>';
                            $output .= '<title>' . html_entity_decode($product['name'], ENT_QUOTES, 'UTF-8') . '</title>';
                            $output .= '<link>' . str_replace('&', '&amp;', str_replace('&amp;', '&', $this->url->link('product/product', 'product_id=' . $product['product_id']))) . '</link>';
                            $output .= '<description><![CDATA[' . strip_tags(html_entity_decode($product['description'], ENT_QUOTES, 'UTF-8')) . ']]></description>';
                            $output .= '<g:brand>' . html_entity_decode($product['manufacturer'], ENT_QUOTES, 'UTF-8') . '</g:brand>';
                            $output .= '<g:condition>new</g:condition>';
                            $output .= '<g:id>' . $product['product_id'] . '</g:id>';
                            
                            if ($product['image']) {
                                $output .= '<g:image_link>' . $this->model_tool_image->resize($product['image'], 500, 500) . '</g:image_link>';
                            } else {
                                $output .= '<g:image_link>' . $this->model_tool_image->resize('no_image.jpg', 500, 500) . '</g:image_link>';
                            }
                            
                            $output .= '<g:mpn>' . $product['model'] . '</g:mpn>';

                            $supported_currencies = array('UAH', 'USD', 'EUR', 'GBP');

                            if (in_array($this->currency->getCode(), $supported_currencies)) {
                                $currency = $this->currency->getCode();
                            } else {
                                $currency = ($this->config->get('google_base_status')) ? $this->config->get('google_base_status') : 'UAH';
                            }
                                            
                            if ((float)$product['special']) {
                                $output .= '<g:price>' .  $this->currency->format($this->tax->calculate($product['special'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                            } else {
                                $output .= '<g:price>' . $this->currency->format($this->tax->calculate($product['price'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                            }
                       
                            $categories = $this->model_catalog_product->getCategories($product['product_id']);
                            
                            foreach ($categories as $category) {
                                $path = $this->getPath($category['category_id']);
                                
                                if ($path) {
                                    $string = '';
                                    
                                    foreach (explode('_', $path) as $path_id) {
                                        $category_info = $this->model_catalog_category->getCategory($path_id);
                                        
                                        if ($category_info) {
                                            if (!$string) {
                                                $string = $category_info['name'];
                                            } else {
                                                $string .= ' &gt; ' . $category_info['name'];
                                            }
                                        }
                                    }
                                 
                                    $output .= '<g:product_type>' . $string . '</g:product_type>';
                                }
                            }
                            
                            $output .= '<g:quantity>' . $product['quantity'] . '</g:quantity>';
                            $output .= '<g:upc>' . $product['upc'] . '</g:upc>'; 
                            $output .= '<g:weight>' . $this->weight->format($product['weight'], $product['weight_class_id']) . '</g:weight>'; 
                            $output .= '<g:availability>' . ($product['quantity'] ? 'in stock' : 'out of stock') . '</g:availability>';
                            $output .= '</item>';
                        }
                    }
                }

            $output .= '</channel>'; 
            $output .= '</rss>';    
            
            $this->response->addHeader('Content-Type: application/rss+xml; charset=utf-8');
            $this->response->setOutput($output);
        }
    }
    
    protected function getPath($parent_id, $current_path = '') {
        $category_info = $this->model_catalog_category->getCategory($parent_id);
    
        if ($category_info) {
            if (!$current_path) {
                $new_path = $category_info['category_id'];
            } else {
                $new_path = $category_info['category_id'] . '_' . $current_path;
            }    
        
            $path = $this->getPath($category_info['parent_id'], $new_path);
                    
            if ($path) {
                return $path;
            } else {
                return $new_path;
            }
        }
    }        
}
?>

 

Share this post


Link to post
Share on other sites
6 минут назад, flai0616 сказал:

Попробуйте этот код (сохраните исходник только:-)). Должно помочь

 

 

<?php 
class ControllerFeedGoogleBase extends Controller {
    public function index() {
        if ($this->config->get('google_base_status')) { 
            $output  = '<?xml version="1.0" encoding="UTF-8" ?>';
            $output .= '<rss version="2.0" xmlns:g="http://base.google.com/ns/1.0">';
            $output .= '<channel>';
            $output .= '<title>' . $this->config->get('config_name') . '</title>'; 
            $output .= '<description>' . $this->config->get('config_meta_description') . '</description>';
            $output .= '<link>' . HTTP_SERVER . '</link>';
            
            $this->load->model('catalog/category');
            
            $this->load->model('catalog/product');
            
            $this->load->model('tool/image');
            
            $products = $this->model_catalog_product->getProducts();
            
                foreach ($products as $product) {
                    for ($i = 0; $i <= 199; $i++) {    
                        if ($product['description']) {
                            $output .= '<item>';
                            $output .= '<title>' . html_entity_decode($product['name'], ENT_QUOTES, 'UTF-8') . '</title>';
                            $output .= '<link>' . str_replace('&', '&amp;', str_replace('&amp;', '&', $this->url->link('product/product', 'product_id=' . $product['product_id']))) . '</link>';
                            $output .= '<description><![CDATA[' . strip_tags(html_entity_decode($product['description'], ENT_QUOTES, 'UTF-8')) . ']]></description>';
                            $output .= '<g:brand>' . html_entity_decode($product['manufacturer'], ENT_QUOTES, 'UTF-8') . '</g:brand>';
                            $output .= '<g:condition>new</g:condition>';
                            $output .= '<g:id>' . $product['product_id'] . '</g:id>';
                            
                            if ($product['image']) {
                                $output .= '<g:image_link>' . $this->model_tool_image->resize($product['image'], 500, 500) . '</g:image_link>';
                            } else {
                                $output .= '<g:image_link>' . $this->model_tool_image->resize('no_image.jpg', 500, 500) . '</g:image_link>';
                            }
                            
                            $output .= '<g:mpn>' . $product['model'] . '</g:mpn>';

                            $supported_currencies = array('UAH', 'USD', 'EUR', 'GBP');

                            if (in_array($this->currency->getCode(), $supported_currencies)) {
                                $currency = $this->currency->getCode();
                            } else {
                                $currency = ($this->config->get('google_base_status')) ? $this->config->get('google_base_status') : 'UAH';
                            }
                                            
                            if ((float)$product['special']) {
                                $output .= '<g:price>' .  $this->currency->format($this->tax->calculate($product['special'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                            } else {
                                $output .= '<g:price>' . $this->currency->format($this->tax->calculate($product['price'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                            }
                       
                            $categories = $this->model_catalog_product->getCategories($product['product_id']);
                            
                            foreach ($categories as $category) {
                                $path = $this->getPath($category['category_id']);
                                
                                if ($path) {
                                    $string = '';
                                    
                                    foreach (explode('_', $path) as $path_id) {
                                        $category_info = $this->model_catalog_category->getCategory($path_id);
                                        
                                        if ($category_info) {
                                            if (!$string) {
                                                $string = $category_info['name'];
                                            } else {
                                                $string .= ' &gt; ' . $category_info['name'];
                                            }
                                        }
                                    }
                                 
                                    $output .= '<g:product_type>' . $string . '</g:product_type>';
                                }
                            }
                            
                            $output .= '<g:quantity>' . $product['quantity'] . '</g:quantity>';
                            $output .= '<g:upc>' . $product['upc'] . '</g:upc>'; 
                            $output .= '<g:weight>' . $this->weight->format($product['weight'], $product['weight_class_id']) . '</g:weight>'; 
                            $output .= '<g:availability>' . ($product['quantity'] ? 'in stock' : 'out of stock') . '</g:availability>';
                            $output .= '</item>';
                        }
                    }
                }

            $output .= '</channel>'; 
            $output .= '</rss>';    
            
            $this->response->addHeader('Content-Type: application/rss+xml; charset=utf-8');
            $this->response->setOutput($output);
        }
    }
    
    protected function getPath($parent_id, $current_path = '') {
        $category_info = $this->model_catalog_category->getCategory($parent_id);
    
        if ($category_info) {
            if (!$current_path) {
                $new_path = $category_info['category_id'];
            } else {
                $new_path = $category_info['category_id'] . '_' . $current_path;
            }    
        
            $path = $this->getPath($category_info['parent_id'], $new_path);
                    
            if ($path) {
                return $path;
            } else {
                return $new_path;
            }
        }
    }        
}
?>

 

что то выдает все ту же ошибку 
Fatal error: Allowed memory size of 268435456 bytes exhausted (tried to allocate 1024 bytes)

 

хотя если было 200 товара точно бы загрузилось 

Share this post


Link to post
Share on other sites
3 минуты назад, Briz сказал:

что то выдает все ту же ошибку 
Fatal error: Allowed memory size of 268435456 bytes exhausted (tried to allocate 1024 bytes)

 

хотя если было 200 товара точно бы загрузилось 

 

А если так?)

 

<?php 
class ControllerFeedGoogleBase extends Controller {
    public function index() {
        if ($this->config->get('google_base_status')) { 
            $output  = '<?xml version="1.0" encoding="UTF-8" ?>';
            $output .= '<rss version="2.0" xmlns:g="http://base.google.com/ns/1.0">';
            $output .= '<channel>';
            $output .= '<title>' . $this->config->get('config_name') . '</title>'; 
            $output .= '<description>' . $this->config->get('config_meta_description') . '</description>';
            $output .= '<link>' . HTTP_SERVER . '</link>';
            
            $this->load->model('catalog/category');
            
            $this->load->model('catalog/product');
            
            $this->load->model('tool/image');
            
            $products = $this->model_catalog_product->getProducts();
            
                foreach ($products as $product) {
                    if ($product['product_id'] <= 200) {  
                        if ($product['description']) {
                            $output .= '<item>';
                            $output .= '<title>' . html_entity_decode($product['name'], ENT_QUOTES, 'UTF-8') . '</title>';
                            $output .= '<link>' . str_replace('&', '&amp;', str_replace('&amp;', '&', $this->url->link('product/product', 'product_id=' . $product['product_id']))) . '</link>';
                            $output .= '<description><![CDATA[' . strip_tags(html_entity_decode($product['description'], ENT_QUOTES, 'UTF-8')) . ']]></description>';
                            $output .= '<g:brand>' . html_entity_decode($product['manufacturer'], ENT_QUOTES, 'UTF-8') . '</g:brand>';
                            $output .= '<g:condition>new</g:condition>';
                            $output .= '<g:id>' . $product['product_id'] . '</g:id>';
                            
                            if ($product['image']) {
                                $output .= '<g:image_link>' . $this->model_tool_image->resize($product['image'], 500, 500) . '</g:image_link>';
                            } else {
                                $output .= '<g:image_link>' . $this->model_tool_image->resize('no_image.jpg', 500, 500) . '</g:image_link>';
                            }
                            
                            $output .= '<g:mpn>' . $product['model'] . '</g:mpn>';

                            $supported_currencies = array('UAH', 'USD', 'EUR', 'GBP');

                            if (in_array($this->currency->getCode(), $supported_currencies)) {
                                $currency = $this->currency->getCode();
                            } else {
                                $currency = ($this->config->get('google_base_status')) ? $this->config->get('google_base_status') : 'UAH';
                            }
                                            
                            if ((float)$product['special']) {
                                $output .= '<g:price>' .  $this->currency->format($this->tax->calculate($product['special'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                            } else {
                                $output .= '<g:price>' . $this->currency->format($this->tax->calculate($product['price'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                            }
                       
                            $categories = $this->model_catalog_product->getCategories($product['product_id']);
                            
                            foreach ($categories as $category) {
                                $path = $this->getPath($category['category_id']);
                                
                                if ($path) {
                                    $string = '';
                                    
                                    foreach (explode('_', $path) as $path_id) {
                                        $category_info = $this->model_catalog_category->getCategory($path_id);
                                        
                                        if ($category_info) {
                                            if (!$string) {
                                                $string = $category_info['name'];
                                            } else {
                                                $string .= ' &gt; ' . $category_info['name'];
                                            }
                                        }
                                    }
                                 
                                    $output .= '<g:product_type>' . $string . '</g:product_type>';
                                }
                            }
                            
                            $output .= '<g:quantity>' . $product['quantity'] . '</g:quantity>';
                            $output .= '<g:upc>' . $product['upc'] . '</g:upc>'; 
                            $output .= '<g:weight>' . $this->weight->format($product['weight'], $product['weight_class_id']) . '</g:weight>'; 
                            $output .= '<g:availability>' . ($product['quantity'] ? 'in stock' : 'out of stock') . '</g:availability>';
                            $output .= '</item>';
                        }
                    }
                }

            $output .= '</channel>'; 
            $output .= '</rss>';    
            
            $this->response->addHeader('Content-Type: application/rss+xml; charset=utf-8');
            $this->response->setOutput($output);
        }
    }
    
    protected function getPath($parent_id, $current_path = '') {
        $category_info = $this->model_catalog_category->getCategory($parent_id);
    
        if ($category_info) {
            if (!$current_path) {
                $new_path = $category_info['category_id'];
            } else {
                $new_path = $category_info['category_id'] . '_' . $current_path;
            }    
        
            $path = $this->getPath($category_info['parent_id'], $new_path);
                    
            if ($path) {
                return $path;
            } else {
                return $new_path;
            }
        }
    }        
}
?>

Share this post


Link to post
Share on other sites
3 минуты назад, flai0616 сказал:

 

А если так?)

 

<?php 
class ControllerFeedGoogleBase extends Controller {
    public function index() {
        if ($this->config->get('google_base_status')) { 
            $output  = '<?xml version="1.0" encoding="UTF-8" ?>';
            $output .= '<rss version="2.0" xmlns:g="http://base.google.com/ns/1.0">';
            $output .= '<channel>';
            $output .= '<title>' . $this->config->get('config_name') . '</title>'; 
            $output .= '<description>' . $this->config->get('config_meta_description') . '</description>';
            $output .= '<link>' . HTTP_SERVER . '</link>';
            
            $this->load->model('catalog/category');
            
            $this->load->model('catalog/product');
            
            $this->load->model('tool/image');
            
            $products = $this->model_catalog_product->getProducts();
            
                foreach ($products as $product) {
                    if ($product['product_id'] <= 200) {  
                        if ($product['description']) {
                            $output .= '<item>';
                            $output .= '<title>' . html_entity_decode($product['name'], ENT_QUOTES, 'UTF-8') . '</title>';
                            $output .= '<link>' . str_replace('&', '&amp;', str_replace('&amp;', '&', $this->url->link('product/product', 'product_id=' . $product['product_id']))) . '</link>';
                            $output .= '<description><![CDATA[' . strip_tags(html_entity_decode($product['description'], ENT_QUOTES, 'UTF-8')) . ']]></description>';
                            $output .= '<g:brand>' . html_entity_decode($product['manufacturer'], ENT_QUOTES, 'UTF-8') . '</g:brand>';
                            $output .= '<g:condition>new</g:condition>';
                            $output .= '<g:id>' . $product['product_id'] . '</g:id>';
                            
                            if ($product['image']) {
                                $output .= '<g:image_link>' . $this->model_tool_image->resize($product['image'], 500, 500) . '</g:image_link>';
                            } else {
                                $output .= '<g:image_link>' . $this->model_tool_image->resize('no_image.jpg', 500, 500) . '</g:image_link>';
                            }
                            
                            $output .= '<g:mpn>' . $product['model'] . '</g:mpn>';

                            $supported_currencies = array('UAH', 'USD', 'EUR', 'GBP');

                            if (in_array($this->currency->getCode(), $supported_currencies)) {
                                $currency = $this->currency->getCode();
                            } else {
                                $currency = ($this->config->get('google_base_status')) ? $this->config->get('google_base_status') : 'UAH';
                            }
                                            
                            if ((float)$product['special']) {
                                $output .= '<g:price>' .  $this->currency->format($this->tax->calculate($product['special'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                            } else {
                                $output .= '<g:price>' . $this->currency->format($this->tax->calculate($product['price'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                            }
                       
                            $categories = $this->model_catalog_product->getCategories($product['product_id']);
                            
                            foreach ($categories as $category) {
                                $path = $this->getPath($category['category_id']);
                                
                                if ($path) {
                                    $string = '';
                                    
                                    foreach (explode('_', $path) as $path_id) {
                                        $category_info = $this->model_catalog_category->getCategory($path_id);
                                        
                                        if ($category_info) {
                                            if (!$string) {
                                                $string = $category_info['name'];
                                            } else {
                                                $string .= ' &gt; ' . $category_info['name'];
                                            }
                                        }
                                    }
                                 
                                    $output .= '<g:product_type>' . $string . '</g:product_type>';
                                }
                            }
                            
                            $output .= '<g:quantity>' . $product['quantity'] . '</g:quantity>';
                            $output .= '<g:upc>' . $product['upc'] . '</g:upc>'; 
                            $output .= '<g:weight>' . $this->weight->format($product['weight'], $product['weight_class_id']) . '</g:weight>'; 
                            $output .= '<g:availability>' . ($product['quantity'] ? 'in stock' : 'out of stock') . '</g:availability>';
                            $output .= '</item>';
                        }
                    }
                }

            $output .= '</channel>'; 
            $output .= '</rss>';    
            
            $this->response->addHeader('Content-Type: application/rss+xml; charset=utf-8');
            $this->response->setOutput($output);
        }
    }
    
    protected function getPath($parent_id, $current_path = '') {
        $category_info = $this->model_catalog_category->getCategory($parent_id);
    
        if ($category_info) {
            if (!$current_path) {
                $new_path = $category_info['category_id'];
            } else {
                $new_path = $category_info['category_id'] . '_' . $current_path;
            }    
        
            $path = $this->getPath($category_info['parent_id'], $new_path);
                    
            if ($path) {
                return $path;
            } else {
                return $new_path;
            }
        }
    }        
}
?>

нет и если я не ошибаюсь то это условие что если товара меньше или ровно 200 то формируется, а уменя товаров 25 000 и мне нужно чтобы только 200 формировалось

Share this post


Link to post
Share on other sites
3 минуты назад, Briz сказал:

нет и если я не ошибаюсь то это условие что если товара меньше или ровно 200 то формируется, а уменя товаров 25 000 и мне нужно чтобы только 200 формировалось

Не совсем)

Это условие если id товара < или = 200 - выполнять условие if ($product['description']) 

Каждому товару в opencart присваивается уникальный идентификатор. возможно, в вашем случае, необходимо изменить цифру 200 на другую, чтобы оказалось именно 200 товаров.

Кеш модификаторов обновляли?

 

  • +1 1

Share this post


Link to post
Share on other sites
33 минуты назад, flai0616 сказал:

Не совсем)

Это условие если id товара < или = 200 - выполнять условие if ($product['description']) 

Каждому товару в opencart присваивается уникальный идентификатор. возможно, в вашем случае, необходимо изменить цифру 200 на другую, чтобы оказалось именно 200 товаров.

Кеш модификаторов обновляли?

 

 

Не в обиду скажу, но логика у Вас отсутствует. Т.к. в БД могут отсутствовать товары c id меньше 200 и в итоге мы не получим не одного товара.

 

@Briz попробуйте после  $products = $this->model_catalog_product->getProducts();  написать $products = array_slice($products,0,200); должно вернуть 200 товаров.
 

  • +1 1

Share this post


Link to post
Share on other sites
43 минуты назад, flai0616 сказал:

Не совсем)

Это условие если id товара < или = 200 - выполнять условие if ($product['description']) 

Каждому товару в opencart присваивается уникальный идентификатор. возможно, в вашем случае, необходимо изменить цифру 200 на другую, чтобы оказалось именно 200 товаров.

Кеш модификаторов обновляли?

 

обновляла, хоть убей 
Fatal error: Allowed memory size of 268435456 bytes exhausted (tried to allocate 8024 bytes)  и все((((

Share this post


Link to post
Share on other sites
10 минут назад, Bn174uk сказал:

 

Не в обиду скажу, но логика у Вас отсутствует. Т.к. в БД могут отсутствовать товары c id меньше 200 и в итоге мы не получим не одного товара.

 

@Briz попробуйте после  $products = $this->model_catalog_product->getProducts();  написать $products = array_slice($products,0,200); должно вернуть 200 товаров.
 

выдает Parse error: syntax error, unexpected '' (T_STRING) на эту строчку что вставила

Share this post


Link to post
Share on other sites
9 минут назад, Bn174uk сказал:

 

Не в обиду скажу, но логика у Вас отсутствует. Т.к. в БД могут отсутствовать товары c id меньше 200 и в итоге мы не получим не одного товара.

 

@Briz попробуйте после  $products = $this->model_catalog_product->getProducts();  написать $products = array_slice($products,0,200); должно вернуть 200 товаров.
 

Без обид, но для этого случая указана следующая фраза:

"Каждому товару в opencart присваивается уникальный идентификатор. возможно, в вашем случае, необходимо изменить цифру 200 на другую, чтобы оказалось именно 200 товаров."

3 минуты назад, Briz сказал:

обновляла, хоть убей 
Fatal error: Allowed memory size of 268435456 bytes exhausted (tried to allocate 8024 bytes)  и все((((

Дайте ссылку на сайт в ЛС) Сейчас посмотрю)

  • +1 1

Share this post


Link to post
Share on other sites
7 минут назад, Briz сказал:

выдает Parse error: syntax error, unexpected '' (T_STRING) на эту строчку что вставила

Решение товарища @Bn174uk должно быть правильным.

Возможно вы не удалили закрывающую скобку моего цикла.

Попробуйте его рекомендацию написать в своем изначальном файле - должно помочь.

  • +1 1

Share this post


Link to post
Share on other sites
16 часов назад, flai0616 сказал:

Решение товарища @Bn174uk должно быть правильным.

Возможно вы не удалили закрывающую скобку моего цикла.

Попробуйте его рекомендацию написать в своем изначальном файле - должно помочь.

вставляю даже в оригинал все равно ошибка эта

Share this post


Link to post
Share on other sites

Уверены, что правильно вставили? 

Должно быть так http://prntscr.com/klka70

 

Проверил даже на тестовом http://test15.cmsshop.com.ua/index.php?route=feed/google_base вывело 3и товара, вместо 19шт.

  • +1 2

Share this post


Link to post
Share on other sites
32 минуты назад, Bn174uk сказал:

Уверены, что правильно вставили? 

Должно быть так http://prntscr.com/klka70

 

Проверил даже на тестовом http://test15.cmsshop.com.ua/index.php?route=feed/google_base вывело 3и товара, вместо 19шт.

 

324234.png

Share this post


Link to post
Share on other sites
Спойлер

<?php 
class ControllerFeedGoogleBase extends Controller {
    public function index() {
        if ($this->config->get('google_base_status')) { 
            $output  = '<?xml version="1.0" encoding="UTF-8" ?>';
            $output .= '<rss version="2.0" xmlns:g="http://base.google.com/ns/1.0">';
            $output .= '<channel>';
            $output .= '<title>' . $this->config->get('config_name') . '</title>'; 
            $output .= '<description>' . $this->config->get('config_meta_description') . '</description>';
            $output .= '<link>' . HTTP_SERVER . '</link>';
            
            $this->load->model('catalog/category');
            
            $this->load->model('catalog/product');
            
            $this->load->model('tool/image');
            
            $products = $this->model_catalog_product->getProducts();
            
            $products = array_slice($products,0,200); 
            
            foreach ($products as $product) {
                if ($product['description']) {
                    $output .= '<item>';
                    $output .= '<title>' . html_entity_decode($product['name'], ENT_QUOTES, 'UTF-8') . '</title>';
                    $output .= '<link>' . str_replace('&', '&amp;', str_replace('&amp;', '&', $this->url->link('product/product', 'product_id=' . $product['product_id']))) . '</link>';
                    $output .= '<description><![CDATA[' . strip_tags(html_entity_decode($product['description'], ENT_QUOTES, 'UTF-8')) . ']]></description>';
                    $output .= '<g:brand>' . html_entity_decode($product['manufacturer'], ENT_QUOTES, 'UTF-8') . '</g:brand>';
                    $output .= '<g:condition>new</g:condition>';
                    $output .= '<g:id>' . $product['product_id'] . '</g:id>';
                    
                    if ($product['image']) {
                        $output .= '<g:image_link>' . $this->model_tool_image->resize($product['image'], 500, 500) . '</g:image_link>';
                    } else {
                        $output .= '<g:image_link>' . $this->model_tool_image->resize('no_image.jpg', 500, 500) . '</g:image_link>';
                    }
                    
                    $output .= '<g:mpn>' . $product['model'] . '</g:mpn>';

                    $supported_currencies = array('UAH', 'USD', 'EUR', 'GBP');

                    if (in_array($this->currency->getCode(), $supported_currencies)) {
                        $currency = $this->currency->getCode();
                    } else {
                        $currency = ($this->config->get('google_base_status')) ? $this->config->get('google_base_status') : 'UAH';
                    }
                                    
                    if ((float)$product['special']) {
                        $output .= '<g:price>' .  $this->currency->format($this->tax->calculate($product['special'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                    } else {
                        $output .= '<g:price>' . $this->currency->format($this->tax->calculate($product['price'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                    }
               
                    $categories = $this->model_catalog_product->getCategories($product['product_id']);
                    
                    foreach ($categories as $category) {
                        $path = $this->getPath($category['category_id']);
                        
                        if ($path) {
                            $string = '';
                            
                            foreach (explode('_', $path) as $path_id) {
                                $category_info = $this->model_catalog_category->getCategory($path_id);
                                
                                if ($category_info) {
                                    if (!$string) {
                                        $string = $category_info['name'];
                                    } else {
                                        $string .= ' &gt; ' . $category_info['name'];
                                    }
                                }
                            }
                         
                            $output .= '<g:product_type>' . $string . '</g:product_type>';
                        }
                    }
                    
                    $output .= '<g:quantity>' . $product['quantity'] . '</g:quantity>';
                    $output .= '<g:upc>' . $product['upc'] . '</g:upc>'; 
                    $output .= '<g:weight>' . $this->weight->format($product['weight'], $product['weight_class_id']) . '</g:weight>'; 
                    $output .= '<g:availability>' . ($product['quantity'] ? 'in stock' : 'out of stock') . '</g:availability>';
                    $output .= '</item>';
                }
            }
            
            $output .= '</channel>'; 
            $output .= '</rss>';    
            
            $this->response->addHeader('Content-Type: application/rss+xml; charset=utf-8');
            $this->response->setOutput($output);
        }
    }
    
    protected function getPath($parent_id, $current_path = '') {
        $category_info = $this->model_catalog_category->getCategory($parent_id);
    
        if ($category_info) {
            if (!$current_path) {
                $new_path = $category_info['category_id'];
            } else {
                $new_path = $category_info['category_id'] . '_' . $current_path;
            }    
        
            $path = $this->getPath($category_info['parent_id'], $new_path);
                    
            if ($path) {
                return $path;
            } else {
                return $new_path;
            }
        }
    }        
}
?>

 

Share this post


Link to post
Share on other sites
27 минут назад, Briz сказал:

 

324234.png

 

Попробуйте эту строчку " $products = array_slice($products,0,200); " руками написать , т.к. когда вставляю Ваш код к себе, тоже самая ошибка, а когда строку пишу заново, все ок, ошибки нет.

  • +1 2

Share this post


Link to post
Share on other sites
39 минут назад, Briz сказал:
  Показать контент

<?php 
class ControllerFeedGoogleBase extends Controller {
    public function index() {
        if ($this->config->get('google_base_status')) { 
            $output  = '<?xml version="1.0" encoding="UTF-8" ?>';
            $output .= '<rss version="2.0" xmlns:g="http://base.google.com/ns/1.0">';
            $output .= '<channel>';
            $output .= '<title>' . $this->config->get('config_name') . '</title>'; 
            $output .= '<description>' . $this->config->get('config_meta_description') . '</description>';
            $output .= '<link>' . HTTP_SERVER . '</link>';
            
            $this->load->model('catalog/category');
            
            $this->load->model('catalog/product');
            
            $this->load->model('tool/image');
            
            $products = $this->model_catalog_product->getProducts();
            
            $products = array_slice($products,0,200); 
            
            foreach ($products as $product) {
                if ($product['description']) {
                    $output .= '<item>';
                    $output .= '<title>' . html_entity_decode($product['name'], ENT_QUOTES, 'UTF-8') . '</title>';
                    $output .= '<link>' . str_replace('&', '&amp;', str_replace('&amp;', '&', $this->url->link('product/product', 'product_id=' . $product['product_id']))) . '</link>';
                    $output .= '<description><![CDATA[' . strip_tags(html_entity_decode($product['description'], ENT_QUOTES, 'UTF-8')) . ']]></description>';
                    $output .= '<g:brand>' . html_entity_decode($product['manufacturer'], ENT_QUOTES, 'UTF-8') . '</g:brand>';
                    $output .= '<g:condition>new</g:condition>';
                    $output .= '<g:id>' . $product['product_id'] . '</g:id>';
                    
                    if ($product['image']) {
                        $output .= '<g:image_link>' . $this->model_tool_image->resize($product['image'], 500, 500) . '</g:image_link>';
                    } else {
                        $output .= '<g:image_link>' . $this->model_tool_image->resize('no_image.jpg', 500, 500) . '</g:image_link>';
                    }
                    
                    $output .= '<g:mpn>' . $product['model'] . '</g:mpn>';

                    $supported_currencies = array('UAH', 'USD', 'EUR', 'GBP');

                    if (in_array($this->currency->getCode(), $supported_currencies)) {
                        $currency = $this->currency->getCode();
                    } else {
                        $currency = ($this->config->get('google_base_status')) ? $this->config->get('google_base_status') : 'UAH';
                    }
                                    
                    if ((float)$product['special']) {
                        $output .= '<g:price>' .  $this->currency->format($this->tax->calculate($product['special'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                    } else {
                        $output .= '<g:price>' . $this->currency->format($this->tax->calculate($product['price'], $product['tax_class_id']), $currency, false, false) . '</g:price>';
                    }
               
                    $categories = $this->model_catalog_product->getCategories($product['product_id']);
                    
                    foreach ($categories as $category) {
                        $path = $this->getPath($category['category_id']);
                        
                        if ($path) {
                            $string = '';
                            
                            foreach (explode('_', $path) as $path_id) {
                                $category_info = $this->model_catalog_category->getCategory($path_id);
                                
                                if ($category_info) {
                                    if (!$string) {
                                        $string = $category_info['name'];
                                    } else {
                                        $string .= ' &gt; ' . $category_info['name'];
                                    }
                                }
                            }
                         
                            $output .= '<g:product_type>' . $string . '</g:product_type>';
                        }
                    }
                    
                    $output .= '<g:quantity>' . $product['quantity'] . '</g:quantity>';
                    $output .= '<g:upc>' . $product['upc'] . '</g:upc>'; 
                    $output .= '<g:weight>' . $this->weight->format($product['weight'], $product['weight_class_id']) . '</g:weight>'; 
                    $output .= '<g:availability>' . ($product['quantity'] ? 'in stock' : 'out of stock') . '</g:availability>';
                    $output .= '</item>';
                }
            }
            
            $output .= '</channel>'; 
            $output .= '</rss>';    
            
            $this->response->addHeader('Content-Type: application/rss+xml; charset=utf-8');
            $this->response->setOutput($output);
        }
    }
    
    protected function getPath($parent_id, $current_path = '') {
        $category_info = $this->model_catalog_category->getCategory($parent_id);
    
        if ($category_info) {
            if (!$current_path) {
                $new_path = $category_info['category_id'];
            } else {
                $new_path = $category_info['category_id'] . '_' . $current_path;
            }    
        
            $path = $this->getPath($category_info['parent_id'], $new_path);
                    
            if ($path) {
                return $path;
            } else {
                return $new_path;
            }
        }
    }        
}
?>

 

Удалите пробел после закрывающейся скобочки

$products = array_slice($products,0,200)"вот тут";

  • +1 2

Share this post


Link to post
Share on other sites
16 минут назад, Bn174uk сказал:

 

Попробуйте эту строчку " $products = array_slice($products,0,200); " руками написать , т.к. когда вставляю Ваш код к себе, тоже самая ошибка, а когда строку пишу заново, все ок, ошибки нет.

мистика ,но так сработало))) спасибо Вам большое=)))

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
You are posting as a guest. If you have an account, please sign in.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Sign in to follow this  

  • Recently Browsing   0 members

    No registered users viewing this page.

×

Important Information

On our site, cookies are used and personal data is processed to improve the user interface. To find out what and what personal data we are processing, please go to the link. If you click "I agree," it means that you understand and accept all the conditions specified in this Privacy Notice.