草庐IT

c++ - 一次从套接字读取 1 个字节与读取大块

全部标签

ruby - 在 Ruby 中,您可以对从文件中读取的数据执行字符串插值吗?

在Ruby中,您可以在字符串中引用变量,并在运行时对它们进行插值。例如,如果您声明一个变量foo等于"Ted"并声明一个字符串"Hello,#{foo}"它插入到"Hello,Ted"。我一直无法弄清楚如何对从文件读取的数据执行神奇的"#{}"插值。在伪代码中它可能看起来像这样:interpolated_string=File.new('myfile.txt').read.interpolate但是最后一个interpolate方法不存在。 最佳答案 我认为这可能是在Ruby1.9.x中执行您想要的操作的最简单和最安全的方法(spr

Ruby 匹配第一次出现的字符串以进行 gsub 替换

我有一个字符串让我们说http://someUrul.com/someController/SOmeAction?SomeQS=http://someOtherUrl我想用https替换第一个http,但不是第二个,所以我最终得到https://someUrul.com/someController/SOmeAction?SomeQS=http://someOtherUrl如何使用简单的gsub完成此操作?以下内容替换了两者。request.url.gsub(/http:/,"https:") 最佳答案 使用sub,不是gsub.g

ruby - 如何从 Ruby 命令行读取密码?

我在Windows机器上运行Ruby和MySQL。我有一些Ruby代码需要连接到MySQL数据库并执行选择。要连接到数据库,我需要提供密码等。Ruby代码可以显示要求输入密码的提示,用户输入密码并按下Enter键。我需要的是将键入的密码显示为一行星号。如何让Ruby在“dosbox”中将输入的密码显示为一行星号? 最佳答案 为了回答我自己的问题,为了其他任何想知道的人的利益,有一个名为HighLine的Rubygem你需要的。require'rubygems'require'highline/import'defget_passwo

ruby - Kernel#gets 尝试读取文件而不是标准输入

我是Ruby的新手,今天我编写了一个应用程序,您可以通过ARGV向其传递参数。但在我的应用程序中,我希望能够使用“gets”。问题是,每次我尝试这样做时,都会出现错误。这是一个显示我的问题的简单脚本:print"Saysomething!"input=gets如果我这样调用它:$rubyscript.rbthisisarguments我收到这个错误:script.rb:2:in`gets':Nosuchfileordirectory-this(Errno::ENOENT)fromscript.rb:2希望有人能帮我解决这个问题,这样我就可以继续我的Ruby之旅。:)编辑:我知道“Get

ruby - 将整个文本文件作为单个字符串读取的合理方法是什么?

我相信这很容易;我无法立即从Google找到答案。我知道我可以做到这一点(对吧?):text=""File.open(path).each_linedo|line|text+=lineend#Dosomethingwithtext但这似乎有点过分,不是吗?或者这是人们在Ruby中的做法吗? 最佳答案 IO.read()正是您要找的。File是IO的子类,所以你也可以使用:text=File.read(path)没有比这更直观的了。 关于ruby-将整个文本文件作为单个字符串读取的合理方法

ruby-on-rails - 如何一次显示一条 Ruby on Rails 表单验证错误消息?

我正在尝试了解如何实现这一目标。谁能给我建议或指出正确的方向?我目前所做的(如下面的代码片段所示)允许我一次显示每个字段的1个错误。这不完全是我想做的。我想一次显示1条错误消息。例如,“名字不能为空”,那么一旦错误被解决,错误数组中的下一个错误就会被显示出来。这应该一直发生,直到所有错误都得到解决。 最佳答案 ActiveRecord将验证错误存储在一个名为errors的数组中。如果您有一个User模型,那么您将像这样访问给定实例中的验证错误:@user=User.create[params[:user]]#createwillau

ruby - 读取文件时如何避免被 UTF-8 BOM 绊倒

我正在使用最近添加了UnicodeBOMheader(U+FEFF)的数据提要,现在我的rake任务被它搞砸了。我可以使用file.gets[3..-1]跳过前3个字节,但是是否有更优雅的方式来读取Ruby中的文件,它可以正确处理这个问题,无论BOM是有没有? 最佳答案 在ruby​​1.9.2中,您可以使用模式r:bom|utf-8text_without_bom=nil#definethevariableoutsidetheblocktokeepthedataFile.open('file.txt',"r:bom|utf-8")

ruby - 如何将 Ruby 字符串强制为 n 个字符

如何使用puts将Ruby字符串变量输出强制为n个字符,以便如果变量更长,它将被截断,如果更短,它将通过尾随或前导空格扩展?是否有一些标准方法可以做到这一点? 最佳答案 与许多其他语言一样,Ruby支持使用格式字符串:[11](pry)main:0>'%3.3s'%'f'=>"f"[12](pry)main:0>'%3.3s'%'foo'=>"foo"[13](pry)main:0>'%3.3s'%'foobar'=>"foo"如果你想在右边填充,在格式字符串中使用-:[14](pry)main:0>'%-3.3s'%'f'=>"f

ruby - 使用 utf-8 编码写入和读取文件

我一直在阅读所有与UTF-8相关的问题和博客文章,并且在test.rb文件中有以下示例:#encoding:UTF-8File.open("test.txt","w")do|f|f.write"test©foo"endFile.open("test.txt","r")do|f|putsf.readend这非常有效。是在文件中正确生成©符号,并将©读回给我并将其打印在屏幕上。但是当我在我的实际项目中使用相同的代码时,我将其写入文件而不是©符号:\u00A9FWIW:我在针对我的代码运行rspec(v1.2.9)测试时得到了这个结果。规范生成一个带有©符号的文件,然后读回该文件以检查内容。

ruby - 迭代一个数组,一次 n 项

我有一个数组:[1,2,3,4,5,6,7,8,9,0]我想一次迭代3,这会产生1,2,3and4,5,6and7,8,9and0在Ruby中执行此操作的最佳方法是什么? 最佳答案 您正在寻找#each_slice.data.each_slice(3){|slice|...} 关于ruby-迭代一个数组,一次n项,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/12869614/