我们可以写get'/foo'do...end和post'/foo'do...end这很好。但是我可以在一个路由中组合多个HTTP动词吗? 最佳答案 这可以通过multi-routeextension实现这是sinatra-contrib的一部分:require'sinatra'require"sinatra/multi_route"route:get,:post,'/foo'do#"GET"or"POST"prequest.env["REQUEST_METHOD"]end#Orformodule-styleapplicationsc
我有一个字符串:s="123--abc,123--abc,123--abc"我尝试使用Ruby1.9的新功能“命名组”来获取所有命名组信息:/(?\d*)--(?\s*)/是否有像Python的findall那样返回matchdata集合的API?在这种情况下,我需要返回两个匹配项,因为123和abc重复两次。每个匹配数据都包含每个命名捕获信息的详细信息,因此我可以使用m['number']获取匹配值。 最佳答案 命名捕获只适用于一个匹配结果。Ruby的findall类比是String#scan.您可以使用scan结果作为数组,或将
有一个包含2个元素的数组test=["iamaboy","iamagirl"]我想测试是否在数组元素中找到了一个字符串,比如:test.include("boy")==>truetest.include("frog")==>false我可以那样做吗? 最佳答案 使用正则表达式。test=["iamaboy","iamagirl"]test.find{|e|/boy/=~e}#=>"iamaboy"test.find{|e|/frog/=~e}#=>nil 关于ruby-匹配数组中的模式,
我有一张交易表,需要查找日期与今天匹配的记录。在Rails控制台中,我需要匹配的日期字段如下所示。我已经分配了一条记录进行测试。ruby-1.9.2-p0>deal.start=>Tue,10May201100:00:00UTC+00:00如果我像这样尝试查找与开始日期匹配的任何记录,我会得到nilruby-1.9.2-p0>Deal.find_by_start(Date.today)=>nil然后我想我可以通过将Date.today转换为日期时间来匹配。ruby-1.9.2-p0>Date.today.to_datetime=>Tue,10May201100:00:00+0000ru
我有一个RubySinatra应用程序,我有一些代码需要在除少数异常(exception)情况外的所有路由上执行。我该怎么做?如果我想在选定的路由(白名单样式)上执行代码,我会这样做:['/join',"/join/*","/payment/*"].eachdo|path|beforepathdo#somecodeendend我该如何反其道而行之(黑名单样式)?我想匹配除'/join'、'/join/*'和'/payment/*'之外的所有路由 最佳答案 负面前瞻:before/^(?!\/(join|payment))/do#..
我是ruby的新手,我想知道我是否可以只用一行来完成这项工作。以本站的“搜索”为例。当用户键入[ruby]regex时,我可以使用以下代码获取标签和关键字'[ruby]regex'=~/\[(.*?)\](.*)/tag,keyword=$1,$2我们可以只写一行吗?更新非常感谢!我可以让它更难更有趣吗,输入可能包含多个标签,例如:[ruby][regex][rails]oneline是否可以使用一行代码获取标签数组和关键字?我试过了,但失败了。 最佳答案 您需要Regexp#match方法。如果您编写/\[(.*?)\](.*
我正在寻找一种内置的Ruby方法,它具有与index相同的功能,但使用二进制搜索算法,因此需要一个预先排序的数组。我知道我可以编写自己的实现,但根据“Ruby#indexMethodVSBinarySearch”,索引使用的内置简单迭代搜索比二进制搜索的纯Ruby版本更快,因为内置方法是用C写的。Ruby是否提供任何进行二分查找的内置方法? 最佳答案 引入了Ruby2.0Array#bsearch和Range#bsearch.对于Ruby1.9,您应该查看bsearch和binary_searchgem。另一种可能性是使用与数组不同
非常迷茫,因为我没有对我的搜索进行任何更改,该搜索一直有效,但不知何故我休息了。作为Rails的新手,错误输出没有给我足够的细节来进行调试。下面的相关代码-询问您是否还想查看其他内容。home.html.slim(带有搜索表单的摘录)=form_tagsearch_venues_path,method::get,id:'search'do|f|.search-fields.span16p=text_field_tag:q,'',placeholder:"Searchforcoffee,hotel,etc",class:'span7search-field'p=text_field_ta
我正在运行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我有一个验证错误“名称格式无效。。我如何更改上面的正则表达式以便匹配重音字符,如à、è、é、ì
我有一个字符串让我们说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