text is :
WYATT - Ranked # 855 with 0.006 %
XAVIER - Ranked # 587 with 0.013 %
YONG - Ranked # 921 with 0.006 %
YOUNG - Ranked # 8
Don't need a regex.
string[: string.find(' ')]
You don't need regex to split a string on whitespace:
In [1]: text = '''WYATT - Ranked # 855 with 0.006 %
...: XAVIER - Ranked # 587 with 0.013 %
...: YONG - Ranked # 921 with 0.006 %
...: YOUNG - Ranked # 807 with 0.007 %'''
In [2]: print '\n'.join(line.split()[0] for line in text.split('\n'))
WYATT
XAVIER
YONG
YOUNG
Regex is unnecessary for this. Just use some_string.split(' ', 1)[0] or some_string.partition(' ')[0].
If you want to feel especially sly, you can write it as this:
(firstWord, rest) = yourLine.split(maxsplit=1)
This is supposed to bring the best from both worlds:
maxsplit while splitting with any whitespaceI kind of fell in love with this solution and it's general unpacking capability, so I had to share it. :)
You shoud do something like :
print line.split()[0]
Use this regex
^\w+
\w+ matches 1 to many characters.
\w is similar to [a-zA-Z0-9_]
^ depicts the start of a string
About Your Regex
Your regex (.*)?[ ] should be ^(.*?)[ ] or ^(.*?)(?=[ ]) if you don't want the space