草庐IT

表达式

全部标签

ruby-on-rails - 如何将重音字符与正则表达式匹配?

我正在运行RubyonRails3.0.10和Ruby1.9.2。我正在使用以下正则表达式来匹配名称:NAME_REGEX=/^[\w\s'"\-_&@!?()\[\]-]*$/uvalidates:name,:presence=>true,:format=>{:with=>NAME_REGEX,:message=>"formatisinvalid"}但是,如果我尝试保存如下的一些单词:OilalàPìRùby...#Infewwords,thosewithaccentedcharacters我有一个验证错误“名称格式无效。。我如何更改上面的正则表达式以便匹配重音字符,如à、è、é、ì

Ruby:通过正则表达式过滤数组?

这对我来说是一个常见的、重复的习惯用法:使用正则表达式过滤一个数组,并返回一个子数组。我的方法看起来不太像Ruby(我来自Java)。我最终得到了很多看起来很像这样的方法。改进此代码的惯用Ruby方法是什么?defget_all_gifs(items_)output=Array.newfilter=/\.jpg$/items_.eachdo|item|nextifitem=~filteroutput 最佳答案 如果你想找到所有的动图:defget_all_gifs(files)files.select{|i|i[/\.gif$/]}

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-on-rails - PG::错误:SELECT DISTINCT,ORDER BY 表达式必须出现在选择列表中

ActionView::Template::Error(PG::Error:ERROR:forSELECTDISTINCT,ORDERBYexpressionsmustappearinselectlist我正在创建一个事件网站,我正在尝试按事件的开始时间对呈现的rsvps进行排序。有很多RSVPS,所以我将它们分组为不同的,但在过去的几天里,我在排序结果时遇到了很多困难,而没有在PG上弹出这个错误。我已经查看了之前关于该主题的一些问题,但仍然很迷茫。我怎样才能让它工作?非常感谢!@rsvps=Rsvp.where(:voter_id=>current_user.following.co

ruby - 有效的电子邮件地址正则表达式?

这个问题在这里已经有了答案:HowcanIvalidateanemailaddressusingaregularexpression?(80个答案)关闭9年前。我已经做了一些测试,但我想问问是否有人发现这个用于电子邮件验证的ruby​​正则表达式有问题:/\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\Z/i好看吗?

使用正则表达式的 Ruby 电子邮件验证

我有一大堆正在浏览的电子邮件。很多邮件都有拼写错误。我正在尝试构建一个字符串来检查有效的电子邮件。这就是我的正则表达式。defis_a_valid_email?(email)(email=~/^(([A-Za-z0-9]*\.+*_+)|([A-Za-z0-9]+\-+)|([A-Za-z0-9]+\+)|([A-Za-z0-9]+\+))*[A-Z‌​a-z0-9]+@{1}((\w+\-+)|(\w+\.))*\w{1,63}\.[a-zA-Z]{2,4}$/i)end如果电子邮件为下划线且只有一个句点,则通过。我有很多电子邮件的名称本身有不止一个句点。我如何在正则表达式中检查它。

ruby - 从 Ruby 中的字符串创建不区分大小写的正则表达式

假设我有一个任意的字符串`Aman+aplan*acanal:Panama!`我想对大小写不同的字符串进行正则表达式搜索。也就是说,这个正则表达式应该匹配字符串`aman+APLAN*acanal:PaNaMa!`我认为最好的方法是在Ruby正则表达式中对每个具有特殊含义的字符进行反斜杠转义,然后使用该字符串执行Regexp.new和Regexp::IGNORECASE作为参数。是对的吗?是否存在用于将任意字符串转换为文字正则表达式的经过验证的正则表达式?顺便说一下,我最终想使用这个正则表达式来做一个任意的不区分大小写的MongoDB查询。因此,如果我有其他方法可以做到这一点,请告诉我

ruby - 如何在 ruby​​ 中针对正则表达式测试整个字符串?

如果整个字符串匹配(而不是子字符串),我如何针对正则表达式设置字符串以返回true?例如:test(\ee\,"street")#=>returnsfalsetest(\ee\,"ee")#=>returnstrue!谢谢。 最佳答案 您可以用\A匹配字符串的开头,用\Z匹配结尾。在ruby​​中,^和$也分别匹配行的开头和结尾:>>"a\na"=~/^a$/=>0>>"a\na"=~/\Aa\Z/=>nil>>"a\na"=~/\Aa\na\Z/=>0 关于ruby-如何在ruby​​

Ruby 全局匹配正则表达式?

在其他语言中,在RegExp中,您可以使用/.../g进行全局匹配。然而,在Ruby中:"hellohello".match/(hello)/只捕获一个问候语。如何捕获所有的hello? 最佳答案 您可以使用扫描方法。scan方法将为您提供所有匹配项的数组,或者如果您将其传递给一个block,则将每个匹配项传递给该block。"hello1hello2".scan(/(hello\d+)/)#=>[["hello1"],["hello2"]]"hello1hello2".scan(/(hello\d+)/).eachdo|m|put