I have an input for users to enter a Twitter account in any different way and I want to extract the user account.
For example:
twitters = [
"www.twitter.com/twitteruser1",
"@twitteruser2",
"twitteruser3",
"https://twitter.com/twitteruser4",
"https://www.twitter.com/twitteruser5",
"www.twitter.com/twitteruser6",
"http://www.twitter.com/twitteruser7",
"http://www.twitter.com/twitteruser8",
"twitter.com/twitteruser9"
]
The script that I've written to extract the data is the following:
twitters.each do |twitter|
# for the url
twitter_user = twitter.match(/twitter.com\/([^\/.]*)$/)
if twitter_user != nil
puts twitter_user[1]
next
end
# for @ beginning
twitter_user = twitter.match(/^@([^\/.]*)$/)
if twitter_user != nil
puts twitter_user[1]
next
end
# if we arrive, we haven't found any coincidence
puts twitter
end
It actually works, outputting the following:
twitteruser1
twitteruser2
twitteruser3
twitteruser4
twitteruser5
twitteruser6
twitteruser7
twitteruser8
twitteruser9
But as I'm really newbie in Ruby I wanted to check for possible improvements.