草庐IT

php - 用 PHP 匹配卡片

全部标签

ruby - 在 Sinatra 中,你如何制作一个 "before"过滤器来匹配除某些路由之外的所有路由

我有一个RubySinatra应用程序,我有一些代码需要在除少数异常(exception)情况外的所有路由上执行。我该怎么做?如果我想在选定的路由(白名单样式)上执行代码,我会这样做:['/join',"/join/*","/payment/*"].eachdo|path|beforepathdo#somecodeendend我该如何反其道而行之(黑名单样式)?我想匹配除'/join'、'/join/*'和'/payment/*'之外的所有路由 最佳答案 负面前瞻:before/^(?!\/(join|payment))/do#..

ruby - 如何使用一行正则表达式来获取匹配的内容

我是ruby​​的新手,我想知道我是否可以只用一行来完成这项工作。以本站的“搜索”为例。当用户键入[ruby]regex时,我可以使用以下代码获取标签和关键字'[ruby]regex'=~/\[(.*?)\](.*)/tag,keyword=$1,$2我们可以只写一行吗?更新非常感谢!我可以让它更难更有趣吗,输入可能包含多个标签,例如:[ruby][regex][rails]oneline是否可以使用一行代码获取标签数组和关键字?我试过了,但失败了。 最佳答案 您需要Regexp#match方法。如果您编写/\[(.*?)\](.*

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 匹配第一次出现的字符串以进行 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 - 从数组中删除匹配元素的第一个实例

假设我有数组[1,2,3,1,2,3]并且我想从给出[1,3,1,2,3]的数组。什么是最简单的方法? 最佳答案 li.delete_at(li.index(n)||li.length)li[li.length]超出范围,所以||li.length处理n不在列表中的情况。irb(main):001:0>li=[1,2,3,1,2,3]=>[1,2,3,1,2,3]irb(main):002:0>li.delete_at(li.index(2)||li.length)=>2irb(main):003:0>li.delete_at(li

ruby-on-rails - 是否有与 PHP 的 isset() 等效的 Rails?

基本上只是检查以确保设置了url参数。我如何在PHP中做到这一点:if(isset($_POST['foo'])&&isset($_POST['bar'])){}这是RoR中isset()的粗略/最佳等价物吗?if(!params['foo'].nil?&&!params['bar'].nil?)end 最佳答案 更接近的匹配可能是#present?#returnstrueifnotnilandnotblankparams['foo'].present?还有一些其他的方法#returnstrueifnilparams['foo'].

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 - 将一个字符串与多个模式匹配

如何使用ruby​​中的正则表达式将字符串与多个模式进行匹配。我正在尝试查看一个字符串是否包含在前缀数组中,这是行不通的,但我认为它至少证明了我正在尝试做的事情。#example:#prefixes.include?("Mrs.KirstenHess")prefixes.include?(name)#shouldreturntrue/falseprefixes=[/Ms\.?/i,/Miss/i,/Mrs\.?/i,/Mr\.?/i,/Master/i,/Rev\.?/i,/Reverend/i,/Fr\.?/i,/Father/i,/Dr\.?/i,/Doctor/i,/Atty\.

Ruby 全局匹配正则表达式?

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