Avatar billede mmalling Nybegynder
25. februar 2011 - 00:04 Der er 7 kommentarer og
1 løsning

Brug af number_format() ved udtræk fra database

Jeg har et script der ved hjælp af udtræk fra database laver en xml fil, over et vare sortiment. Den fil bliver hentet af diverse prisguides, og mit problem er nu at der er for mange decimaler på prisen. istedet for 19.95 står der feks 19.95452.

Hvorledes får jeg fjernet disse decimaler ved udtrækket?

Her den del der laver udtrækket.
foreach ($products as $product) {
  $prodObj = new Product($product['id_product'], false, $id_lang);
  $product['url'] = $link->getProductLink($prodObj);
  $cover = Product::getCover($product['id_product']);
  $product['imageUrl'] = _PS_BASE_URL_.$link->getImageLink($prodObj->link_rewrite, $product['id_product'].'-'.$cover['id_image'], 'large');
  if (intval($configuration['PS_SHIPPING_METHOD']))
    $shipping_cost = $carrier->getDeliveryPriceByWeight($product['weight'], $id_zone);
  else
    $shipping_cost = $carrier->getDeliveryPriceByPrice($product['price'], $id_zone);
  $shipping_cost *= 1 + ($carrierTax / 100);
  $shipping_cost += floatval($configuration['PS_SHIPPING_HANDLING']);
  $product['shipping_cost'] = $shipping_cost;
  $product['price_inc'] = $product['price'] * (1 + $product ['tax_rate'] / 100  );
  $product['manufacturerName'] = $manMap[$product['id_manufacturer']]['name'];
  $product['description_short'] = my_strip_tags($product['description_short']);
  $product['leveringstid'] = ($carrier->delay[4]);
  $product['lager'] = $product['quantity'];

når det kommer ud ser det således ud
<product place="3190">
<id>3049</id>
<ean13/>
<reference>37-4251412</reference>
<longDescription/>
<description>KNR-412  IPCORDER 412 HDD BOKS, U/HDD 4X3,5SATA</description>
<name>IPCorder</name>
<url>http://www.mbmdata.dk/product.php?id_product=3049</url>
<imageUrl>http://www.mbmdata.dk/img/p/3049-3049-large.jpg</imageUrl>
<shipping>69</shipping>
<price>21872.8125</price>
<manufacturer>KOUKAAM</manufacturer>
<leveringstid>Lev 1-3 hverdage</leveringstid>
<lager>0</lager>
&#8722;
<category>
Overvågning | HDD optager | HDD optager til IP | IP Corder 4xx
</category>
</product>
Avatar billede olsensweb.dk Ekspert
25. februar 2011 - 00:48 #1
http://dk2.php.net/manual/en/function.number-format.php
// French notation
$nombre_format_francais = number_format($number, 2, ',', '.');
// 1.234,56

din code
$product['price_inc'] = $product['price'] * (1 + $product ['tax_rate'] / 100  );

noget i denne stil
$price = number_format($product['price_inc'], 2, ',', '.');
Avatar billede mmalling Nybegynder
25. februar 2011 - 11:51 #2
har prøvet at sætte dit forslag ind, men desværre har det ikke hjulpet. koden ser nu således ud.

foreach ($products as $product) {
  $prodObj = new Product($product['id_product'], false, $id_lang);
  $product['url'] = $link->getProductLink($prodObj);
  $cover = Product::getCover($product['id_product']);
  $product['imageUrl'] = _PS_BASE_URL_.$link->getImageLink($prodObj->link_rewrite, $product['id_product'].'-'.$cover['id_image'], 'large');
  if (intval($configuration['PS_SHIPPING_METHOD']))
    $shipping_cost = $carrier->getDeliveryPriceByWeight($product['weight'], $id_zone);
  else
    $shipping_cost = $carrier->getDeliveryPriceByPrice($product['price'], $id_zone);
  $shipping_cost *= 1 + ($carrierTax / 100);
  $shipping_cost += floatval($configuration['PS_SHIPPING_HANDLING']);
  $product['shipping_cost'] = $shipping_cost;
  $product['price_inc'] = $product['price'] * (1 + $product ['tax_rate'] / 100  );
  $price = number_format($product['price_inc'], 2, ',', '.');
  $product['manufacturerName'] = $manMap[$product['id_manufacturer']]['name'];
  $product['description_short'] = my_strip_tags($product['description_short']);
  $product['leveringstid'] = ($carrier->delay[4]);
  $product['lager'] = $product['quantity'];

og når det kommer ud ser det sådan ud
product place="3193">
<id>1404</id>
<ean13/>
<reference>30-7680560</reference>
<longDescription/>
<description>32311045 19" LOGIC2 DB. SKAB, 42 HE 1993X800X1000</description>
<name>19" LOGIC-2 rackskab DOBBELT</name>
<url>http://www.mbmdata.dk/product.php?id_product=1404</url>
<imageUrl>http://www.mbmdata.dk/img/p/1404-1404-large.jpg</imageUrl>
<shipping>69</shipping>
<price>24950.0625</price>
<manufacturer>RETEX</manufacturer>
<leveringstid>Lev 1-3 hverdage</leveringstid>
<lager>0</lager>
&#8722;
<category>
Rack computer produkter | Rackskabe og tilbehør | 19" rackskabe - gulv | Logic2 Alurack -  vent.db. døre -  800 mm
</category>
</product>
</products>
Avatar billede olsensweb.dk Ekspert
25. februar 2011 - 12:19 #3
prøv dette, jeg går ud fra dit pricetag (  <price>21872.8125</price> ) = $product['price_inc']
foreach ($products as $product) {
  $prodObj = new Product($product['id_product'], false, $id_lang);
  $product['url'] = $link->getProductLink($prodObj);
  $cover = Product::getCover($product['id_product']);
  $product['imageUrl'] = _PS_BASE_URL_.$link->getImageLink($prodObj->link_rewrite, $product['id_product'].'-'.$cover['id_image'], 'large');
  if (intval($configuration['PS_SHIPPING_METHOD']))
    $shipping_cost = $carrier->getDeliveryPriceByWeight($product['weight'], $id_zone);
  else
    $shipping_cost = $carrier->getDeliveryPriceByPrice($product['price'], $id_zone);
  $shipping_cost *= 1 + ($carrierTax / 100);
  $shipping_cost += floatval($configuration['PS_SHIPPING_HANDLING']);
  $product['shipping_cost'] = $shipping_cost;
    [b]$price = $product['price'] * (1 + $product ['tax_rate'] / 100  );
    $product['price_inc'] = number_format($price, 2, ',', '.');    [b]
  $product['manufacturerName'] = $manMap[$product['id_manufacturer']]['name'];
  $product['description_short'] = my_strip_tags($product['description_short']);
  $product['leveringstid'] = ($carrier->delay[4]);
  $product['lager'] = $product['quantity'];
Avatar billede olsensweb.dk Ekspert
25. februar 2011 - 12:21 #4
den blev ikke fed hvor den skulle, da jeg glemte et /
prøv dette, jeg går ud fra dit pricetag (  <price>21872.8125</price> ) = $product['price_inc']
foreach ($products as $product) {
  $prodObj = new Product($product['id_product'], false, $id_lang);
  $product['url'] = $link->getProductLink($prodObj);
  $cover = Product::getCover($product['id_product']);
  $product['imageUrl'] = _PS_BASE_URL_.$link->getImageLink($prodObj->link_rewrite, $product['id_product'].'-'.$cover['id_image'], 'large');
  if (intval($configuration['PS_SHIPPING_METHOD']))
    $shipping_cost = $carrier->getDeliveryPriceByWeight($product['weight'], $id_zone);
  else
    $shipping_cost = $carrier->getDeliveryPriceByPrice($product['price'], $id_zone);
  $shipping_cost *= 1 + ($carrierTax / 100);
  $shipping_cost += floatval($configuration['PS_SHIPPING_HANDLING']);
  $product['shipping_cost'] = $shipping_cost;
    $price = $product['price'] * (1 + $product ['tax_rate'] / 100  );
    $product['price_inc'] = number_format($price, 2, ',', '.');   

  $product['manufacturerName'] = $manMap[$product['id_manufacturer']]['name'];
  $product['description_short'] = my_strip_tags($product['description_short']);
  $product['leveringstid'] = ($carrier->delay[4]);
  $product['lager'] = $product['quantity'];
Avatar billede mmalling Nybegynder
25. februar 2011 - 16:07 #5
det virker tak
Avatar billede mmalling Nybegynder
25. februar 2011 - 16:16 #6
det virker
Avatar billede mmalling Nybegynder
11. marts 2011 - 01:58 #7
det virker
Avatar billede olsensweb.dk Ekspert
11. marts 2011 - 11:43 #8
svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester