Magento

Produtos mais visualizados no Magento – Criando uma lista

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

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

Ver comentários

  • Roger por favor.. Preciso de ajuds para criar uma listagem filtrando por atributos personalizados, como faço? Muito obrigado!

    • 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.

Post Recentes

CNPJ alfanumérico Magento 2: módulo grátis com máscara e validação

Módulo gratuito Roger_CnpjAlfanumerico que aplica máscara e validação do novo CNPJ alfanumérico no checkout e formulários do Magento 2 e…

4 dias atrás

CNPJ alfanumérico no WooCommerce: plugin grátis de máscara e validação

A partir de 06/07/2026 a Receita passa a emitir CNPJ alfanumérico. Conheça o plugin grátis que aplica máscara e validação…

4 dias atrás

Como remover um modulo do Magento 2

Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…

1 ano atrás

Criar um memorando de crédito (cancelar) invoice no Magento 2

Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…

2 anos atrás

Consultando no banco quantidade disponivel para Venda (estoque)

No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…

2 anos atrás

Admin do Magento 2 não acessa

Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…

2 anos atrás