| 秒 | 分 | 时 | 日 | 月 | 周 | 年 | |
|---|---|---|---|---|---|---|---|
| 可用的值 | 0~59 | 0~59 | 0~23 | 1~31 | 1~12(JAN-DEC) | 1~7(SUN-SAT) | 1970~2099 |
| 可用的通配符 | , - * / | , - * / | , - * / | , - * / ? L W | , - * / | , - * / ? L # | , - * / |
| 是否必填 | 是 | 是 | 是 | 是 | 是 | 是 | 否 |
秒(Seconds):可用数字"0~59"表示。
分(Minutes):可用数字"0~59"表示。
时(Hours):可用数字"0~23"表示。
日(Day-of-Month):可用数字"1~31"表示,但要注意具体月份的天数。
月(Month):可用数字"1~12"或单词缩写"JAN,FEB,MAR,APR,MAY,JUN,JUL,AUG,SEP,OCT,NOV,DEC"表示。
周(Day-of-Week):可用数字"1~7"或单词缩写"SUN,MON,TUE,WED,THU,FRI,SAT"表示(用数字表示时注意"1"表示周日)。
年(Year):可用数字"1970~2099"表示,此项非必填。
| 通配符 | 适用域 | 含义 | 实例 |
|---|---|---|---|
| * | 所有 | 表示所有值 | 在分的位置上设置"*",表示每分钟都会触发。 |
| ? | 日和周 (日和周不能同时为"?") |
不需要关心当前位置的值,表示每月的某一天,或每周的某一天。 | "0 0 0 1 * ?"表示每月1号触发,但不关心是周几,所以周的位置设置为"?"; "0 0 0 ? * 2"表示每周一触发,但不关心是多少号,所以日的位置设置为"?"。 |
| - | 所有 | 表示区间 | 在时的位置上设置"10-12",表示"10点、11点、12点"触发。 |
| , | 所有 | 表示指定多个值 | 在周的位置上设置"MON,WED,FRI",表示"周一、周三、周五"触发。 |
| / | 所有 | 用于递增触发 | 在秒的位置上设置"5/15",表示从5秒开始,每隔15秒触发一次(5,20,35,50)。 在月的位置上设置"1/7",表示每月1号开始,每隔7天触发一次。 |
| L(Last) | 日和周 | L前不加数字时表示每月或每周的最后一天; L前加数字时表示每月的最后一个周几,XL表示每月的最后一个周(X-1)。 |
"0 0 0 L * ?"表示每月的最后一天触发; "0 0 0 ? * L"表示每周的最后一天触发,相当于"0 0 0 ? * 7"或"0 0 0 ? * STA"; "0 0 0 ? * 1L"表示每月的最后一个周日触发; "0 0 0 ? * 7L"表示每月的最后一个周六触发。 |
| W(Work) | 日 | 表示离指定日期最近的工作日(周一至周五,忽略节假日)("W"前的数字表示多少号)。 | 在日的位置上设置"15W",表示离15号的最近的工作日触发(若15号为周六,则14号触发;若15号为周日,则16号触发;若15号为工作日,则当天触发); 在日的位置上设置"1W",表示当月1号往后最近的工作日触发。(若1号为周六,则3号触发); "L"和"W"可组合使用。如果在日字段上设置"LW",则表示在本月的最后一个工作日触发。 |
| # | 周 | N#M表示每月的第M个周(N-1) | "0 0 0 ? 5 1#2"表示母亲节(每年5月的第二个周日); "0 0 0 ? 6 1#3"表示父亲节(每年6月的第三个周日)。 |
在我的应用程序中,我需要能够找到所有数字子字符串,然后扫描每个子字符串,找到第一个匹配范围(例如5到15之间)的子字符串,并将该实例替换为另一个字符串“X”。我的测试字符串s="1foo100bar10gee1"我的初始模式是1个或多个数字的任何字符串,例如,re=Regexp.new(/\d+/)matches=s.scan(re)给出["1","100","10","1"]如果我想用“X”替换第N个匹配项,并且只替换第N个匹配项,我该怎么做?例如,如果我想替换第三个匹配项“10”(匹配项[2]),我不能只说s[matches[2]]="X"因为它做了两次替换“1fooX0barXg
@raw_array[i]=~/[\W]/非常简单的正则表达式。当我用一些非拉丁字母(具体来说是俄语)尝试时,条件是错误的。我能用它做什么? 最佳答案 @raw_array[i]=~/[\p{L}]/使用西里尔字符进行测试。引用:http://www.regular-expressions.info/unicode.html#prop 关于ruby-正则表达式将非英文字母匹配为非单词字符,我们在StackOverflow上找到一个类似的问题: https://
我需要一个非常简单的字符串验证器来显示第一个符号与所需格式不对应的位置。我想使用正则表达式,但在这种情况下,我必须找到与表达式相对应的字符串停止的位置,但我找不到可以做到这一点的方法。(这一定是一种相当简单的方法……也许没有?)例如,如果我有正则表达式:/^Q+E+R+$/带字符串:"QQQQEEE2ER"期望的结果应该是7 最佳答案 一个想法:你可以做的是标记你的模式并用可选的嵌套捕获组编写它:^(Q+(E+(R+($)?)?)?)?然后你只需要计算你获得的捕获组的数量就可以知道正则表达式引擎在模式中停止的位置,你可以确定匹配结束
我想从then子句中访问case语句表达式,即food="cheese"casefoodwhen"dip"then"carrotsticks"when"cheese"then"#{expr}crackers"else"mayo"end在这种情况下,expr是食物的当前值(value)。在这种情况下,我知道,我可以简单地访问变量food,但是在某些情况下,该值可能无法再访问(array.shift等)。除了将expr移出到局部变量然后访问它之外,是否有直接访问caseexpr值的方法?罗亚附注我知道这个具体示例很简单,只是一个示例场景。 最佳答案
这是一个例子:s="abcd+subtext@example.com"s.match(/+[^@]*/)Result=>"+subtext"问题是,我不想在其中包含“+”。我希望结果是“潜台词”,没有+ 最佳答案 您可以在正则表达式中使用括号来创建匹配组:s="abcd+subtext@example.com"s=~/\+([^@]*)/&&$1=>"subtext" 关于ruby-正则表达式-排除一个字符,我们在StackOverflow上找到一个类似的问题:
我们有一个字符串:“”这个正则表达式://i如何从当前字符串中获取所有匹配项? 最佳答案 "".scan(//)参见scan在ruby-docs上 关于ruby-如何遍历Ruby中所有正则表达式匹配的字符串?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6857852/
我正在尝试通过正则表达式拆分参数列表。这是一个带有我的参数列表的字符串:"a=b,c=3,d=[1,3,5,7],e,f=g"我想要的是:["a=b","c=3","d=[1,3,5,7]","e","f=g"]我试过先行,但Ruby不允许使用动态范围后行,所以这行不通:/(?如何让正则表达式忽略方括号中的所有内容? 最佳答案 也许这样的东西对你有用:str.scan(/(?:\[.*?\]|[^,])+/)编辑再三考虑。简单的非贪婪匹配器在某些嵌套括号的情况下会失败。 关于Ruby正则
我想找到给定字符串中的所有匹配项,包括重叠匹配项。我怎样才能实现它?#Example"a-b-c-d".???(/\w-\w/)#=>["a-b","b-c","c-d"]expected#Solutionwithoutoverlappedresults"a-b-c-d".scan(/\w-\w/)#=>["a-b","c-d"],but"b-c"ismissing 最佳答案 在积极的前瞻中使用捕获:"a-b-c-d".scan(/(?=(\w-\w))/).flatten#=>["a-b","b-c","c-d"]参见Rubyde
我想为名字验证编写一个正则表达式。正则表达式应包括所有字母(拉丁/法语/德语字符等)。但是我想从中排除数字并允许-。所以基本上它是\w(减)数(加)-。请帮忙。 最佳答案 ^[\p{L}-]+$\p{L}匹配anykindofletterfromanylanguage. 关于ruby-on-rails-rails中的正则表达式匹配[\w]和"-"但不匹配数字,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c
这就是我做的a="%span.rockets#diamonds.ribbons.forever"a=a.match(/(^\%\w+)([\.|\#]\w+)+/)putsa.inspect这是我得到的#这就是我想要的#帮助?我尝试过但失败了:( 最佳答案 通常,您不能获得任意数量的捕获组,但如果您使用扫描,您可以为您想要捕获的每个标记获得一个匹配:a="%span.rockets#diamonds.ribbons.forever"a=a.scan(/^%\w+|\G[.|#]\w+/)putsa.inspect["%span","