Produtos mais visualizados no Magento – Criando uma lista

Tutorial com código fonte para montar uma lista com os produtos mais visualizados no nos últimos 90 dias.

criando uma lista com os produtos mais visualizados no magento

Exemplo com filtro por período (nos últimos 90 dias)

No código abaixo, estou buscando os produtos mais visualizados nos últimos 90 dias.

/*Qtd de produtos */
$qtdProdutos = 5; 
    
$storeId = Mage::app()->getStore()->getId(); 

/* Data atual */
$hoje = time();

/* 90 dias atrás.. altere o 90 para quantidade que você desejar */
$ultimo = $hoje - (60*60*24*90);
 
$de = date("Y-m-d", $ultimo);
$ate = date("Y-m-d", $hoje);

    
/* Adiciono os filtros na minha collection */
$products = Mage::getResourceModel('reports/product_collection')
        ->addAttributeToSelect('*')        
        ->setStoreId($storeId)
        ->addStoreFilter($storeId)
        ->addViewsCount($de, $ate)
        ->setPageSize($qtdProdutos); 
    

			
foreach($products as $product){
	echo $product->getName();
}

Lembrando, se você for carregar o código em um arquivo externo, fora do Magento utilize:

/* Atenção com o caminho completo até o Mage.php */
require_once 'app/Mage.php';
umask(0);
Mage::app('default');

Outro fato importante sobre o código é que ele depende que as estatísticas dos relatórios do Magento estejam atualizadas.

Como atualizar as estatísticas: http://docs.magento.com/m1/ce/user_guide/store-operations/reports-refresh.html

Se você não deseja filtrar os mais visualizados por um período, utilize o exemplo abaixo:

$qtdProdutos = 5; 
    
$id_loja = Mage::app()->getStore()->getId();       
    

$productsCollection = Mage::getResourceModel('reports/product_collection')
        ->addAttributeToSelect('*')        
        ->setStoreId($id_loja)
        ->addStoreFilter($id_loja)
        ->addViewsCount()
        ->setPageSize($qtdProdutos); 
    
Mage::getSingleton('catalog/product_status')
            ->addVisibleFilterToCollection($productsCollection);

Mage::getSingleton('catalog/product_visibility')
            ->addVisibleInCatalogFilterToCollection($productsCollection);
			
			
foreach($products as $product){
	echo $product->getName();
}

 

Resumo
Produtos mais visualizados no Magento
Nome do Artigo
Produtos mais visualizados no Magento
Descrição
Tutorial de como montar uma lista com os produtos mais visualizados no Magento
Autor
Editor
Roger Mauricio Takemiya
Logo do Editor

2 comentários sobre “Produtos mais visualizados no Magento – Criando uma lista

    1. Julia, boa tarde, É bem simples, na “collection” utilize o seguinte método: addAttributeToFilter(), exemplo: $collection->addAttributeToFilter(‘codigo_atributo’, ‘678678’); Primeiro campo é o código do atributo personalizado / customizado e o segundo o valor.

Dúvidas? Faça um comentário logo abaixo ou envie uma mensagem clicando aqui.

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *