require 'date'
def pull_dates(str)
str.split(/[\/.]/).map { |s| Date.strptime(s, '%Y-%m-%d') rescue nil }.compact
end
pull_dates "log/archive/2016-12-21.zip"
#=> [#<Date: 2016-12-21 ((2457744j,0s,0n),+0s,2299161j)>]
pull_dates "log/2016-12-21/archive.zip"
#=> [#<Date: 2016-12-21 ((2457744j,0s,0n),+0s,2299161j)>]
pull_dates "log/2016-12-21/2016-12-22.zip"
#=> [#<Date: 2016-12-21 ((2457744j,0s,0n),+0s,2299161j)>,
# #<Date: 2016-12-22 ((2457745j,0s,0n),+0s,2299161j)>]
pull_dates "log/2016-12-21/2016-12-32.zip"
#=> [#<Date: 2016-12-21 ((2457744j,0s,0n),+0s,2299161j)>]
pull_dates "log/archive/2016A-12-21.zip"
#=> []
pull_dates "log/archive/2016/12/21.zip"
#=> []
Если вы хотите строку с датой, а не объект даты, измените метод следующим образом.
def pull_dates(str)
str.split(/[\/.]/).
each_with_object([]) { |s,a|
a << s if (Date.strptime(s, '%Y-%m-%d') rescue nil)}
end
pull_dates "log/archive/2016-12-21.zip"
#=> ["2016-12-21"]
, если точка должна всегда приходит только в последнем, то вы можете попробовать это '«Журнал/архив/2016-12-21.zip». split (/[\/.]/)[- 2] ' –
Да, точка всегда будет навсегда – Thorin
Даже это не самое простое решение, я всегда буду с регулярным выражением (\/(\ d {4} - \ d {2} - \ d {2}) \. zip). Причина в том, что вы можете протестировать его с совпадением, и вы обязательно обнаружите, изменилась ли структура строки. Я не знаю, как ведет себя номер 2, но я бы не пошел с номером 3, так как он может оценивать строки без дат вообще ... –