Como “arredondar” um float em Python? – python valor-monetário

Pergunta:


Eu tenho esta soma:

total = 0.1 + 0.2
print total #retorna 0.30000000000000004

Como eu faria para “arredondar” as casas decimais e retornar apenas o número de casas somadas? Exemplo:

totalA = 0.1 + 0.2     #retornaria 0.3
totalB = 0.32 + 0.25   #retornaria 0.57
totalC = 0.358 + 0.1   #retornaria 0.458
#...

Autor da pergunta Kazzkiq

Resposta Comunidade:

Esta é uma dúvida recorrente. Este “problema” de arredondamento ocorre pela maneira como o número de ponto fluante é armazenado e manipulado na própria CPU, e não depende do Python. O processador trabalha com ponto flutuante binário e não decimal, por isso há estes pequenas imprecisões. As linguagens acabam, por tabela, incorporando isto.

É muito rápido trabalhar com números assim e eles funcionam bem em muitos cenários. Quando você quer ter a precisão exata, provavelmente porque está trabalhando com valores monetários, precisa usar um tipo decimal ou algo parecido que garanta a precisão necessária.

O que dá para fazer em Python ou qualquer linguagem é apresentar o número com a quantidade de casas decimais desejada. Na maioria das vezes apresentará o número que deseja. Não em todas.

Nessa resposta no SO tem algumas alternativas para a apresentação:

>>> a=13.946
>>> print(a)
13.946
>>> print("%.2f" % a)
13.95
>>> round(a,2)
13.949999999999999
>>> print("%.2f" % round(a,2))
13.95
>>> print("{0:.2f}".format(a))
13.95
>>> print("{0:.2f}".format(round(a,2)))
13.95
>>> print("{0:.15f}".format(round(a,2)))
13.949999999999999

Documentação da formatação.

Muito simples:

def arredondar(num):
    return float( '%g' % ( num ) )
print(arredondar(0.1 + 0.2)

A saída: 0.3.

Você pode utilizar o .format
Você vai por algo tipo: print(“texto que vai utilizar {}”.format(a variável que utilizou))
Note que dentro das aspas “” vão duas {} dentro das {} você porá {:.Nf} o “N” é um número que será arredondado, exemplo: print(“O valor é: {:.2f}”.format(sla))
Com isso a variável que eu chamei de sla vai ser aredondada dua casas depois da vírgula e caso queira também pode por apenas {:.f} que vai praticamente tirar o número e assim arredondar ele.
Isso funciona para qualquer número que coloque antes do f dentro do {}

Fonte

Related Posts:

Qual a diferença entre AppCompatActivity e Activity? – android android-activity
Pergunta: Qual a diferença da AppCompatActivity para Activity ? A partir de qual versão a AppCompatActivity foi adicionada ao Android? Autor da pergunta Luhhh A diferença reside ...
Como abreviar palavras em PHP? – php string
Pergunta: Possuo informações comuns como nome de pessoas e endereços, e preciso que elas contenham no máximo 30 caracteres sem cortar palavras. Exemplo: 'Avenida Natalino João Brescansin' ...
Qual é a finalidade de um parêntese vazio numa declaração Lambda? – c# expressões-lambda característica-linguagem
Pergunta: Criei um exemplo de uma declaração Lambda sem argumentos, entretanto, estou com duvidas referente a omissão do parêntese vazio () na declaração. Veja o exemplo: class ...
Boas práticas para URI em API RESTful – api rest restful
Pergunta: Estou com dúvida em relação às URIs de alguns recursos da api que estou desenvolvendo. Tenho os recursos projetos e atividades com relação 1-N, ...
Dúvidas sobre a integração do MySQL com Java – java mysql netbeans
Pergunta: Estou criando um sistema no NetBeans, utilizando a linguagem Java e o banco de dados MySQL. Escrevi o seguinte código para realizar a conexão ...
Qual é a finalidade da pasta Model do framework Inphinit? – php inphinit
Pergunta: No Inphinit micro-framework existe a pasta Model que fica dentro da pasta application, e nela é onde ficam as classes, mas eu estou muito ...
Uso do ‘@’ em variáveis – javascript typescript coffeescript
Pergunta: Vejo em algumas linguagens que compilam para javascript, como TypeScript e CoffeeScript, o uso do @ em variáveis, como também, casos em que o ...
Qual tamanho máximo um arquivo JSON pode ter? – json arquivo
Pergunta: Vou dar um exemplo para conseguir explicar minha duvida: Preciso recuperar informação de imagens vindas de uma API, esse banco de imagens me retorna JSON's ...
O que é Teste de Regressão? – terminologia engenharia-de-software testes
Pergunta: Na matéria de Teste de Software o professor abordou um termo chamado Teste de Regressão, isto dentro da disciplina de teste de software. Sendo ...
O que é um construtor da linguagem? – php característica-linguagem
Pergunta: Em PHP, já li e ouvi várias vezes a respeito dos Construtores da Linguagem. Os casos que sempre ouvi falar deles foi em casos ...
Função intrínseca para converter numérico para string – cobol
Pergunta: Estou a tentar saber se existe alguma função intrínseca do COBOL para converter um data numérico para string sem precisar usar a cláusula REDEFINES: ( ...
Porque usar implements? – java android
Pergunta: Qual a diferença entre usar btn.setOnClickListener(new OnClickListener() { e public class MainActivity extends Activity implements OnClickListener{ Estive fazendo um curso de Android e meu professor falou que ...
O que é XHTML e quando deve ser usado? – html xml xhtml
Pergunta: O que eu sei é que o XHTML precisa ser XML válido. Isso implica, por exemplo, que todas as tags precisam ser fechadas. Por ...
Uma placa aceleradora de vídeo pode melhorar o desempenho não-gráfico? [fechada] – desempenho
Pergunta: Para desenvolver em Ruby on Rails, eu utilizo aqui uma máquina virtual do VirtualBox com Ubuntu Server 14.04 sem interface gráfica instalada. Recentemente descobri uma ...
Concat() VS Union() – c# .net
Pergunta: Qual a diferença entre Concat() e Union() ? Quando usar Concat() e quando usar Union() ? Somente pode ser usado em list ? ...

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios marcados com *