Foros del Web » Programando para Internet » PHP »

Cómo se suma el total de los valores de una columna?

Estas en el tema de Cómo se suma el total de los valores de una columna? en el foro de PHP en Foros del Web. Hola a todos! Quisiera saber como puedo hacer para sumar el contenido de cada fila para obtener un total gra., en este caso de la ...
  #1 (permalink)  
Antiguo 21/08/2011, 18:23
 
Fecha de Ingreso: mayo-2002
Ubicación: Capital Federal
Mensajes: 630
Antigüedad: 21 años, 11 meses
Puntos: 1
Cómo se suma el total de los valores de una columna?

Hola a todos! Quisiera saber como puedo hacer para sumar el contenido de cada fila para obtener un total gra., en este caso de la cantidad que se ingresa en la columna Cantidad. El valor cantidad NO ESTA en la bdd. Este se modifica por medio de un input y lo guarda en una variable:

Producto----- Cantidad
lamparitas--- 1
faroles------- 3
lamparas---- 5
...
Total:------- 8

La variable de la columna "cantidad" se guarda en:
$total = $v['cantidad'];

¿Se puede hacer por ejemplo con un bucle, que a medida que se ingresa un valor éste lo sume?

Muchas gracias y saludos.
Marx.
__________________
"Todo lo que somos es el resultado de lo que hemos pensado". Budda.
  #2 (permalink)  
Antiguo 21/08/2011, 19:08
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Cómo se suma el total de los valores de una columna?

Cita:
Iniciado por marx-pola Ver Mensaje
[...] ¿Se puede hacer por ejemplo con un bucle, que a medida que se ingresa un valor éste lo sume? [...]
Si.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 21/08/2011, 20:46
 
Fecha de Ingreso: mayo-2010
Mensajes: 60
Antigüedad: 13 años, 10 meses
Puntos: 0
Respuesta: Cómo se suma el total de los valores de una columna?

$total += $v['cantidad'];
  #4 (permalink)  
Antiguo 22/08/2011, 09:28
 
Fecha de Ingreso: mayo-2002
Ubicación: Capital Federal
Mensajes: 630
Antigüedad: 21 años, 11 meses
Puntos: 1
Respuesta: Cómo se suma el total de los valores de una columna?

Hola y gracias por responder pero no me funcionó, quizás porque no lo estoy utilizando bien. Les paso el código para que vean como está armado:

Código PHP:
<?php session_start();
error_reporting(E_ALL);
@
ini_set('display_errors''1');
if(isset(
$_SESSION['carro']))
$carro=$_SESSION['carro'];else $carro=false;

if(
$carro){
?>

<table width="880" border="0" cellspacing="0" cellpadding="0" align="center">
  <tr bgcolor="#333333" class="tit"> 
    <td width="64" height="20">Producto</td>
    <td width="82" height="20">Precio</td>
    <td height="20" colspan="2" align="center">Cantidad de Unidades</td>
    <td width="70" height="20" align="center">Borrar</td>
    <td width="100" height="20" align="center">Actualizar</td>
  </tr>
  <?php
  $color
=array("#ffffff","#F0F0F0");
  
$contador=0;
  
$suma=0;
   foreach(
$carro as $k => $v){
   
$subto=$v['cantidad']*$v['precio'];
   
$suma=$suma+$subto;
   
$contador++;
    
?>
  <form name="a<?php echo $v['identificador'?>" method="post" action="carro_actualiza.php?<?php echo SID ?>" id="a<?php echo $v['identificador'?>">
    <tr bgcolor="<?php echo $color[$contador%2]; ?>" class='prod'> 
      <td height="20"><?php echo $v['id_articulo'?></td>
      <td height="20"><?php echo $v['precio'?></td>
      <td width="45" height="20" align="center"><?php echo $v['cantidad'?></td>
      <td width="79" height="20" align="center"> 
        <input name="cantidad" type="text" class="prod" id="cantidad" value="<?php echo $v['cantidad'?>" size="6">
        <input name="id_articulo" type="hidden" id="id_articulo" value="<?php echo $v['id_articulo'?>"> </td>
      <td height="20" align="center"><a href="carro_borrar.php?<?php echo SID ?>&id_articulo=<?php echo $v['id_articulo'?>"><img src="trash.gif" width="12" height="14" border="0"></a></td>
      <td height="20" align="center"> 
        <input name="imageField" type="image" src="actualizar.gif" width="20" height="20" border="0"></td>
  </tr></form>
  <?php }?>
</table>
</td>
  </tr>
  <tr>
    <td height="30" align="center" valign="bottom">&nbsp;</td>
  </tr>
  <tr>
    <td height="53" align="center" valign="bottom"><div align="center"><span class="prod">Total de Artículos: <?php echo count($carro); ?></span> 
</div><br>
<div align="center"><span class="prod">Total: $<?php echo number_format($suma,2); ?></span> 
</div><br>
<div align="center"><span class="prod">Continuar la selección de productos</span> 
  <a href="../index.php?<?php echo SID;?>"><img src="continuar.gif" width="13" height="13" border="0"></a></div></td>
  </tr>
  <tr>
    <td align="center"><?php }else{ ?>
      <p align="center"> <span class="prod">No hay productos seleccionados</span> <a href="../index.php?<?php echo SID;?>"><img src="continuar.gif" width="13" height="13" border="0"></a>
        <?php }?>
    </p></td>
  </tr>
  <tr>
    <td align="center">
     </td>
  </tr>
</table>
La línea "Total de Artículos: <?php echo count($carro); ?>" me cuenta solo las filas/artículos ingresados pero no la cantidad ingresada en cada uno de ellos. Por eso puse este ejemplo:
Producto----- Cantidad
lamparitas--- 1
faroles------ 3
lamparas---- 5
...
Productos: 3 - Total/Cantidad: ?

Además encontré otro error. No me está sumando los decimales y la suma me devuelve números enteros. Lo que noté es que en la bdd los números están cargados con comas (51,10) y esta línea "Total: $<?php echo number_format($suma,2); ?>" me devuelve el número con punto (51.00).

Si pueden darme una mano se los agradecería. Solo me falta solucionar esto para tener el carrito completo.

Muchas gracias. Marx.
__________________
"Todo lo que somos es el resultado de lo que hemos pensado". Budda.
  #5 (permalink)  
Antiguo 22/08/2011, 10:05
 
Fecha de Ingreso: mayo-2002
Ubicación: Capital Federal
Mensajes: 630
Antigüedad: 21 años, 11 meses
Puntos: 1
Respuesta: Cómo se suma el total de los valores de una columna?

Listo, ya solucioné la suma. El código es así:
Código PHP:
  $contador=0;
  
$suma=0;
  foreach(
$carro as $k => $v)
  {
   
$subto=$v['cantidad'];
   
$suma=$suma+$subto;
   
$contador++;
  }
    echo 
$suma
Ahora 2 cosas:
- ¿Cómo hago para que la variable $suma la pueda ver desde cualquier página? Por ejemplo quisiera que en el index.php me aparezca: Total de Productos: $suma
- No me suma los decimales, ¿cómo lo puedo solucionar?

Gracias.
__________________
"Todo lo que somos es el resultado de lo que hemos pensado". Budda.

Etiquetas: suma, variables, totales
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 10:12.