Magentoでstatus = 'complete'の注文の注文IDやその他の詳細を取得する作業をしています。 Magentoには、ステータスが「完了」のすべての注文を取得できる方法があると確信しています。私はmagentoの初心者なので、これを解決するのは難しいと感じています。
注文ステータスが「メールを完了」の顧客に送信し、メールが送信されたらマークを付けたいと思います。しかし、それはそれの後半部分です。 MagentoでステータスがCompleteのすべての注文IDを取得する方法を教えてもらえますか?
どんな助けでも大歓迎です。前もって感謝します。
これは、ベースのMagentoインストールフォルダーからスクリプトとして実行できます。すでにMagentoファイル内で実行されている場合(コントローラーやブロックなど)、最初の3行は必要ありません。
<?php
require_once('app/Mage.php');
Mage::app();
$orders = Mage::getModel('sales/order')->getCollection()
->addFieldToFilter('status', 'complete')
->addAttributeToSelect('customer_email')
;
foreach ($orders as $order) {
$email = $order->getCustomerEmail();
echo $email . "\n";
}
編集:
ステータスとメールアドレスを含むall注文を表示するには:
$orders = Mage::getModel('sales/order')->getCollection()
//->addFieldToFilter('status', 'complete')
->addAttributeToSelect('customer_email')
->addAttributeToSelect('status')
;
foreach ($orders as $order) {
$email = $order->getCustomerEmail();
echo $order->getId() . ": '" . $order->getStatus() . "', " . $email . "\n";
}
注文ステータスが「完了」のすべての製品を取得するには
$orders = Mage::getResourceModel('sales/order_collection')
->addFieldToSelect('*')
->addFieldToFilter('customer_id', Mage::getSingleton('customer/session')->getCustomer()->getId())
->addFieldToFilter('state', array('in' => Mage::getSingleton('sales/order_config')->getVisibleOnFrontStates()))
->addFieldToFilter('status', 'complete')
->setOrder('created_at', 'desc');
$this->setOrders($orders);
foreach ($orders as $order)
{
$order_id=$order->getRealOrderId();
$order = Mage::getModel('sales/order')->load($order_id, 'increment_id');
$order->getAllVisibleItems();
$orderItems = $order->getItemsCollection()
->addAttributeToSelect('*')
->addAttributeToFilter('product_type', array('eq'=>'simple'))
->load();
foreach($orderItems as $Item)
{
$Item = Mage::getModel('catalog/product')->setStoreId($Item->getStoreId())->load($Item->getProductId());
if ($Item->getId())
{
echo $Item->getName();
echo $Item->getPrice();
echo $Item->getProductUrl();
echo $Item->getImageUrl();
}
}
}
?>