草庐IT

Javascript if 表达式求值

全部标签

ruby - 与原子分组混淆 - 它与 Ruby 正则表达式中的分组有何不同?

我已经浏览了AtomicGrouping的文档和rubyinfo我想到了一些问题:为什么叫“原子分组”?它有什么“原子性”而一般分组没有?原子分组与一般分组有何不同?为什么原子组被称为非捕获组?我尝试了下面的代码来理解,但对输出以及它们在同一字符串上的工作方式有何不同感到困惑?irb(main):001:0>/a(?>bc|b)c/=~"abbcdabcc"=>5irb(main):004:0>$~=>#irb(main):005:0>/a(bc|b)c/=~"abcdabcc"=>0irb(main):006:0>$~=># 最佳答案

Ruby: bool 正则表达式方法的正确语法是什么?

检查字符串中的模式并在正则表达式匹配时返回true或false的方法的正确语法是什么?基本思路:defhas_regex?(string)pattern=/something/ireturnstring=~patternend用例:ifhas_regex?("something")#woohooelse#nothingfound:panic!end 最佳答案 在你说的问题中:...methodthatchecksastringforapattern,andreturnstrueorfalseiftheregexmatches作为jo

ruby - 一个在 Ruby 上表现非常糟糕的简单正则表达式

我有一个简单的Ruby正则表达式,需要很长时间才能计算:"fußball"*20=~/^([\S\s]{1000})/i如果我删除/i标志,它会工作得非常快。为什么运行这么慢?(我没有等到执行完毕)我知道这个正则表达式可能没有意义,但我想知道幕后是什么。错误报告:https://bugs.ruby-lang.org/issues/14418 最佳答案 默认.不匹配换行符。[\s\S]是解决该问题的方法。在Ruby中,您可以使用/m标志使点匹配所有字符。它在文档中RubyMetacharactersandEscapes[\S\s]由于

ruby-on-rails - Ruby 表达式求值 : whitespace matters?

假设现在是1月19日。如果您今天看这个问题,这并不难。Date.today=>Thu,19Jan2012#asexpectedDate.today+1=>Fri,20Jan2012#asexpectedDate.today+1=>Fri,20Jan2012#asexpectedDate.today+1=>Thu,19Jan2012#?!我在这里错过了什么? 最佳答案 区别在于:Date.today+1是两个数值相加Date.today+1是对方法today的调用,参数sg(日历改革日)值为+1检查这一点的最佳方法是猴子修补包含调试输

ruby - Ruby 中的惰性求值

我有一个Ruby的情况,其中可能需要创建一个对象,但不确定。由于对象的创建可能代价高昂,我不太急于创建它。我认为这是延迟加载的明显案例。如何定义一个仅在有人向其发送消息时才创建的对象?该对象将在block中创建。有没有一种方法可以在Ruby中进行简单的延迟加载/初始化?这些东西是否得到某些gem的支持,它们为对象的延迟初始化的各种情况提供了不同的解决方案?感谢您的建议! 最佳答案 有两种方法。第一个是让调用者处理惰性对象创建。这是最简单的解决方案,也是Ruby代码中非常常见的模式。classExpensiveObjectdefini

ruby - 如何使用正则表达式匹配字符或不匹配

我正在尝试获取一组可能有或没有分隔符的数字,并以标准格式返回它们。以SSN为例:ex1="Anexample123-45-6789"ex2="123.45.6789somemorethings"ex3="123456789thankyouRubymayIhaveanother"都应该进入返回“123-45-6789”的方法基本上,除数字或字母外的任何内容(包括任何内容)都应返回XXX-XX-XXXX格式的SSN。stumping的部分是正则表达式识别不能有任何东西的方式。到目前为止,我在识别我的ssn方面有什么:defformat_ssns(string)string.scan(/\d

Ruby 正则表达式 - gsub 仅捕获组

我不太确定我了解非捕获组的工作原理。我正在寻找一个正则表达式来产生这个结果:5.214。我认为下面的正则表达式可以工作,但它正在替换所有内容,包括非捕获组。如何编写一个正则表达式来仅替换捕获组?"5,214".gsub(/(?:\d)(,)(?:\d)/,'.')#=>".14"我想要的结果:"5,214".gsub(some_regex)#=>"5.214 最佳答案 非捕获组仍然消耗匹配使用"5,214".gsub(/(\d+)(,)(\d+)/,'\1.\3')或者"5,214".gsub(/(?

ruby-on-rails - ruby 正则表达式 - 如何匹配所有内容直到字符 -

给定一个字符串如下:randomstring1-randomstring2-3df83eeff2我如何使用ruby​​正则表达式或其他一些ruby​​/rails友好的方法来查找第一个破折号之前的所有内容-在上面的例子中是:randomstring1谢谢 最佳答案 你可以使用这个模式:^[^\-]* 关于ruby-on-rails-ruby正则表达式-如何匹配所有内容直到字符-,我们在StackOverflow上找到一个类似的问题: https://stack

ruby - Ruby 1.9 中的大小写表达式不同?

这是一本书中的示例代码。我假设它适用于Ruby1.8。birthyear=1986generation=casebirthyearwhen1946...1963:"Babyboomer"when1964...1976:"GenerationX"when1977...2012:"newgeneration"elsenilendputsgeneration我在Ruby1.9上运行它,得到了这个错误信息:Untitled2.rb:12:syntaxerror,unexpected':',expectingkeyword_thenor','or';'or'\n'when1946...1963:

ruby - 在文本文件中查找与正则表达式匹配的行

谁能解释一下我如何在Ruby中使用正则表达式来只返回字符串的匹配项。例如,如果代码读取一个包含一系列名称的.txt文件:JohnSmithJamesJonesDavidBrownTomDavidsonetcetc..并且要匹配的单词被输入为“ohn”,然后它只会返回“JohnSmith”,但不会返回任何其他名字。 最佳答案 注意:在现代Rubies中,不要使用File.each_line,而是使用IO.foreach。例如:[1]pry(main)>IO.foreach('./.bashrc')do|l|[1]pry(main)*p