Jump to content
Sign in to follow this  
Hamon

Números decimais na multiplicação

Recommended Posts

Olá, pessoal, estou com uma grande dúvida e dor de cabeça. Estou criando um sisteminha... e nele tenho alguns inputs que devem ser preenchidos pelo usuario, depois de enviar deverá aparecer todos deverá aparecer uma multiplicação no final, que seria entre uma QUANTIDADE e um PREÇO ($quantidade * $preco) ou pegando por post seria esses valores (2 * 1.500,00) só que ele não aparece o resultado correto (mesmo trocando "," por ".") em vez de obter o resultado de 3.000 eu só consigo o resultado de 3,0 (com number format) e 3 sem number format. A pergunta é a seguinte: Como fazer com que o resultado final da minha multiplicação seja 1.500,00? (esse exemplo que dei só funcionaria caso eu colocasse no preço como 1500, usando o number format. Mas não posso depender que o usuario faça isso.)

 

CÓDIGO:


  <?php 
	
		include "conexao.php";
		
		@$data=$_POST['data'];
		@$nome=$_POST['nome'];
		@$quantidade=$_POST['quantidade'];
		@$resultado=$_POST['quest'];
		@$preco=$_POST['preco'];
		@$enviar=$_POST['enviar'];
		
		@$preco_final= $quantidade * $preco; 
		
		echo number_format($preco_final, 2, ',', '.')."<br/><br/>";
		 
		 		
		
		echo $data." ".$nome." ".$quantidade." ".$resultado." ".$preco." ".$preco_final;

?>

 

Share this post


Link to post
Share on other sites

Você deve garantir que 1.500,00 se transforme em 1500.00, com isto a multiplicação dará certo. Basta usar str_replace.

Share this post


Link to post
Share on other sites

Bom, tudo deveria estar correndo normal a menos que haja erro nos dados de entrada.

Sugiro debugar os inputs antes de executar o script.

var_dump($_POST);

Se estiver utilizando algum tipo de máscara no input, filtre os dados não numéricos antes de executar a operação.

Caso não ainda assim não consiga resolver, posta o resultado do var_dump.

Share this post


Link to post
Share on other sites

Como utilizar o var_dump?

 

Insira na página que recebe o formulário, deste jeito:

var_dump($_POST);

Preencha o formulário corretamente, submeta e poste aqui o resultado.

Share this post


Link to post
Share on other sites

Olá, Lucas, fiz como dito e apareceu este resultado na minha tela:

 

array(6) { ["data"]=> string(10) "21/02/2016" ["nome"]=> string(7) "Revista" ["quantidade"]=> string(1) "2" ["preco"]=> string(5) "14,90" ["quest"]=> string(5) "saida" ["enviar"]=> string(6) "enviar" }

Share this post


Link to post
Share on other sites

(desculpa o double post) Seguinte, acabei de fazer uns testes e verifiquei que por exemplo, se eu por em QUANTIDADE o numero 2 e no preço 1000 (sem ponto) ele faz certinho a conta. Mas eu queria que desse para por no campo de preço o ponto, envez de precisar ser tudo junto. Outro exemplo é que caso existam centavos no meio, eu deveria por assim: 1500.40(mil e quinhentos e 40 centavos). Mas eu queria que fosse dessa forma 1.500,40

Share this post


Link to post
Share on other sites

(desculpa o double post) Seguinte, acabei de fazer uns testes e verifiquei que por exemplo, se eu por em QUANTIDADE o numero 2 e no preço 1000 (sem ponto) ele faz certinho a conta. Mas eu queria que desse para por no campo de preço o ponto, envez de precisar ser tudo junto. Outro exemplo é que caso existam centavos no meio, eu deveria por assim: 1500.40(mil e quinhentos e 40 centavos). Mas eu queria que fosse dessa forma 1.500,40 (o usuario deveria digitar dessa forma, assim sendo iria ocorrer a multiplicação (ja usando o number_format) e então eu usaria novamente o number_format para trocar as "," por ".", para poder inserir os registros no banco de dados)

Share this post


Link to post
Share on other sites

