我需要在Ruby中为变量创建签名字符串,其中变量可以是数字、字符串、散列或数组。哈希值和数组元素也可以是这些类型中的任何一种。此字符串将用于比较数据库(在本例中为Mongo)中的值。我的第一个想法是创建一个JSON编码值的MD5散列,如下所示:(body是上面提到的变量)defcreatesig(body)Digest::MD5.hexdigest(JSON.generate(body))end这几乎可以工作,但是JSON.generate不会每次都以相同的顺序对散列的键进行编码,所以createsig({:a=>'a',:b=>'b'})并不总是等于createsig({:b=>'b
标题本身就说明了一切。我只想知道它是否存在,而不是它在哪里。是否有一个衬垫可以实现这一目标? 最佳答案 File.open(filename).grep(/string/)这会将整个文件载入内存(slurps文件)。你应该避免文件slurpingwhendealingwithlargefiles.这意味着一次加载一行,而不是整个文件。File.foreach(filename).grep(/string/)最好自己清理,而不是让垃圾收集器在某个时候处理它。如果您的程序是长期存在的,而不仅仅是一些快速脚本,那么这一点就更为重要。使用代
如何使用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
正则表达式/abc$/将匹配出现在行尾的abc。我该怎么做?我想匹配不在行尾的abc。此外,我将使用正则表达式来替换字符串,所以我只想捕获abc,而不是字符串后面的任何内容,所以/abc.+$/不起作用,因为它不仅会替换abc,还会替换abc之后的所有内容。正确的正则表达式是什么? 最佳答案 /abc(?!$)/(?!$)是一个negativelookahead.它将查找abc的任何匹配项,但后面没有直接跟$(行尾)测试abcddee(匹配)dddeeeabc(不匹配)adfassdfabcs(匹配)fabcddee(匹配)将它应用
对于字符串中正则表达式的每次出现,我都需要MatchData。这与MatchAllOccurrencesofaRegex中建议的扫描方法不同,因为这只会给我一个字符串数组(我需要完整的MatchData,以获取开始和结束信息等)。input="abc12def34ghijklmno567pqrs"numbers=/\d+/numbers.matchinput##(onlythefirstmatch)input.scannumbers#["12","34","567"](allmatches,butonlythestrings)我怀疑我忽略了某些方法。有什么建议吗?
这是这个问题的反面:Whycan'tstringsbemutableinJavaand.NET?在Ruby中做出这个选择仅仅是因为操作(追加等)对可变字符串有效,还是有其他原因?(如果只是效率,那似乎很奇怪,因为Ruby的设计似乎并没有高度重视促进高效实现。) 最佳答案 如您所见,这符合Ruby的设计。不可变字符串比可变字符串更有效——更少的复制,因为字符串被重复使用——但让程序员的工作更加困难。将字符串视为可变的很直观——您可以将它们连接在一起。为了解决这个问题,Java默默地将两个字符串的连接(通过+)转换为StringBuff
我是Ruby的新手,一直使用String.scan来搜索数字的第一次出现。返回值在嵌套数组中有点奇怪,但我只是去[0][0]获取我想要的值。(我确定它有它的用途,只是我还没有使用它。)我刚刚发现有一个String.match方法。而且似乎更方便,因为返回的数组不是嵌套的。这是两者的一个例子,第一个是扫描:>>'a1-nightstay'.scan(/(a)?(\d*)[-]night/i).to_a=>[["a","1"]]然后是匹配>>'a1-nightstay'.match(/(a)?(\d*)[-]night/i).to_a=>["a1-night","a","1"]我已经检查了
我正在尝试计算一个字符串在另一个字符串中出现的次数。我知道你可以数出一个字母在字符串中出现的次数:string="aabbccddbb"string.count('a')=>2但是如果我搜索'aa'在这个字符串中出现了多少次,我也会得到两次。string.count('aa')=>2我不明白这个。我将值放在引号中,因此我搜索的是确切字符串出现的次数,而不仅仅是字母。 最佳答案 这里有几种方法可以计算给定子字符串在字符串中出现的次数(第一种是我的偏好)。请注意(经OP确认)子字符串'aa'在字符串'aaa'中出现两次,因此出现了五次:
我有用户条目作为文件名。当然这不是一个好主意,所以我想删除除[a-z]、[A-Z]、[0-9]之外的所有内容,_和-。例如:my§document$is°°very&interesting___thisIs%nice445.doc.pdf应该变成my_document_is_____very_interesting___thisIs_nice445_doc.pdf然后理想情况下my_document_is_very_interesting_thisIs_nice445_doc.pdf有没有一种优雅而优雅的方式来做到这一点? 最佳答案
为什么这在Ruby中有效:"foo""bar"#=>"foobar"我不确定为什么要连接字符串而不是给出语法错误。我很好奇这是否是预期的行为,以及它是否是解析器负责争吵的东西(两个没有运算符的字符串被认为是一个字符串)或者语言定义本身正在指定这种行为(隐式连接)。 最佳答案 在C和C++中,stringliterals彼此相邻areconcatenated.由于这些语言影响了Ruby,我猜它是从那里继承的。它现在用Ruby记录:参见thisanswer和thispageintheRubyrepo其中指出:Adjacentstring