Отримайте колекцію продуктів з ідентифікатора категорії


18

Я намагаюся отримати колекцію продуктів з ідентифікатора категорії. Деякі речі, які я спробував, знаходяться в блоці:

 $category = Mage::getModel('catalog/category')->load(123)
        ->getProductCollection();

і

    $category = Mage::getModel('catalog/category')->load(123);
    $products = $category->getProductCollection()->addCategoryFilter($category)
                         ->addAttributeToFilter('type_id', 'simple')
                         ->addAttributeToSelect('*');

також спробував просто зробити це з phtml

$oCatId = Mage::getModel('catalog/category')->load(769); 
        $products->addCategoryFilter($oCatId);

Нічого з цього не працює, але я також не бачу помилок. Я побачив ще одну публікацію, схожу на те саме питання: Magento - Отримати продукти з конкретної категорії, але цей метод також не працював для мене. Дякуємо за будь-яку допомогу!

Відповіді:


32

Спробуйте це:

$products = Mage::getModel('catalog/category')->load($category_id)
 ->getProductCollection()
 ->addAttributeToSelect('*') // add all attributes - optional
 ->addAttributeToFilter('status', 1) // enabled
 ->addAttributeToFilter('visibility', 4) //visibility in catalog,search
 ->setOrder('price', 'ASC'); //sets the order by price

Джерело: http://overlycaffeined.com/blog/2011/02/get-all-sale-products-from-a-category-in-magento/

Це повинно працювати, оскільки він додає фільтр категорій для вас в силу вже завантаженої категорії:

Mage_Catalog_Model_Category

public function getProductCollection()
{
    $collection = Mage::getResourceModel('catalog/product_collection')
        ->setStoreId($this->getStoreId())
        ->addCategoryFilter($this);
    return $collection;
}

Зачекайте, це все ще не працює!

Гаразд, тому у вас можуть виникнути більші проблеми, імовірно, щось перезаписане getProductCollection. Тож спробуємо обійти цей спосіб зручності:

$category = Mage::getModel('catalog/category')->load($category_id);
$products = Mage::getResourceModel('catalog/product_collection')
        ->setStoreId(Mage::app()->getStore()->getId())
        ->addCategoryFilter($category);

Спасибі за вашу допомогу! Я відчуваю себе ближче, але все-таки розвіваюсь. Використовуючи ваш останній метод, я додав, foreach ($products as $product) { echo $product->getId(); }і я отримую ряд ідентифікаторів. Однак коли я echo $product->getName();нічого не пробую . Я спробував додати ->addAttributeToSelect('*')також, але немає. Дякуємо за додаткову допомогу.
Зак

@philwinkle Чи є спосіб отримати всі продукти для категорії? У мене виникають проблеми з вилученням інвалідів. Я використовуюMage::getResourceModel('catalog/product_collection')->setStoreId(Mage::app()->getStore()->getId())->addCategoryFilter($category)->addAttributeToSelect('sku');
Нік Роландо

9

Як завантажити колекцію продукту з усіма даними, які вам зазвичай потрібні для списків продуктів у передній частині:

$_categoryId = 123;
$category = Mage::getModel('catalog/category')->load($_categoryId );
$productCollection = $category->getProductCollection();
$productCollection
        ->addStoreFilter()
        ->setVisibility(Mage::getSingleton('catalog/product_visibility')->getVisibleInCatalogIds())
        ->addMinimalPrice()
        ->addFinalPrice()
        ->addTaxPercents()
        ->addAttributeToSelect(Mage::getSingleton('catalog/config')->getProductAttributes())
        ->addUrlRewrite();

Це готує колекцію продукту для завантаження необхідних даних для відображення цін, посилання на товар та будь-які атрибути, налаштовані як "використовується у переліку продуктів", але не більше.


Як я можу обмежити результати? ->limit(5)не працювало.
Педрам Бехрозі

->setPageSize(5)
Фабіан Шменглер

@fschmengler ви пропустите ;після $category = Mage::getModel('catalog/category')->load(123)коду
Муртуза Zabuawala

5

Цей нижченаведений код надасть вам колекцію продуктів з ідентифікатора 10 категорії.

$categoryId = 10;    
$products = Mage::getSingleton('catalog/category')->load($categoryId)
            ->getProductCollection()
            ->addAttributeToSelect('*');

3

Код, щоб отримати колекцію товару з певного ідентифікатора категорії:

$productCollection = Mage::getResourceModel('catalog/product_collection')
                       ->addCategoryFilter($category);

ідеально !!! +1 :)
SagarPPanchal

де $ category = $ categoryId?
lorakeen

2

Нижче фрагмент коду набагато простіше та ефективніше, ніж завантаження колекції та фільтрування продукту за допомогою його атрибутів,

$categoryId = 32; // Replace with your category

$category = Mage::getModel('catalog/category')
                 ->setStoreId(Mage::app()->getStore()->getId())
                 ->load($categoryId);

Mage::register('current_category', $category);

$products = Mage::getSingleton('catalog/layer')->getProductCollection();

echo $products->getSize();

0

У Magento 2 спробуйте цю колекцію забути за допомогою ідентифікатора категорії

  $objectManager = \Magento\Framework\App\ObjectManager::getInstance();
  $subCategory =  $objectManager->create('Magento\Catalog\Model\Category')-> 
         load('categorey_id');
  foreach($subCategory as $subcat)
   { 
        print_r($subcat->getData();
  }

-2
<?php

$categoryid = 123; // Category Id

$category = new Mage_Catalog_Model_Category();
$category->load($categoryid);
$collection = $category->getProductCollection();
$collection->addAttributeToSelect('*'); 

foreach ($_productCollection as $_product) { ?>
    <div class="pr_section">
        <div class="pr_desc">
            <a href="<?php echo $_product->getProductUrl(); ?>"><?php echo $_product->getName(); ?></a>
            <?php echo $this->getReviewsSummaryHtml($_product, false, true); // Reviews ?>
                <?php echo $this->getPriceHtml($_product, true) ?>
                <?php echo $_product->getShortDescription();?>

                <?php if(!$_product->canConfigure() && $_product->isSaleable()): ?>
                    <p><button type="button" title="<?php echo Mage::helper('core')->quoteEscape($this->__('Add to Cart')) ?>" class="button btn-cart" onclick="setLocation('<?php echo $this->getAddToCartUrl($_product) ?>')"><span><span><?php echo $this->__('Add to Cart') ?></span></span></button></p>
                <?php elseif($_product->getStockItem() && $_product->getStockItem()->getIsInStock()): ?>
                    <p><a title="<?php echo $this->__('View Details') ?>" class="button btn-cart" href="<?php echo $_product->getProductUrl() ?>"><?php echo $this->__('View Details') ?></a></p>
                <?php else: ?>
                    <p class="availability out-of-stock"><span><?php echo $this->__('Out of stock') ?></span></p>
                <?php endif; ?>
        </div>
        <div class="pr_img">
                <a href="<?php echo $_product->getProductUrl() ?>"><img src="<?php echo $this->helper('catalog/image')->init($_product, 'small_image')->resize(200); ?>" width="200" height="200" alt="" /></a> 
        </div>
<?php } ?>

Отримайте колекцію товару з деталями. Сподіваюся, це буде корисним.


1
Я думаю, що некропостінг не був необхідним, оскільки є достатньо відповідей на це питання. Крім того, ваше використання під new Mage_Catalog_Model_Category()питанням.
Жульєн Лашал
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.