草庐IT

float_exception

全部标签

ruby - 设置Ruby中 float 的显示精度

在Ruby中可以设置float的显示精度吗?类似于:z=1/3z.to_s#=>0.33333333333333z.to_s(3)#=>0.333z.to_s(5)#=>0.33333或者我是否必须覆盖Float的to_s方法? 最佳答案 z.round(2)或x.round(3)是最简单的解决方案。参见http://www.ruby-doc.org/core-1.9.3/Float.html#method-i-round.也就是说,这只会确保它不超过那么多位数。在1/3的情况下没问题,但如果你说0.25.round(3)你会得到0

ruby-on-rails - rails ActiveRecord : Find All Users Except Current User

我觉得这应该很简单,但是我的脑子短路了。如果我有一个代表当前用户的对象,并且想查询除当前用户之外的所有用户,考虑到当前用户有时可能为nil,我该怎么做?这就是我现在正在做的:defindex@users=User.all@users.deletecurrent_userend我不喜欢的是我正在对查询结果进行后处理。除了感觉有点不对之外,如果我将查询转换为使用will_paginate运行,我认为这不会很好地工作。关于如何通过查询执行此操作的任何建议?谢谢。 最佳答案 可以在Rails4及更高版本中执行以下操作:User.where.

ruby - 将 float 四舍五入到 ruby​​ 中最接近的整数

如果我有一个49.967的float并且我执行.to_i它将把它削减到49这对于我使用磁盘空间分析.967超过900mb的空间不会在显示中考虑。是否有将数字四舍五入到最接近的整数的函数,或者我必须像这样自己定义它:classFloatdefto_nearest_i(self+0.5).to_iendend这样我就可以做:>>5.44.to_nearest_i=>5>>5.54.to_nearest_i=>6 最佳答案 试试Float.round。irb(main):001:0>5.44.round=>5irb(main):002:0

ruby - 如何使用#{variable} 在 Ruby 中格式化带有 float 的字符串?

我想格式化一个包含浮点变量的字符串,包括带有固定小数位数的它们,我想用这种格式化语法来实现:amount=Math::PIputs"Currentamount:#{amount}"我想获得当前金额:3.14。我知道我可以用amount=Math::PIputs"Currentamount%.2f"%[amount]但我想问是否有可能以#{}方式进行。 最佳答案 您可以使用"#{'%.2f'%var}":irb(main):048:0>num=3.1415=>3.1415irb(main):049:0>"Piis:#{'%.2f'%n

ruby - `raise "foo "` and ` raise Exception.new ("foo")` 有什么区别?

在技术、哲学、概念或其他方面有什么区别raise"foo"和raiseException.new("foo")? 最佳答案 从技术上讲,第一个引发RuntimeError,消息设置为"foo",第二个引发异常,消息设置为"foo".实际上,使用前者和使用后者之间存在显着差异。简单地说,您可能想要一个RuntimeError不是Exception.没有参数的救援block将捕获RuntimeErrors,但不会捕获Exception秒。所以如果你提出Exception在您的代码中,此代码不会捕获它:beginrescueend为了ca

ruby-on-rails - rails : Logging the entire stack trace of an exception

我一直在尝试找出记录堆栈跟踪的正确方法。我遇到了this链接指出logger.error$!,$!.backtrace是要走的路,但这对我不起作用log_error。根据文档,我看不出将第二个参数传递给错误方法是如何工作的,因为rails使用的ruby​​记录器只接受一个参数。奇怪的是(或者可能不是)第二个论点被接受了,没有任何口译员的提示。但是,我传递给它的任何内容都将被忽略。谁能解释一下我错过了什么?对错误的第二个论点是什么以及是什么吞噬了它有什么见解吗? 最佳答案 如果您查看ActiveSupport中BufferedLogg

ruby - 你如何在 JRuby 中将 float 四舍五入到小数点后两位?

如何在JRuby(1.6.x)中将float四舍五入到小数点后两位?number=1.1164number.round(2)#Theaboveshowsthefollowingerror#wrongnumberofarguments(1for0) 最佳答案 (5.65235534).round(2)#=>5.65 关于ruby-你如何在JRuby中将float四舍五入到小数点后两位?,我们在StackOverflow上找到一个类似的问题: https://st

ruby - 为什么在 Ruby 中 `rescue Exception => e` 是错误的风格?

瑞恩戴维斯的RubyQuickRef说(没有解释):Don’trescueException.EVER.orIwillstabyou.为什么不呢?什么是正确的做法? 最佳答案 TL;DR:使用StandardError代替一般异常捕获。当重新引发原始异常时(例如,当救援仅记录异常时),救援Exception可能没问题。Exception是Ruby'sexceptionhierarchy的根,所以当你rescueException时,你从一切中拯救出来,包括SyntaxError、LoadError和中断。挽救中断可以防止用户使用CT

javascript - LINQ.JS,用于 Except 的 comparerSelector

我正在尝试使用LINQ.JS(不是.NetLINQ!),但无法获得comparerSelector概念。我有两个对象数组,每个对象都包含Id、Name、Date、Passport等。我只想通过以下2个字段来区分它们:Id、Name。应忽略日期和护照上的差异。comparerSelector怎么写?以下仅适用于Id:Enumerable.From(p2).Except(p1,"$.Id}").ForEach(function(x){alert('Id=='+x.Id);});这也行:Enumerable.From(p2).Except(p1,function(x){returnx.Id;

Javascript float + float = 字符串?

当我运行它时,它返回NaN。如果我不parseFloat,我将添加2个字符串。我错过了什么?我会说我的结果应该总是一个float?functioncalculate(i){varresult=0.0;$j(".t"+i+"input").each(function(){varnumber=$j(this).val();number=number.replace(",",".");if(parseFloat(number)!=NaN){result=parseFloat(result);number=parseFloat(number);result+=number;}});consol