Olá, bom dia. Consegui uma função na internet que quando eu digitio por exemplo: 1.500,95 ele transforma a virgula em ponto, pronto era oq eu queria... maaassss, na hora de enserir 1.500.95 (tudo com pontos) o banco de dados não aceita, ele só aceita 1.500 em DECIMAL (7,3). Alguem pode me ajudar? Somente isso que necessito.

Share this post


Link to post
Share on other sites

Tchê, postar 500 vezes não adianta nada se você não parar 10 segundos para ler o que já foi postado... no segundo post eu te disse exatamente o que você tinha que fazer, não sabe usar o str_replace? Beleza, existe um negócio mágico, se chama MANUAL, dá uma olhada lá:

http://php.net/str_replace

 

Leu o negócio mágico e não conseguiu? Beleza, posta TODOS as suas tentativas e a gente ajuda.

 

Agora simplesmente ficar postando esperando que alguém vá fazer o seu trabalho, esquece.

Share this post


Link to post
Share on other sites

ESerra, desculpa pelos posts. Mas seguinte, já consegui oq eu queria usando uma funçao. Mas agora eu gostaria de saber como inserir um valor que existam centavos no banco de dados, por exemplo: 1.543.32

Share this post


Link to post
Share on other sites

Simples, o padrão correto é:

xxxxxxxxxxxxxxxxxxxxxxxxxxx.xx:

Colocando isto de forma de mobral:

Separar de milhar = NÃO EXISTE

Separador de centavos = PONTO

 

Como está o seu número atualmente?

1.543.32

Separador de milhar = PONTO

Separador de centavos = PONTO

 

Como o seu número deve ser:

1543.32

Separador de milhar = NÃO EXISTE

Separador de centavos = PONTO

 

Como conseguir isto? Simples, assumindo que o valor original é 1.500,95:

Primeiro use str_replace para subtituir o PONTO por nada, então o número ficará como 1500,95

Após isto use str_replace de novo para substituir a vírgula por ponto, ficando então 1500.95

Pronto, a partir daí o resultado será o esperado.

Share this post


Link to post
Share on other sites

