我有以下数组:a=["CH3","CH2"]我想使用正则表达式将其拆分为两个大写字母以显示:a=["C","H3","C","H2"]怎么做你这样做吗?到目前为止我已经尝试过:a.each{|array|x=array.scan(/[A-Z]*/)putsa}returns:CHCH提前致谢! 最佳答案 你可以试试这个:s.scan(/[A-Z][^A-Z]*/) 关于ruby-如何拆分两个大写字母?,我们在StackOverflow上找到一个类似的问题: h
我正在使用HTTParty和Hashie获取最新的推文。tweet=Hashie::Mash.newHTTParty.get(http://twitter.com/statuses/user_timeline/ethnt.json).firstputstweet.text我希望能够将每个链接(http://*.*)和用户名(@.)变成链接。这两个的正则表达式是什么,我将如何实现它? 最佳答案 deflink_urls_and_userss#regexpsurl=/(|^)http:\/\/([^\s]*\.[^\s]*)(|$)/u
Facebook刚刚重新推出了具有自动语法修复功能的评论。Whatdoesthegrammarfilterdo?Addspunctuation(e.g.periodsattheendofsentences)TrimsextrawhitespaceAutocaseswords(e.g.capitalizethefirstwordofasentence)Expandsslangwords(e.g.plzbecomesplease)Addsaspaceafterpunctuation(e.g.Hi,CatwouldbecomeHi,Cat)Fixcommongrammarmistakes(e
我在某些代码中遇到了三元组,但我无法理解条件:str.split(/',\s*'/).mapdo|match|match[0]==?,?match:"somestring"end.join我确实理解我是在某些点上拆分字符串并将总结果转换为数组,然后依次处理数组的每个元素。除此之外,我不知道发生了什么。 最佳答案 一种(稍微)不那么令人困惑的写法是:str.split(/',\s*'/).mapdo|match|ifmatch[0]==?,matchelse"somestring"endend.join我认为多行三元语句很糟糕,尤其是
我搜索了一下,但我一定是使用了错误的术语-ruby是否有办法grep查找字符串/正则表达式并返回周围的5行(上方和下方)?我知道我可以调用"grep-C5..."或什至编写我自己的方法,但这似乎是ruby应该有的东西,我只是没有使用正确的搜索词。 最佳答案 您可以使用正则表达式来完成。这是我们要搜索的字符串:s=%{ThefirstlineThesecondlineThethirdlineThefourthlineThefifthlineThesixthlineTheseventhlineTheeightlineThenin
我正在使用Ruby的正则表达式引擎。我需要编写一个执行此操作的正则表达式WIKI_WORD=/\b([a-z][\w_]+\.)?[A-Z][a-z]+[A-Z]\w*\b/但也可以使用除英语以外的其他欧洲语言。我认为字符范围[a-z]不会涵盖德语等的小写字母。 最佳答案 WIKI_WORD=/\b(\p{Ll}\w+\.)?\p{Lu}\p{Ll}+\p{Lu}\w*\b/u应该在Ruby1.9中工作。\p{Lu}和\p{Ll}是大写和小写Unicode字母的简写。(\w已经包含下划线)另见thisanswer-您可能需要在UTF
在ruby1.9.3中,正则表达式引擎不会将nbsp的(\u00A0)视为空格(\s)。这对我来说常常是一个无赖。所以我的问题是,这会在2.0中改变吗?如果没有,是否有任何方法可以修补解决方案? 最佳答案 使用Unicode属性(你需要声明一个匹配的源代码编码才能工作):#encoding=utf-8ifsubject~=/\p{Z}/#subjectcontainswhitespaceorotherseparators或使用POSIX字符类:ifsubject~=/[[:space:]]/根据thedocs,\s现在和将来只会
我想匹配格式为A0123456、E0123456或IN:A0123456Q等格式的字符串,我原来做的是这个regex^(IN:)?[AE][0-9]{7}Q?$但它匹配IN:E012346而末尾没有Q。所以我创建了这个正则表达式(^IN:[AE][0-9]{7}Q$)|(^[AE][0-9]{7}$)有什么方法可以缩短这个正则表达式,使其同时需要IN:和Q如果它们存在,但如果两者都不存在则不需要?编辑:正则表达式将在Ruby中使用。编辑2:我更改了正则表达式以反射(reflect)我匹配了错误的字符串,因为它仍然匹配IN:A0123456。编辑3:下面的两个答案都是有效的,但由于我使用
我有一个很长的文本,我想用空格替换其中的点,但只能在文本的中间。例如:Domain:...................google.com我需要这样:Domain:google.com我发现了这个用单个空格替换点的正则表达式:str.gsub!(/(?但这还不够,因为它会产生:Domain:google.com我需要保留与点一样多的空格。你会如何解决? 最佳答案 你快到了,你的正则表达式没问题,只需使用String#gsub的block版本计算替换匹配的长度:▶str='Domain:...................goo
是否可以在gsub表达式中使用否定匹配?我想替换以hello开头的字符串except以helloPeter开头的字符串>my-string.gsub(/^hello@/i,'')我应该用什么代替@? 最佳答案 听起来你想要一个负面的前瞻:>>"hellofoo".gsub(/hello(?!peter)/,'lala')#=>"lalafoo">>"hellopeter".gsub(/hello(?!peter)/,'lala')#=>"hellopeter" 关于ruby-在正则表达式