我想计算订单中所有产品的基本价格。每个(1个数量)的价格应包括任何折扣/奖金但不含税。所有产品价格乘以其数量+税的总和应与$ order-> getGrandTotal()完全相同。
我设法得到个别价格,包括运费,只有很小的精度误差。当然,在处理货币时这是不可接受的。此外,我还没有考虑捆绑产品等。
所以我请你帮助我,我需要做与Magento完全相同的计算,并且仍然得到我需要的值(每个产品/运费都有折扣但不含税)。
提前致谢
答案 0 :(得分:4)
我已经做到了这一点,它给了我确切的信息。但我不确定这是否是正确的方法。另外,我的$ total似乎与$ grand_total不同,有时会有一些小数,例如0.005或类似的小数。
$store = Mage::app()->getStore($order->getStoreId());
$customer = Mage::getModel('customer/customer')
->load($order->getCustomerId());
$tax_calc = Mage::getSingleton('tax/calculation');
$tax_rate_req = $tax_calc->getRateRequest(
$order->getShippingAddress(),
$order->getBillingAddress(),
$customer->getTaxClassId(),
$store);
$args = array();
$total = 0;
// Calculate price of each item in the order
foreach($order->getAllVisibleItems() as $item)
{
$product = Mage::getModel('catalog/product')
->load($item->getProductId());
$children = $item->getChildrenItems();
if(count($children) && ($product->getData('price_type') != 1))
{
foreach($children as $child)
{
$product = Mage::getModel('catalog/product')
->load($child->getProductId());
/* If tax_percent is not set?
Mage::getSingleton('tax/calculation')->getRate(
$tax_rate_req->setProductClassId($product->getTaxClassId()))
*/
$tax_mod = (float)$child->getData('tax_percent');
$tax_mod /= 100;
$qty = (float)$child->getData('qty_ordered');
$price = (float)$child->getData('row_total_incl_tax');
$price -= (float)$child->getData('discount_amount');
$base_price = (($price / (1 + $tax_mod)) / $qty);
$base_price = $store->roundPrice($base_price);
$total += (($base_price * (1 + $tax_mod)) * $qty);
$args[] = array
(
'name' => $product->getData('name'),
'sku' => $child->getData('sku'),
'tax_mod' => $tax_mod,
'qty' => $qty,
'price' => $price,
'base_price' => $base_price
);
}
}
else
{
/* If tax_percent is not set?
Mage::getSingleton('tax/calculation')->getRate(
$tax_rate_req->setProductClassId($product->getTaxClassId()))
*/
$tax_mod = (float)$item->getData('tax_percent');
$tax_mod /= 100;
$qty = (float)$item->getData('qty_ordered');
$price = (float)$item->getData('row_total_incl_tax');
$price -= (float)$item->getData('discount_amount');
$base_price = (($price / (1 + $tax_mod)) / $qty);
$base_price = $store->roundPrice($base_price);
$total += (($base_price * (1 + $tax_mod)) * $qty);
$args[] = array
(
'name' => $product->getData('name'),
'sku' => $item->getData('sku'),
'tax_mod' => $tax_mod,
'qty' => $qty,
'price' => $price,
'base_price' => $base_price
);
}
}
// Calculate price for shipping
if(($price = (float)$order->getData('shipping_incl_tax')) > 0)
{
$tax_mod = $tax_calc->getRate($tax_rate_req->setProductClassId(
Mage::getStoreConfig('tax/classes/shipping_tax_class')));
$tax_mod /= 100;
$price -= (float)$order->getData('shipping_discount_amount');
$base_price = ($price / (1 + $tax_mod));
$base_price = $store->roundPrice($base_price);
$total += ($base_price * (1 + $tax_mod));
$args[] = array
(
'name' => $order->getData('shipping_description'),
'sku' => $order->getData('shipping_method'),
'tax_mod' => $tax_mod,
'qty' => 1,
'price' => $price,
'base_price' => $base_price
);
}
$total = $store->roundPrice($total);
echo('<pre>');
print_r($args);
//print_r($order->getData());
echo('</pre>');
$grand_total = (float)$order->getData('grand_total');
//$grand_total = $store->roundPrice($grand_total);
echo('<p><strong>My total</strong>: ' . $total . '</p>');
echo('<p><strong>Grand total</strong>: ' . $grand_total . '</p>');
exit;