草庐IT

读取控制

全部标签

ruby-on-rails - Rails 控制台数据库模式检查

我是rails/ruby的新手,我想知道如何在rails控制台中仔细检查我的数据库模式是否正确构建在railsc中ActiveRecord::Base.connection.tables给了我的输出["schema_migrations","users","expense_pictures","income_pictures","income_texts","expense_texts"]如何在控制台中检查我是否正确构建了以下架构?从用户到IncomePictures和ExpensePictures是外键。IncomePictures到ExpensePictures也是其相应文本的外键

ruby - 用 Ruby 控制 Tor 客户端

我正在写一个自动抓取网站进行数据分析的Ruby脚本,现在我有一个相当复杂的需求:我必须能够模拟来自多个国家的访问,大约20个不同的国家。该网站将根据IP位置包含不同的信息,因此完成它的唯一方法是从实际位于该国家/地区的服务器请求它。因为我不想在这20个国家/地区中的每一个国家/地区都购买服务器,所以我选择尝试一下Tor-正如你们中的许多人所知,通过编辑torrc配置文件,可以指定导出节点,因此实际请求将来自的国家/地区。当我手动执行此操作时,例如通过编辑torrc文件以使用阿根廷服务器,然后使用Vidalia断开Tor,重新连接Vidalia,然后重新运行请求,它工作正常。但是,我想完

ruby - 在 Ruby 中,如何控制 Test::Unit 测试的运行顺序?

例如,当运行这些测试时,我想确保test_fizz总是先运行。require'test/unit'classFooTest更新:我为什么要这样做?我的想法是,某些测试(那些测试更简单、更基本的方法)的早期失败将使跟踪系统中的问题变得更容易。例如,bar的成功取决于fizz是否正常工作。如果fizz坏了,我想马上知道,因为没有必要担心bar,它也会失败,但输出要复杂得多测试结果。 最佳答案 您可以使用Test::Unit::TestCase#test_order=:defined定义测试顺序例子:gem'test-unit'#Iuse

ruby-on-rails - 使用 S3 预签名 URL 上传一个文件,该文件将具有公共(public)读取权限

我正在使用RubyonRails和AWSgem。我可以获得用于上传和下载的预签名URL。但是当我得到URL时没有文件,因此将acl设置为“public-read”在下载url上不起作用。用例是这样的:1,服务器为用户提供了一个路径,用于将内容上传到我的存储桶,如果没有凭据则该存储桶不可读。2,并且该内容需要稍后公开:任何人都可以阅读。澄清一下:我没有上传文件,我提供了URL供我的用户上传。那时我也想给用户一个公众可读的URL。好像我自己上传文件会容易一些。此外,读取URL需要永不过期。 最佳答案 当您为PUT对象请求生成预签名URL

ruby-on-rails - 有没有办法在 Ruby on Rails 的控制台中检查命令的性能?

我找不到任何关于这是否可能的信息,但它会很有用及时思考。例如,我试图找出其中哪一个更快:[val2,val3,val4,val5,val6].find{|x|x!=val1}[val2,val3,val4,val5,val6].all?{|x|x==val1}有这样的东西吗?[val2,val3,val4,val5,val6].find{|x|x!=val1}.performance 最佳答案 有!而且您甚至不需要Rails。查看benchmark来自标准库。作为示例:require'benchmark'putsBenchmark.

ruby-on-rails - 如何在 Rails 控制台中将数组的每个元素打印在各自的行中?

当我运行Rails控制台时,如何在单独的行中显示每个项目?而不是>Post.all=>#,#它会显示为>Post.all=>#,#类似于Perl调试器中的x。我试过了Post.all.each{|e|e.inspect+"\n"}但这只会让事情变得更糟,而且不是很方便。我看到了RubyonRails:prettyprintforvariable.hash_set.inspect...isthereawaytoprettyprint.inpsectintheconsole?和https://github.com/michaeldv/awesome_print但这似乎行不通irb(main

Ruby:如何确定正在读取的文件是二进制文件还是文本文件

我正在用Ruby编写一个程序,它将在目录中的文本文件中搜索字符串-类似于Grep。我不希望它尝试在二进制文件中搜索,但我无法在Ruby中找到确定文件是二进制文件还是文本文件的方法。该程序需要同时在Windows和Linux上运行。如果有人能指出我正确的方向,那就太好了。谢谢,黄原素 最佳答案 libmagic是一个检测文件类型的库。对于这个解决方案,我假设所有以text/开头的mimetype都代表文本文件。其他的都是二进制文件。这个假设并不适用于所有mime类型(例如application/x-latex、application/

ruby-on-rails - Ruby - 批量读取文件

我正在读取一个大小为10mb且包含一些ID的文件。我将它们读入ruby列表。我担心将来可能会导致内存问题,因为文件中的id数量可能会增加。有没有一种批量读取大文件的有效方法?谢谢 最佳答案 与LazyEnumerators和each_slice,您可以两全其美。中间切线不用担心,可以批量迭代多行。batch_size可以自由选择。header_lines=1batch_size=2000File.open("big_file")do|file|file.lazy.drop(header_lines).each_slice(batch

Ruby - 如何从文件中读取前 n 行到数组中

出于某种原因,我找不到任何提及如何执行此操作的教程...那么,如何从文件中读取前n行?我想出了:whileFile.open('file.txt')andcount但它不起作用,而且对我来说也不是很好。出于好奇,我试过类似的东西:File.open('file.txt').10.timesdo|f|但这也没有真正起作用。那么,有没有一种简单的方法可以只读取前n行而不必加载整个文件?非常感谢! 最佳答案 这是一个单行解决方案:lines=File.foreach('file.txt').first(10)我担心它可能不会及时关闭文件(

ruby-on-rails - Rails 4.2,回形针 gem 。无法附加 .docx 类型,尽管已注册 MIME 类型,但读取 content_type 为 'application/zip'

我已经注册了一个MIME类型以允许Paperclip读取.docx文件的content_type作为application/vnd.openxmlformats-officedocument.wordprocessingml.document。但是在测试中,content_type仍被读取为application/zip。知道为什么吗?更令人沮丧的是,.pptx和.xlsxmime类型已经被注册,这些测试通过了(呃)。config/initializers/mime_types.rbMime::Type.register'application/vnd.openxmlformats-o