-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathzhibo8_v4.5.py
102 lines (78 loc) · 3.62 KB
/
zhibo8_v4.5.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
import datetime
import os
import re
import eel
import requests
from jinja2 import Environment, FileSystemLoader
root = os.path.dirname(os.path.abspath(__file__))
templates_dir = os.path.join(root, "web/")
env = Environment(loader=FileSystemLoader(templates_dir))
template = env.get_template('main_template.html')
filename = os.path.join(templates_dir, 'index.html')
eel.init(templates_dir)
def handleInput(teamInput):
if not teamInput:
teamInput = ['国安', '利物浦', '阿森纳', '热刺', '勇士', 'F1', '皇家马德里']
return teamInput
def getHtml(url="https://www.zhibo8.cc/"): # 设法消除非UTF-8网页编码带来的乱码
req = requests.get(url)
if req.encoding == 'ISO-8859-1':
encodings = requests.utils.get_encodings_from_content(req.text)
if encodings:
encoding = encodings[0]
else:
encoding = req.apparent_encoding
encode_content = req.content.decode(encoding, 'replace') # 如果设置为replace,则会用?取代非法字符;
return encode_content
else:
return req.text
def reform(result): # 整理比赛数据格式
sort = [result[1], result[0], result[2]]
now = datetime.datetime.now().strftime('%H:%M')
# 优化由于睡眠时间产生的歧义
today = datetime.date.today() - datetime.timedelta(days=1 if '00:00' < now < '05:00' else 0)
tomorrow = today + datetime.timedelta(days=1)
theDayAfterTomorrow = today + datetime.timedelta(days=2)
listDay = sort[0][:10]
listTime = sort[0][-5:]
night = True if "00:00" <= listTime <= "05:00" else False
# 判断时间是否需要替换为汉字 如果是明天凌晨转换为‘今夜’,同理后天凌晨转换为‘明晚’
if listDay == str(tomorrow) and night:
sort[0] = "今夜 " + listTime
elif listDay == str(today):
sort[0] = "今天 " + listTime
elif listDay == str(tomorrow):
sort[0] = "明天 " + listTime
elif listDay == str(theDayAfterTomorrow) and night:
sort[0] = "明晚 " + listTime
else:
sort[0] = sort[0][5:10] + ' ' + listTime # 切掉年份
return sort
def splitTeamInfo(gameInfoList):
# 将以下字符归类为tags
nonTeam = ['欧联杯', '足球', '篮球', 'NBA', 'CBA', '英超', '西甲', '荷甲', '待定',
'中超', '亚冠', '欧冠', '中甲', '足协杯', 'MLB', 'MLB常规赛', '英格兰橄榄球超级联赛']
# 定义需要消除的tags
giveup = ['篮球', '足球', 'F1', '其他']
gameInfo = gameInfoList.split(',')
teams = [i for i in gameInfo if i not in nonTeam and i not in giveup]
tags = [i for i in gameInfo if i in nonTeam and i not in giveup]
return [teams] + [tags]
def showTeam(*args):
showList = listReady = [] # 预定义变量
targetRE = '<li label="(.*?)" id="saishi.*?data-time="(.*?)".*?">(.*?)</a>'
results = re.findall(targetRE, getHtml(), re.S)
for result in results:
for team in args:
if team in result[0] and result not in showList:
showList.append(reform(result))
for game in range(len(showList)): # 整理成分组的list,[第一组时间][第二组比赛信息][第三组转播信息]
listReady[game] = [showList[game][0].split()] + [splitTeamInfo(showList[game][1])] + \
[showList[game][2].split()]
return listReady
if __name__ == '__main__':
showListReady = showTeam(*handleInput(teamInput=[]))
with open(filename, 'w', encoding='UTF-8') as fh:
output = template.render(showListReady=showListReady)
fh.write(output)
eel.start('index.html', size=(752, 730))