草庐IT

seo - Robots.txt 被正则表达式禁止

全部标签

ruby - 用于匹配一组大括号之间的所有单词的正则表达式

对于我认识的大多数正则表达式专家来说,这是一个简单的问题,但我正在尝试返回句子中某些大括号之间单词的所有匹配项;但是Ruby只返回一个匹配项,我不知道为什么。我正在使用这个例句:sentence=hello{name}is{thing}使用此正则表达式尝试返回“{name}”和“{thing}”:sentence[/\{(.*?)\}/]但是,Ruby只返回“{name}”。谁能解释为什么这两个词不匹配? 最佳答案 你很接近,但使用了错误的方法:sentence="hello{name}is{thing}"sentence.scan

正则表达式匹配以感叹号开头的整行

我正在尝试匹配从开始的整行文本!用正则表达式。我做了这样的事情:/(!\w+\s+\S+)/ig非常接近,但只有2个单词。我想将单词匹配到新行。我还看到句子中间有扰流板的问题。实例:http://www.rubular.com/r/MXmholsDwE 最佳答案 你只需要^!.*参见updatedregexdemo^匹配一行的开头(在Ruby中),!将匹配文字!和。*将匹配换行符以外的零个或多个字符(如果您使用的是Ruby,我假设您使用的是rubular网站)。如果您使用的不是Ruby的正则表达式,例如JS、PHP或.NET,您需要

ruby - 正则表达式:如果字符串包含空格则不匹配

我似乎无法找出仅当不包含空格时匹配字符串的正则表达式模式。例如"thishaswhitespace".match(/some_pattern/)应该返回nil但是"nowhitespace".match(/some_pattern/)应返回包含整个字符串的MatchData。任何人都可以针对上述问题提出解决方案吗? 最佳答案 在Ruby中我认为它会是/^\S*$/意思是“开始,匹配任意数量的非空白字符,结束” 关于ruby-正则表达式:如果字符串包含空格则不匹配,我们在StackOver

ruby-on-rails - 基于正则表达式的 Rails 自定义验证?

我在我的routes.rb中使用了以下正则表达式/type-in​​-something-here#A-Z,a-z,0-9,_inthemiddlebutneverstartingorendingina_#Atleast5,nomorethan500characters在route,这适用于:match':uuid'=>'room#show',:constraints=>{:uuid=>/[A-Za-z\d]([-\w]{,498}[A-Za-z\d])?/}我还想将此作为验证,以免创建无效记录。所以我在room.rb中添加了以下内容:validates_format_of:uuid,

ruby - 从字符串创建正则表达式

有没有办法从字符串func:[sync]displayPTS创建正则表达式/func:\[sync\]displayPTS/?这个问题背后的故事是我有多个字符串模式可以在文本文件中搜索,我不想一次又一次地写同样的东西。File.open($f).readlines.reject{|l|notl=~/"#{string1}"/}File.open($f).readlines.reject{|l|notl=~/"#{string2}"/}相反,我想要一个函数来完成这项工作:deffilterstring#buildtheregpatternfromstringFile.open($f).r

ruby - Ruby 中有正则表达式删除吗?

我所有使用正则表达式删除的字符串都使用gsub,有更短的方法吗?string.gsub(/\A.*\//,'') 最佳答案 一种方法是添加您自己的简短方法:classStringdefdel(regexp)gsub(regexp,'')enddefdel!(regexp)gsub!(regexp,'')endend通常此代码将放在lib/目录中,例如lib/string-extensions.rb请注意,有些程序员真的不喜欢这个,因为它是猴子补丁。我个人喜欢在项目中使用它,因为它使代码更容易理解-一旦我有了“del”方法,我可以很快

ruby-on-rails - 如何在 ruby​​ 中使用 utf8 的正则表达式

在RoR中,如何使用utf8代码验证中文或日文单词用于发布表单。在GBK编码中,它使用[\u4e00-\u9fa5]+来验证中文单词。在Php中,它使用/^[\x{4e00}-\x{9fa5}]+$/u用于utf-8页面。 最佳答案 Ruby1.8对UTF-8字符串的支持很差。您需要在正则表达式中单独编写字节,而不是完整的代码:>>"acentuação".scan(/\xC3\xA7/)=>["ç"]要匹配您指定的范围,表达式会变得有点复杂:/([\x4E-\x9E][\x00-\xFF])|(\x9F[\x00-\xA5])/#

ruby-on-rails - 知道@vendor.name 后如何使 Ruby on Rails 中的 URL 对 SEO 友好?

我的应用程序在RoR中我有一个名为showsummary的操作/View,其中ID已传递到URL,并且Controller使用它来实例化@vendor,其中@vendor.name是公司的名称。我希望URL是showsummary/1/而不是在URL中包含/vendor-name。我该怎么做? 最佳答案 所有这些解决方案都使用find_by_name,这肯定需要在该列上有一个索引并且要求它们是唯一的。我们使用的一个更好的解决方案是在供应商名称前加上其ID,但牺牲了一点美观。这意味着您不必在名称列上有索引和/或要求唯一性。供应商.rb

ruby - 如何在 Ruby 中获取字符串匹配正则表达式的特定部分?

我有一个字符串Unnecessary:12357927251data并且我需要选择冒号和数字之后的所有数据。我将使用Regexp来完成。string.scan(/:\d+.+$/)这会给我:12357927251data,但是我可以只选择需要的信息.+(data)吗? 最佳答案 正则表达式中括号中的任何内容都将被捕获为一个组,您可以在$1、$2等中或使用[]在匹配对象上:string.match(/:\d+(.+)$/)[1]如果将扫描与捕获组一起使用,您将获得一组数组:"Unnecessary:123data\nUnnecessa

Ruby 1.9 正则表达式作为哈希键

我正在使用ruby1.9.2p136(2010-12-25)[i386-mingw32].它没有按预期工作(编辑:事实证明它不应该像我预期的那样工作):irb(main):004:0>myhash={/(\d+)/=>"hello"}=>{/(\d+)/=>"Hello"}irb(main):005:0>myhash[2222]=>nilirb(main):006:0>myhash["2222"]=>nil在Rubular在ruby​​1.8.7上regex有效。我错过了什么? 最佳答案 你在寻找这种行为吗?myhash=Hash.