re = /^.*SEC_LOGIN-\d-LOGIN_\w+: Login (?P<Cisco_SEC_LOGIN_Result>[^\s]+) \[user: (?P<Cisco_SEC_LOGIN_User>[^\s]*)\] \[Source: (?P<Cisco_SEC_LOGIN_SrcIP>[^\]]+)\] .+/
str = 'Nov 24 17:21:03 192.168.77.254/192.168.77.254 132162: Nov 24 2016 17:21:02: %SEC_LOGIN-5-LOGIN_SUCCESS: Login Success [user: ] [Source: 192.168.77.20] [localport: 23] at 17:21:02 CST Thu Nov 24 2016'
# 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