REGEX Help for Twitter

Hello guys,

Can you help me with the REGEX for the following?

I want to extract the "username" out of any of the following strings. The main differences are http[s], trailing slash, the inclusion of #!, and a variant that includes some other stuff in the url.

Thank you!

http://twitter.com/username/ 
http://twitter.com/username 

https://twitter.com/username/ 
https://twitter.com/username 

http://twitter.com/#!/username/
https://twitter.com/#!/username/

http://twitter.com/intent/user?screen_name=username
https://twitter.com/intent/user?screen_name=username
EffinGoodAsked:
Who is Participating?
 
gr8gonzoConnect With a Mentor ConsultantCommented:
I highly recommend installing the free tool "The Regex Coach" - I've been using it for years.

That said, try this on:
<?php

$urls = array(
"http://twitter.com/username/",
"http://twitter.com/username",
"https://twitter.com/username/",
"https://twitter.com/username",
"http://twitter.com/#!/username/",
"https://twitter.com/#!/username/",
"http://twitter.com/intent/user?screen_name=username",
"https://twitter.com/intent/user?screen_name=username");

foreach($urls as $url)
{
  echo "URL: {$url}\n";
  preg_match("@https?://twitter.com/(?:#!/|intent/user\?screen_name=)?(\w+)@",$url,$matches);
  echo "Username: " . $matches[1] . "\n";
}
?>

Open in new window


You should get this result:
URL: http://twitter.com/username/
Username: username
URL: http://twitter.com/username
Username: username
URL: https://twitter.com/username/
Username: username
URL: https://twitter.com/username
Username: username
URL: http://twitter.com/#!/username/
Username: username
URL: https://twitter.com/#!/username/
Username: username
URL: http://twitter.com/intent/user?screen_name=username
Username: username
URL: https://twitter.com/intent/user?screen_name=username
Username: username

Open in new window

0
 
ozoCommented:
.*\b(\w+)
0
 
Cornelia YoderArtistCommented:
If you are using php, there is an easier way (assuming that you are showing all possible formats).

Just explode() the string on "/", take the 4th part.  It will be either the username or "intent" or "#!".  In the second case, explode again on "=" and the last part will be the username.  In the third case, take the original 5th part.

The php explode() function is awesome.
0
Keep up with what's happening at Experts Exchange!

Sign up to receive Decoded, a new monthly digest with product updates, feature release info, continuing education opportunities, and more.

 
EffinGoodAuthor Commented:
Well, the problem is that the strings are located in a big file full of other chars, so I need to examine the entire file to pull these out.

There will be other urls in there - I'm just looking for those with the 'twitter' part.
0
 
EffinGoodAuthor Commented:
Nice! Thank you! I remember that nifty piece of software now - it's been eons! Thank you very much Gonzo!
0
 
Terry WoodsIT GuruCommented:
Very similar to @gr8gonzo's, though I wrote it independently:
preg_match_all("@https?://twitter.com/(?:#!/)?(?:.*\?screen_name=)?((?!intent)\w+)@i", $data, $matches);
print_r($matches[1]);

Open in new window

0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.