草庐IT

JavaScript数值计算时精度问题处理

全部标签

ruby-on-rails - 使用 Rails Assets 管道在 JavaScript 文件中编码问题

我正在使用Rails3.1和Assets管道(ruby1.9.2)。在尝试提供具有utf-8编码字符串的javascriptjs.erb文件时出现以下错误invalidbytesequenceinUS-ASCII我在我的environment.rb文件中设置了Encoding.default_external="UTF-8"。我如何让Assets管道以不同的编码提供服务?编辑仅当我在文件外部生成utf-8字符时才会出现该错误(在本例中是通过从数据库查询)。如果我添加,错误就会消失到文件的顶部。我猜这里会进行某种编码猜测,但如果没有那种骇人听闻的解决方案,我该如何避免呢?

ruby - 如何计算ruby服务器中正在运行的线程

我想在Sinatra网络服务器的线程中执行“长时间运行”-(执行大约需要0.5秒)任务。Web响应大约需要20毫秒,所以如果我很忙,线程就会堆积起来......所以我想如果我忙的话我会同步..if(running_thread_count>10)stuff_that_takes_a_second()elseThread.newdostuff_that_takes_a_second()endend您如何获得正在运行的线程数(我想要启动的线程数,但尚未完成运行)-您如何编写running_thread_count代码?defrunning_thread_countreturnThread.

ruby - 类内的路由处理程序

我有一个Sinatra应用程序设置,其中大部分逻辑在各种类中执行,post/get路由实例化这些类并调用它们的方法。我在考虑将post/get路由处理程序放在类本身中是否会是一个更好的结构。无论如何,我想知道这是否可能。例如:classExampledefsay_hello"Hello"endget'/hello'do@message=say_helloendend如果不修改以上内容,Sinatra会说SinatraApplication对象上没有方法say_hello。 最佳答案 你只需要继承Sinatra::Base:requi

ruby - 在 Mountain Lion 上安装 Ruby 时出现问题 - ruby​​ 1.9.3 不会编译

我之前看过很多关于此的帖子,并按照他们的说明进行操作,但没有任何效果。我将在下面概述我所做的事情,以及我所遵循的说明-如果您有任何建议,我将不胜感激!我遵循了以下安装说明:http://pragmaticstudio.com/blog/2010/9/23/install-rails-ruby-mac我已经为OSXMountainLion下载了X代码,并安装了gcc编译器:$gcc--versioni686-apple-darwin11-llvm-gcc-4.2(GCC)4.2.1(BasedonAppleInc.build5658)(LLVMbuild2336.11.00)Copyri

ruby-on-rails - Rails 以月为单位计算日期范围

如何计算两个日期的月差?此外,如果它有所作为,我正在使用Date对象,而不是DateTime。此外,一些舍入选项可能会很好,这样我就可以控制是否要对部分月份进行向上或向下舍入。谢谢! 最佳答案 从一个Date或DateTime中减去另一个Date或DateTime将得到天数的分数,但这可以根据需要评估为Float或Fixnum。例如:(Date.today-Date.today.advance(:months=>-3)).to_f#=>89.0今天与三个月前的同一日历日期之间相隔89.0天。如果您使用30天的月份或平均30.4375

ruby-on-rails - 从 HTML 页面中删除所有 JavaScript

我试过使用Sanitizegem清理包含网站HTML的字符串。它只删除了标记,而不是脚本标记内的JavaScript。我可以使用什么从页面中删除JavaScript? 最佳答案 require'open-uri'#includedwithRuby;onlyneededtoloadHTMLfromaURLrequire'nokogiri'#geminstallnokogirireadmoreathttp://nokogiri.orghtml=open('http://stackoverflow.com')#GettheHTMLsour

ruby - 下载前获取文件大小并计算已经下载了多少 (http+ruby)

谁能帮帮我在我开始下载之前获取文件大小显示已经下载了多少%.require'net/http'require'uri'url="http://www.onalllevels.com/2009-12-02TheYangShow_Squidoo_Part1.flv"url_base=url.split('/')[2]url_path='/'+url.split('/')[3..-1].join('/')Net::HTTP.start(url_base)do|http|resp=http.get(URI.escape(url_path))open("test.file","wb")do|fi

ruby - RSpec 中的 "to"方法出现问题(未定义的方法)

这里是rspec的全新内容,这将变得很明显。以下rspec文件失败:require_relative('spec_helper')describeGenotypingScenariodoit'shouldaddgenes'doscen=GenotypingScenario.newgene=Gene.new("Pcsk9",989)scen.addGene(gene)expect(gene.id).toeq(989)ct=scen.genes.countexpect(ct).toequal(1)expect(5).toeq(5)endend具体来说,最后两行expect()失败,错误如下

ruby-on-rails - 如何解决超时问题(Ruby、Rails)

我的大部分应用程序都与网络服务有很大关系,并且经常由于第三方网站而出现超时问题。这是我得到的错误:executionexpired/usr/lib/ruby/1.8/timeout.rb:54:in`rbuf_fill'如何在Rails应用程序中解决此类错误? 最佳答案 根据您使用库的方式,有不同的方法来挽救异常。在图书馆假设您创建了一个包装器来访问某种网络服务,您可以让包装器挽救异常并始终返回“安全”数据。在行动中如果你在action中调用了一个特定的方法,并且方法success是action的一个要求,那么你可以在action中

ruby - 快速处理大量 CSV 数据的最佳方式

我有大型CSV数据集(超过1000万行)需要处理。我有两个其他文件需要引用输出-它们包含的数据放大了我们对CSV文件中数百万行的了解。目标是输出一个新的CSV文件,其中每条记录都与来自其他文件的附加信息合并。假设大型CSV文件有交易,但客户信息和账单信息记录在另外两个文件中,我们想要输出一个新的CSV,其中每笔交易都链接到客户ID和账户ID等。一位同事有一个用Java编写的功能程序来执行此操作,但速度很慢。原因是数百万行的CSV文件显然要遍历很多很多次。我的问题是——是的,我已经开始了——我应该如何在Ruby中处理这个问题?目标是让它更快(现在18小时以上,CPU事件很少)我可以将这么