diff options
author | Jinwei Zhao <[email protected]> | 2017-01-31 18:32:56 +0800 |
---|---|---|
committer | Jinwei Zhao <[email protected]> | 2017-01-31 18:32:56 +0800 |
commit | e0c3ae70a20fedc3bad638ef6676363f8eb3efcb (patch) | |
tree | dd4c35e9159802ecbd3ca6c5c08f64caca662ba3 /ingrex | |
parent | 3e3bd71f48821d3cdb34536be4dcecdcde9b49ab (diff) | |
download | COMM2TG-e0c3ae70a20fedc3bad638ef6676363f8eb3efcb.tar.gz |
refactor
Diffstat (limited to 'ingrex')
-rwxr-xr-x | ingrex/praser.py | 62 |
1 files changed, 51 insertions, 11 deletions
diff --git a/ingrex/praser.py b/ingrex/praser.py index a05ec1e..1d2c03d 100755 --- a/ingrex/praser.py +++ b/ingrex/praser.py | |||
@@ -1,26 +1,66 @@ | |||
1 | "Ingrex praser deal with message" | ||
2 | from datetime import datetime, timedelta | 1 | from datetime import datetime, timedelta |
3 | import platform | 2 | import re |
4 | import os | 3 | import os |
5 | import time | 4 | import time |
6 | 5 | ||
7 | osname = platform.system() | ||
8 | if osname == "Linux": | ||
9 | os.environ['TZ'] = 'Asia/Shanghai' | ||
10 | time.tzset() | ||
11 | |||
12 | 6 | ||
13 | class Message(object): | 7 | class Message(object): |
14 | "Message object" | ||
15 | def __init__(self, raw_msg): | 8 | def __init__(self, raw_msg): |
9 | os.environ['TZ'] = 'Asia/Shanghai' | ||
10 | time.tzset() | ||
11 | |||
12 | seconds, millis = divmod(raw_msg[1], 1000) | ||
13 | timestamp = datetime.fromtimestamp(seconds) + timedelta(milliseconds=millis) | ||
14 | self.time = timestamp.strftime('%Y/%m/%d %H:%M:%S:%f')[:-3] | ||
15 | |||
16 | self.raw = raw_msg | 16 | self.raw = raw_msg |
17 | self.guid = raw_msg[0] | 17 | self.guid = raw_msg[0] |
18 | self.timestamp = raw_msg[1] | 18 | self.timestamp = raw_msg[1] |
19 | seconds, millis = divmod(raw_msg[1], 1000) | ||
20 | time = datetime.fromtimestamp(seconds) + timedelta(milliseconds=millis) | ||
21 | self.time = time.strftime('%Y/%m/%d %H:%M:%S:%f')[:-3] | ||
22 | self.text = raw_msg[2]['plext']['text'] | 19 | self.text = raw_msg[2]['plext']['text'] |
23 | self.ptype = raw_msg[2]['plext']['plextType'] | 20 | self.ptype = raw_msg[2]['plext']['plextType'] |
24 | self.team = raw_msg[2]['plext']['team'] | 21 | self.team = raw_msg[2]['plext']['team'] |
25 | self.type = raw_msg[2]['plext']['markup'][1][1]['plain'] | 22 | self.type = raw_msg[2]['plext']['markup'][1][1]['plain'] |
26 | 23 | ||
24 | self.msg = '' | ||
25 | self.markup = raw_msg[2]['plext']['markup'] | ||
26 | |||
27 | for mark in self.markup: | ||
28 | if mark[0] == 'SECURE': | ||
29 | self.msg += mark[1]['plain'] | ||
30 | elif mark[0] == 'SENDER': | ||
31 | player = mark[1]['plain'] | ||
32 | team = mark[1]['team'] | ||
33 | |||
34 | pattern = re.compile(':') | ||
35 | match = pattern.search(player) | ||
36 | if match: | ||
37 | if team == 'RESISTANCE': | ||
38 | player = player[:match.span()[0]] + ' 🐳' + player[match.span()[0]:] | ||
39 | elif team == 'ENLIGHTENED': | ||
40 | player = player[:match.span()[0]] + ' 🐸' + player[match.span()[0]:] | ||
41 | self.msg += player | ||
42 | |||
43 | elif mark[0] == 'PLAYER' or mark[0] == 'AT_PLAYER': | ||
44 | player = mark[1]['plain'] | ||
45 | team = mark[1]['team'] | ||
46 | |||
47 | self.msg += player | ||
48 | if team == 'RESISTANCE': | ||
49 | self.msg += ' 🐳' | ||
50 | elif team == 'ENLIGHTENED': | ||
51 | self.msg += ' 🐸' | ||
52 | |||
53 | elif mark[0] == 'TEXT': | ||
54 | self.msg += mark[1]['plain'] | ||
55 | |||
56 | pattern = re.compile('\[secure\]') | ||
57 | match = pattern.search(self.msg) | ||
58 | if match: | ||
59 | if self.msg.find(':') != -1: | ||
60 | self.msg = self.msg[:9] + '@' + self.msg[9:] | ||
61 | else: | ||
62 | self.msg = self.msg[:10] + '@' + self.msg[10:] | ||
63 | else: | ||
64 | self.msg = '@' + self.msg | ||
65 | |||
66 | self.msg = self.time + self.msg | ||