Cara, muito obrigado, você me tirou muitas duvidas, até mesmo as que eu não pedi! Obrigado cara, você ajudou em 50% do meu projeto! :D

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

  • Similar Content

    • By Kemily
      Estou com dificuldade com este programa.
      Ele da erro e não sei o que posso fazer para ele mostrar na tela o exemplo da venda de carros.
      Neste programa eu preciso conseguir dar opções de carros e formas de pagamento ao usuário para depois armazenar a escolha e assim criar uma tabela com o id do usuário, escolha de carro, quanto será a entrada e quantas parcelas de pagamento.
      Faltam algumas coisas ainda mas eu não sei como inseri-las.
      <?php if ($_POST) { $saldo = $_POST['total'] - $_POST['entrada']; <tr> <td>carro</td> <td>$_post['carro']</td> </tr> <tr> <td>total</td> <td>$_post['carro']</td> </tr> <tr> <td>estrada</td>, <td>$_post['entrada']</td> </tr> <tr> <td>parcelas</td> <td>$_post['parcelas']</td> </tr> <tr> <td>saldo</td> <td>$_POST['total'] - $_POST['entrada']</td> </tr> } ?> <html> <body> <form name='Carros' action='' method='post'> <label for="carros">Qual carro deseja comprar?</label> <br> <br> <select name="carros"> <option value="bmw">BMW M3 Sedã</option> <option value="chevrolet">Chevrolet Volt</option> <option value="dodge">Chrysler/Dodge Journey</option> <option value="citroen">Citroen C4 Lounge</option> <option value="ford">Ford Ka</option> </select> <label for="entrada">$ Entrada</label> <input type="dinheiro" value="0" name="entrada"><br> <label for="parcelas">Quantas parcelas?</label> <select name="parcelas"> <option value="12">12</option> <option value="24">24</option> <option value="36">36</option> <option value="48">48</option> </select><br><br> <label for="total">$ Total</label> <input type="dinheiro" value="0" name="total"><br> <input type="submit" value="Enviar"> </form> </body> </html>  
    • By Kemily
      <? php /* 1 - Faça uma função que recebe 3 numeros e faça a média aritmética desses números e retorne o resultado. */ if (isset ($_POST['enviar'])); $valor1 = $_POST['valor1']; $valor2 = $_POST['valor2']; $valor3 = $_POST['valor3']; $media = ($valor1 + $valor2 + $valor3) / 3; endif; ?> <!DOCTYPE html> <html> <head> <meta charset = "Utf-8"> <title> Cálculo da média aritimética</title> </head> <body> <form method="post" action=""> <br> <label>Primeiro valor: </label> <input name="valor1" type="text"> <br> <label>Segundo valor: </label> <input name="valor2" type="text"> <br> <label> Terceiro valor: </label> <input name="valor3" type="text"> <br> <br> <button type="submit" name="enviar"> Calcular Média </button> <button type="reset"> Limpar </button> <br> <br> Valor da Média <? php echo "A média equivale a:<br>" . $media . " - "; ?> </form> </body> </html> Alguém pode me ajudar?
      Eu estou fazendo este programa para calcular a média aritmética de três número que serão digitados pelo usuário.
      Porém não estou conseguindo fazer o resultado ser apresentado na tela.
      Nem o ultimo "echo" aparece só o " " . $media . " - "; " literalmente é isso que aparece onde deveria mostrar o resultado.
      Sou iniciante na área de php e se puderem ajudar agradeço. 
    • By Marcos PP
      Tenho que retornar os dados desta URL e transformar em variaves em PHP

      Ja tentei alguns exemplos mas so me retorna Null

      http://betontec.fortiddns.com:8082/api/login?usuario=joeliton&senha=123

       
      $data = file_get_contents('http://betontec.fortiddns.com:8082/api/login?usuario=joeliton&senha=123'); $data = json_decode($data,true); var_dump($data);  
    • By gramosiri2
      Ola amigos, estou tentando fazer uma confirmação de cadastro por email, porém não estou tendo êxito. Consigo pegar o usuario, email e senha. Porem quando dou um 'echo' na variavel $id e $md5 para conferir os dados não aparece nada e o INSERT não é feito. Segue o codigo.
       
      <?php $host = "mysql:busca;host=localhost"; $usuario = "root"; $pass = ""; try{ $pdo = new PDO($host, $usuario, $pass); }catch(PDOExecption $e){ echo "Falha: ". $e->getMessage(); } $user = addcslashes($_POST['user'],"F"); $email = addcslashes($_POST['email'],"F"); $senha = md5(addcslashes($_POST['senha'],"F")); $pdo->query("INSERT INTO tabela1 SET user='$user', email='$email', senha='$senha'"); $id = $pdo->lastInsertId(); $md5 = md5($id); $assunto = "Confirme seu cadastro"; $link = "confirma.php?h=".$md5; $mensagem = '<a href="'.$link.'">Clique aqui para confirmar: </a>'; $header = "From: teste"; echo $user.'<br>'; echo $email.'<br>'; echo $senha.'<br>'; echo $id.'<br>'; echo $md5.'<br>'; mail($email, $assunto, $mensagem, $header); ?> TABELA:
      CREATE TABLE `tabela1` ( `id` int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY, `user` varchar(50), `email` varchar(100), `senha` varchar(50), `status` tinyint(4) );  
    • By sirrocha
      Oi pessoal, tenho uma dúvida referente a geração de PDFs automáticos em uma tabela.
      Gostaria de gerar um PDF para cada linha de uma tabela, contendo as informações que aparecem na interface, mas também as que estão dentro do banco de dados e preferi não mostrar pro usuário nessa parte. 
      Perguntei em um outro fórum, porém minha pergunta foi excluída, mas não estou procurando uma resposta pronta e sim uma indicação. Sou novo no assunto e por isso não tenho uma base tão sólida pra saber o caminho para eu iniciar.
       
      Tentei utilizar um padrão do dompdf, porém, aparentemente, a dica dada funcionava apenas para o CodeIgniter. O meu site está alocado no cPanel e eu usei o próprio editor de texto de lá para tudo que fiz até agora.
      Caso necessitem de mais informações, estou a disposição.
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.