re = /^(?:(?=.*%)(?![A-Z]{1,5}[0-9])(?:%?[A-Z]){0,6}(?:(?:%?[A-Z0-9]){1,2})?(?:(?:%?[A-Z]){1,3})?%?)$|^(?:[A-Z]{6}(?:[A-Z0-9]{2})(?:[A-Z]{3})?)$|^$/mi
str = '
-> correct: Empty string
AaBB%
ABCDE%
AAAAAA33
AABBCCXX
AABBCC44XXX
-> correct
AA%33
-> correct ( % avoid the max number)
%AAB%BCC4%4X%XX%
-> correct (because % should be ignored in length, length of alpha and alphanumeric is respected here)
A%3
AA%33%
%AA33%
%AA3%
%3
-> correct according comments
----------------------------------------------
AABBCCXXX
AABBCC44XX
-> wrong
AABb
AAbbCC
ABCDEF
-> wrong (need exactly 6 alpha + 2 alphanumeric when there is no %)
AAABB3%
-> wrong (need exactly 6 alpha before numeric)
AABBCC44XXXE
-> wrong (length of alpha not respected)
%AABBCC44XXXE
-> wrong (length of alpha not respected)'
# Print the match result
str.scan(re) do |match|
puts match.to_s
end
Please keep in mind that these code samples are automatically generated and are not guaranteed to work. If you find any syntax errors, feel free to submit a bug report. For a full regex reference for Ruby, please visit: http://ruby-doc.org/core-2.2.0/Regexp.html