例如
!@#123myname --> myname
!@#yourname!@#123 --> yourname!@#123
有很多“删除所有字母数字字符的pythonic方法”的SO示例,但是如果我只想删除导致第一个字母字符的非字母字符,那么最好的方法是什么?
我可以用一个while循环来做,但我正在寻找一个更好的python解决方案
例如
!@#123myname --> myname
!@#yourname!@#123 --> yourname!@#123
有很多“删除所有字母数字字符的pythonic方法”的SO示例,但是如果我只想删除导致第一个字母字符的非字母字符,那么最好的方法是什么?
我可以用一个while循环来做,但我正在寻找一个更好的python解决方案
只需使用str.lstrip
.
它需要一个包含要从字符串左侧删除的字符的字符串,并且无论它们出现的顺序如何,都会删除这些字符。例如:
s = "!@#yourname!@#"
print s.lstrip('@!#') # yourname!@#
您可以在字符串的开头使用匹配非字母数字字符的正则表达式:
s = '!@#myname!!'
r = re.compile(r"^\W+") # \W non-alphanumeric at start ^ of string
输出:
In [28]: r = re.compile(r"^\W+")
In [29]: r.sub("",'!@#myname')
Out[29]: 'myname'
In [30]: r.sub("",'!@#yourname!@#')
Out[30]: 'yourname!@#'
\W+
将保留下划线,以便在开头保留字母和数字,我们可以:
s = '!@#_myname!!'
r = re.compile(r"^[^A-Za-z0-9]+")
print(r.sub("",s))
myname!!
如果您只想删除第一个字母:
r = re.compile(r"^[^A-Za-z]+")
如果要删除前导非字母/数字值:
while not s[0].isalnum(): s = s[1:]
如果您只想删除前导非字母字符:
while not s[0].isalpha(): s = s[1:]
样本:
s = '!@#yourname!@#'
while not s[0].isalpha(): s = s[1:]
print(s)
输出:
yourname!@#