我在Python中发现了一个用于删除表情符号的代码,但它不起作用。你能帮忙提供其他代码或修复这个代码吗?
我发现所有的表情符号都以\xf
开头,但当我尝试搜索str.startswith("\xf")
时,会出现无效字符错误。
emoji_pattern = r'/[x{1F601}-x{1F64F}]/u'
re.sub(emoji_pattern, '', word)
这里是错误:
Traceback (most recent call last):
File "test.py", line 52, in <module>
re.sub(emoji_pattern,'',word)
File "/usr/lib/python2.7/re.py", line 151, in sub
return _compile(pattern, flags).sub(repl, string, count)
File "/usr/lib/python2.7/re.py", line 244, in _compile
raise error, v # invalid expression
sre_constants.error: bad character range
在列表中的每个项都可以是一个单词 ['This', 'dog', '\xf0\x9f\x98\x82', 'https://t.co/5N86jYipOI']
更新: 我使用了另一段代码:
emoji_pattern=re.compile(ur" " " [\U0001F600-\U0001F64F] # emoticons \
|\
[\U0001F300-\U0001F5FF] # symbols & pictographs\
|\
[\U0001F680-\U0001F6FF] # transport & map symbols\
|\
[\U0001F1E0-\U0001F1FF] # flags (iOS)\
" " ", re.VERBOSE)
emoji_pattern.sub('', word)
但这仍然没有移除表情符号并显示它们!有任何线索为什么会这样吗?
\xf
开头。你可能在UTF-8中看到了表示该字符串的字节,而第一个字节是0xf0
。 - roeland