-
Notifications
You must be signed in to change notification settings - Fork 524
/
Copy pathparse_api_log.py
67 lines (55 loc) · 2.38 KB
/
parse_api_log.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
import json
import sys
def extract_data(log_file):
entries = []
with open(log_file, 'r', encoding="utf-8") as file:
lines = file.readlines()
for i, line in enumerate(lines):
if line.startswith('Generation Prompt:') and not lines[i + 1].startswith("<pad>"):
current_entry = {'prompt': "", 'response': ""}
prompt_end_point = i + 1
for j in range(i + 1, len(lines)):
if lines[j].strip().endswith('- INFO'):
current_entry['prompt'] = current_entry['prompt'].rstrip()
break
current_entry['prompt'] += lines[j]
prompt_end_point = j
for j in range(prompt_end_point + 1, len(lines)):
if lines[j].startswith('Url:') and lines[j].strip().endswith("/completions"):
for k in range(j + 1, len(lines)):
if lines[k].startswith('Data:'):
for l in range(k + 1, len(lines)):
if "RequestsNum: " in lines[l]:
current_entry['response'] = current_entry['response'].rstrip()
entries.append(current_entry)
break
current_entry['response'] += lines[l]
else:
continue
break
else:
continue
break
return entries
def main():
log_file = 'D:\\RWKV_Runner\\api.log' if len(sys.argv) < 2 else sys.argv[1]
entries = extract_data(log_file)
try:
import cyac
trie = cyac.Trie()
histories = []
for entry in entries:
v = entry['prompt'] + entry['response']
trie.insert(v)
for entry in entries:
v = entry['prompt'] + entry['response']
for id in trie.predict(v):
pass
if trie[id] == v:
histories.append(entry)
json_data = json.dumps(histories, indent=2)
except ModuleNotFoundError:
json_data = json.dumps(entries, indent=2)
print(json_data.encode('utf-8').decode('unicode_escape'))
if __name__ == "__main__":
main()