草庐IT

ruby - 使用 ruby​​-yajl 解析大型 JSON 哈希?

我有一个包含JSON散列的大文件(>50Mb)。像这样的东西:{"obj1":{"key1":"val1","key2":"val2"},"obj2":{"key1":"val1","key2":"val2"}...}与其解析整个文件并取前十个元素,不如解析散列中的每个项目。我实际上并不关心key,即obj1。如果我将上面的转换为:{"key1":"val1","key2":"val2"}"obj2":{"key1":"val1","key2":"val2"}我可以使用Yajl流轻松实现我想要的:io=File.open(path_to_file)count=10Yajl::Parse

ruby-on-rails - 将大型 Rails 应用程序分解成较小的应用程序?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭10年前。我有一个包含600个模型的Rails应用程序,很快就会增加到800-1000个。我想对Rails应用程序进行分段,以便仅加载某些模型,因此充当单独的应用程序,但所有模型都共享相同的基本模型。是否有执行此操作的标准做法?编辑:我在2.3.8编辑2:问题是许多模型是相似的,但不同之处恰恰足以保证编写一个新类,也就是说,将所有模型都放在一个模型中所需的逻辑将是

ruby-on-rails - 如何使用 ruby​​ 加速大型 CSV 的处理

对于一个项目,我需要解析一些非常大的CSV文件。一些条目的内容存储在MySQL数据库中。我正在尝试使用多线程来加快速度,但到目前为止,这只会减慢速度。我解析了一个CSV文件(最大10GB),其中一些记录(20M+记录CSV中的大约5M)需要插入到MySQL数据库中。为了确定需要插入的记录,我们使用Redis服务器和包含正确ID/引用的集合。由于我们在任何给定时间处理大约30个这样的文件,并且存在一些依赖关系,我们将每个文件存储在一个Resque队列中,并让多个服务器处理这些(优先级)队列。简而言之:classWorkerdefself.perform(file)CsvParser.ea

ruby - 使用 ruby​​ 流式传输和解压缩大型 csv 文件

我遇到问题,我需要下载、解压缩,然后逐行处理一个非常大的CSV文件。我认为让您了解文件有多大很有用:big_file.zip~700mbbig_file.csv~23gb这是我希望发生的一些事情:解压缩前不必下载整个文件在解析csv行之前不必解压缩整个文件在执行所有这些操作时不要占用太多内存/磁盘我不知道这是否可能。这是我的想法:require'open-uri'require'rubyzip'require'csv'open('http://foo.bar/big_file.zip')do|zipped|Zip::InputStream.open(zipped)do|unzipped

ruby-on-rails - Rails 4 中的 Asset-Pipeline/Turbolinks 对于大型应用程序的优缺点是什么?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我们正在开发一个相当大且广泛的应用程序。该网站将有许多不同的部分,具有一些非常不同的用户界面要求和行为。展望future,Rails4将Assets管道分离到一个单独的gem中,因此我们可以选择包含或不包含它。turbolinks可能会发生同样的事情。这些天我一直在问自己但找不到答案的问题是:我是否应该在我们的项目中使用这些库?我反射(reflect)的主

ruby-on-rails - Rspec 和大型规范文件组织

我只是想知道其他人如何组织大型规范文件(尤其是模型),其中许多上下文和部分组织在描述block中,用于验证和其他可以以某种有意义的方式分组的规范。你们是否将有关模型的所有规范保存在该模型的同一个规范文件中,或者你们是否以某种方式拆分为模块?到目前为止,我从来没有太在意过这个,但我想知道其他人在做什么,因为似乎没有围绕最佳实践等达成某种协议(protocol)。对于某些模型,我有一些非常大的规范文件,我想将它们组织成较小的文件,而且不同模型之间几乎没有或没有共享功能,所以我不确定共享示例是否可以解决这个问题(无论可重用性如何)或者是否有更好的方法。有什么建议吗?提前致谢。

ruby-on-rails - 在具有 RoR 的大型项目中使用 ExtJS 的危险?

我们正在使用RubyonRails框架(CRM系统)开发一个相当大的应用程序,并正在考虑重写它以使用ExtJS,这样Rails将只进行数据处理,而ExtJS将在桌面上完成所有浏览器的繁重工作-喜欢举止。任何人都有一些关于什么是最佳方法的经验和提示?ExtJS是否足够成熟以用于相对较大(和复杂)的应用程序?那么Rails部分呢-这里最好的方法是什么?编辑:只是为了说清楚。我更愿意以这样一种方式来加载所有javascript客户端应用程序代码(在应用程序启动时,最好作为一个压缩的js文件),然后只使用ajax将数据发送到Rails或从Rails发送数据应用程序。此外,如果ERB可用于动态生

在大型双重转换为未签名的INT中堆叠腐败

在Windows计算机上运行VisualC++,我发现以下代码行似乎是通过调用__dtoui3的呼叫损坏内存(此调用后一堆字节更改。具体来说,DBL_MAX的值似乎是在两次中打印的,在记忆中的随机位置行)doubletemp=DBL_MAX;unsignedintblissfullyUnaware=(unsignedint)temp;但是,以下没有:doubletemp=0;unsignedintblissfullyUnaware=(unsignedint)temp;谁能阐明为什么会发生这种情况?看答案[cons.fpint]/1浮点类型的prvalue可以转换为整数类型的prvalue。转换

ruby-on-rails - 在大型 Rails 应用程序中加速 RSpec 测试

在我的RSpec测试中,我有一个包含2,000多个示例的Rails应用程序。不用说,这是一个大型应用程序,需要测试的内容很多。此时运行这些测试效率非常低,而且因为它需要很长时间,我们几乎不鼓励在推送新构建之前编写它们。我将--profile添加到我的spec.opts以查找运行时间最长的示例,其中至少有10个平均需要10秒才能运行。这在你们RSpec专家中是正常的吗?10秒对于一个例子来说是不是太长了?我意识到使用2,000个示例,彻底测试所有内容将花费大量时间-但此时4小时有点荒谬。对于运行时间最长的示例,您看到了什么样的时间?我可以做些什么来解决我现有的规范问题,以找出瓶颈并帮助加

javascript - 使用 javascript 将大型 HTML 字符串加载到 UIWebView

通常,当我想使用javascript将HTML字符串加载到webview中时,我会使用类似这样的东西...NSString*htmlString=@"HTMLString";[webViewstringByEvaluatingJavaScriptFromString:[NSStringstringWithFormat:@"document.getElementById('elementid').innerHTML=\"%@\";",htmlString]];虽然这对于小字符串似乎很有效,但当字符串相对较大时就没有效果了。显然,有一个长度限制。所以,我的问题是,是否有人知道无需重新加载w