草庐IT

javascript替换字符

全部标签

ruby - 在 Ruby 中创建数字、字符串、数组或散列的 md5 散列

我需要在Ruby中为变量创建签名字符串,其中变量可以是数字、字符串、散列或数组。哈希值和数组元素也可以是这些类型中的任何一种。此字符串将用于比较数据库(在本例中为Mongo)中的值。我的第一个想法是创建一个JSON编码值的MD5散列,如下所示:(body是上面提到的变量)defcreatesig(body)Digest::MD5.hexdigest(JSON.generate(body))end这几乎可以工作,但是JSON.generate不会每次都以相同的顺序对散列的键进行编码,所以createsig({:a=>'a',:b=>'b'})并不总是等于createsig({:b=>'b

ruby - 在文件中搜索字符串的最佳方法是什么?

标题本身就说明了一切。我只想知道它是否存在,而不是它在哪里。是否有一个衬垫可以实现这一目标? 最佳答案 File.open(filename).grep(/string/)这会将整个文件载入内存(slurps文件)。你应该避免文件slurpingwhendealingwithlargefiles.这意味着一次加载一行,而不是整个文件。File.foreach(filename).grep(/string/)最好自己清理,而不是让垃圾收集器在某个时候处理它。如果您的程序是长期存在的,而不仅仅是一些快速脚本,那么这一点就更为重要。使用代

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 - 什么是匹配不在行尾的字符串的正则表达式?

正则表达式/abc$/将匹配出现在行尾的abc。我该怎么做?我想匹配不在行尾的abc。此外,我将使用正则表达式来替换字符串,所以我只想捕获abc,而不是字符串后面的任何内容,所以/abc.+$/不起作用,因为它不仅会替换abc,还会替换abc之后的所有内容。正确的正则表达式是什么? 最佳答案 /abc(?!$)/(?!$)是一个negativelookahead.它将查找abc的任何匹配项,但后面没有直接跟$(行尾)测试abcddee(匹配)dddeeeabc(不匹配)adfassdfabcs(匹配)fabcddee(匹配)将它应用

ruby - 如何获取字符串中所有出现的 Ruby 正则表达式的匹配数据?

对于字符串中正则表达式的每次出现,我都需要MatchData。这与MatchAllOccurrencesofaRegex中建议的扫描方法不同,因为这只会给我一个字符串数组(我需要完整的MatchData,以获取开始和结束信息等)。input="abc12def34ghijklmno567pqrs"numbers=/\d+/numbers.matchinput##(onlythefirstmatch)input.scannumbers#["12","34","567"](allmatches,butonlythestrings)我怀疑我忽略了某些方法。有什么建议吗?

ruby - 为什么 Matz 选择在 Ruby 中默认设置可变字符串?

这是这个问题的反面:Whycan'tstringsbemutableinJavaand.NET?在Ruby中做出这个选择仅仅是因为操作(追加等)对可变字符串有效,还是有其他原因?(如果只是效率,那似乎很奇怪,因为Ruby的设计似乎并没有高度重视促进高效实现。) 最佳答案 如您所见,这符合Ruby的设计。不可变字符串比可变字符串更有效——更少的复制,因为字符串被重复使用——但让程序员的工作更加困难。将字符串视为可变的很直观——您可以将它们连接在一起。为了解决这个问题,Java默默地将两个字符串的连接(通过+)转换为StringBuff

ruby - Ruby 字符串上的扫描和匹配有什么区别

我是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"]我已经检查了

Ruby:如何计算一个字符串在另一个字符串中出现的次数?

我正在尝试计算一个字符串在另一个字符串中出现的次数。我知道你可以数出一个字母在字符串中出现的次数:string="aabbccddbb"string.count('a')=>2但是如果我搜索'aa'在这个字符串中出现了多少次,我也会得到两次。string.count('aa')=>2我不明白这个。我将值放在引号中,因此我搜索的是确切字符串出现的次数,而不仅仅是字母。 最佳答案 这里有几种方法可以计算给定子字符串在字符串中出现的次数(第一种是我的偏好)。请注意(经OP确认)子字符串'aa'在字符串'aaa'中出现两次,因此出现了五次:

ruby-on-rails - 如何使 Ruby 字符串对文件系统安全?

我有用户条目作为文件名。当然这不是一个好主意,所以我想删除除[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 - 为什么用空格分隔的两个字符串在 Ruby 中连接?

为什么这在Ruby中有效:"foo""bar"#=>"foobar"我不确定为什么要连接字符串而不是给出语法错误。我很好奇这是否是预期的行为,以及它是否是解析器负责争吵的东西(两个没有运算符的字符串被认为是一个字符串)或者语言定义本身正在指定这种行为(隐式连接)。 最佳答案 在C和C++中,stringliterals彼此相邻areconcatenated.由于这些语言影响了Ruby,我猜它是从那里继承的。它现在用Ruby记录:参见thisanswer和thispageintheRubyrepo其中指出:Adjacentstring