-
Notifications
You must be signed in to change notification settings - Fork 1
/
emoticons.py
68 lines (54 loc) · 1.98 KB
/
emoticons.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
""" emoticon recognition via patterns. tested on english-language twitter, but
probably works for other social media dialects. """
__author__ = "Brendan O'Connor (anyall.org, [email protected])"
__version__= "april 2009"
#from __future__ import print_function
import re,sys
mycompile = lambda pat: re.compile(pat, re.UNICODE)
#SMILEY = mycompile(r'[:=].{0,1}[\)dpD]')
#MULTITOK_SMILEY = mycompile(r' : [\)dp]')
NormalEyes = r'[:=]'
Wink = r'[;]'
NoseArea = r'(|o|O|-)' ## rather tight precision, \S might be reasonable...
HappyMouths = r'[D\)\]]'
SadMouths = r'[\(\[]'
Tongue = r'[pP]'
OtherMouths = r'[doO/\\]' # remove forward slash if http://'s aren't cleaned
Happy_RE = mycompile( '(\^_\^|' + NormalEyes + NoseArea + HappyMouths + ')')
Sad_RE = mycompile(NormalEyes + NoseArea + SadMouths)
Wink_RE = mycompile(Wink + NoseArea + HappyMouths)
Tongue_RE = mycompile(NormalEyes + NoseArea + Tongue)
Other_RE = mycompile( '('+NormalEyes+'|'+Wink+')' + NoseArea + OtherMouths )
Emoticon = (
"("+NormalEyes+"|"+Wink+")" +
NoseArea +
"("+Tongue+"|"+OtherMouths+"|"+SadMouths+"|"+HappyMouths+")"
)
Emoticon_RE = mycompile(Emoticon)
#Emoticon_RE = "|".join([Happy_RE,Sad_RE,Wink_RE,Tongue_RE,Other_RE])
#Emoticon_RE = mycompile(Emoticon_RE)
def analyze_tweet(text):
h= Happy_RE.search(text)
s= Sad_RE.search(text)
if h and s: return "BOTH_HS"
if h: return "HAPPY"
if s: return "SAD"
return "NA"
# more complex & harder, so disabled for now
#w= Wink_RE.search(text)
#t= Tongue_RE.search(text)
#a= Other_RE.search(text)
#h,w,s,t,a = [bool(x) for x in [h,w,s,t,a]]
#if sum([h,w,s,t,a])>1: return "MULTIPLE"
#if sum([h,w,s,t,a])==1:
# if h: return "HAPPY"
# if s: return "SAD"
# if w: return "WINK"
# if a: return "OTHER"
# if t: return "TONGUE"
#return "NA"
if __name__=='__main__':
for line in sys.stdin:
import sane_re
sane_re._S(line[:-1]).show_match(Emoticon_RE, numbers=False)
#print(analyze_tweet(line.strip()), line.strip(), sep="\t")