草庐IT

Bigdecimal

全部标签

ruby-on-rails - rspec 大十进制匹配器

-:total_cost_with_tax=>#,-:total_cost_without_tax=>#,-:total_last_installment_amount=>#,-:total_monthly_installment_amount=>#,-:total_tax=>#,+:total_cost_with_tax=>#,+:total_cost_without_tax=>#,+:total_last_installment_amount=>#,+:total_monthly_installment_amount=>#,+:total_tax=>#,因此,这些在我的一些测试中随

ruby-on-rails - Ruby BigDecimal 圆 : Is this an error?

在用一个表示为BigDecimal的值编写测试时,我遇到了一些奇怪的事情并决定深入研究它。简而言之,四舍五入到小数点后两位的“0.00009”返回为0.01而不是0.00。真的。这是我的脚本/控制台捕获:>>bp=BigDecimal('0.09')=>#>>bp.round(2,BigDecimal::ROUND_HALF_DOWN).to_f=>0.09>>bp=BigDecimal('0.009')=>#>>bp.round(2,BigDecimal::ROUND_HALF_DOWN).to_f=>0.01>>bp=BigDecimal('0.0009')=>#>>bp.roun

ruby - 如何将 ruby​​ BigDecimal 转换为 2 位小数位字符串?

我想将RubyBigDecimal对象转换为漂亮的、可打印的货币值。所以我想让它打印到小数点后两位。我该怎么做?如您所见,以下方法均无效:irb(main):033:0>v=BigDecimal("7.1762")=>#irb(main):034:0>v.to_s('2F')=>"7.1762"irb(main):035:0>v.to_s('F')=>"7.1762"irb(main):036:0>v.to_s('%0.2F')=>"0.71762E1"irb(main):037:0>v.to_s('%0.2f')=>"0.71762E1"irb(main):038:0>哪个表达式只会

ruby - 为什么 BigDecimal 返回一个奇怪的值?

我正在编写处理货币、费用等的代码。我将使用BigDecimal类进行数学和存储,但我们遇到了一些奇怪的事情。这个声明:1876.8==BigDecimal('1876.8')返回错误。如果我通过格式化字符串"%.13f"运行这些值,我得到:"%.20f"%1876.8=>1876.8000000000000"%.20f"%BigDecimal('1876.8')=>1876.8000000000002请注意BigDecimal在最后一位小数处的额外2。我认为BigDecimal应该可以解决将实数直接存储在计算机nativefloat中的不准确性。这个2来自哪里?

ruby - 如何将 BigDecimal 转换为两位小数的字符串?

我想将BigDecimal对象转换为保留两位小数的货币值。我不想四舍五入。我该怎么做?以下方法均无效:v=BigDecimal("7.1762")w=BigDecimal("4.2")v.to_s('2F')#=>"7.1762"v.to_s('F')#=>"7.1762"v.to_s('%0.2F')#=>"0.71762E1"v.to_s('%0.2f')#=>"0.71762E1"v.truncate(2).to_s('F')#=>"7.17"#Thisonelookslikeitworkedw.truncate(2).to_s('F')#=>"4.2"#Butitdoesn't

ruby - 为什么我的 BigDecimal 对象初始化时出现意外舍入错误?

在Ruby2.2.0中,为什么:BigDecimal.new(34.13985572755337,9)等于34.0但是BigDecimal.new(34.13985572755338,9)等于34.1398557?请注意,我在64位机器上运行它。 最佳答案 用字符串而不是float初始化一般来说,您无法通过float获得可靠的行为。您错误地使用Float值而不是String值初始化BigDecimals,这在一开始就引入了一些不精确性。例如,在我的64位系统上:float1=34.13985572755337float2=34.13

ruby-on-rails - Ruby BigDecimal 健全性检查( float newb)

我的理解是否正确,即使用RubyBigDecimal类型(即使具有不同的精度和标度长度)应该准确计算还是我应该预测浮点恶作剧?我在Rails应用程序中的所有值都是BigDecimal类型,我看到了一些错误(它们确实有不同的小数长度),希望这只是我的方法而不是我的对象类型。 最佳答案 使用浮点运算时有两个常见的陷阱。第一个问题是Rubyfloat具有固定的精度。在实践中,这要么是1)对您来说没问题,要么2)灾难性的,或者3)介于两者之间。请考虑以下事项:#float1.0e+25-9999999999999999900000000.0

java - Castor 为 xsd 中的整数类型生成 BigDecimal 类型

我使用的xsd架构如下:意思是像XML:111000111但是Castor只为这个模式生成BigDecimal类型:publicabstractclassTrxIdRs_Typeimplementsjava.io.Serializable{//--------------------------///-Class/MemberVariables-///--------------------------//***internalcontentstorage*/privatejava.math.BigDecimal_content;/***Field_trxStatusCode.*/pr

java - 如何避免嵌套的 for-each 循环?

我有一个应该解析XML文件的类,如下所示:...123456Mike...233658...1234510.05......我将使用JAXB解码它,然后处理结果对象以获得统计信息(例如最大订单量、总订单量等)在这种情况下,使用3级foreach循环是一种不好的做法吗?publicvoidgetStatistics(){for(Customercustomer:this.customers.getCustomer()){BigDecimalcustomerTotalAmount=newBigDecimal(0);for(Orderorder:customer.getOrders().ge

c# - 如何在 C# 中获取超过 100 位的十进制数字?

在C#中是否可以获取超过100位的十进制数字?如果是,代码的必要部分是什么?在Java中有一个叫做BigDecimal的东西,但它仍然不能超过55位。 最佳答案 使用J#库:DownloadtheJ#可重新分发以获取J#类库。Thisarticlehints关于如何使用它在您的.NET项目中获得ZIP能力,并解释了一些关于BigDecimal的信息,但正如Ramhound解释的那样,这篇文章相对较旧。下载后,将vsjlib添加到您的项目中。它在.NET4.0上对我不起作用,但在2.0项目上确实有效。它包含一个BigDecimal类,