Skip to content

Commit be554c2

Browse files
committed
一个纯净的软件下载服务后台
1 parent 27a6e56 commit be554c2

File tree

1 file changed

+85
-0
lines changed

1 file changed

+85
-0
lines changed

com/ww/software/__init__.py

Lines changed: 85 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,85 @@
1+
import json
2+
import re
3+
4+
import requests
5+
import web
6+
7+
8+
class Download(object):
9+
10+
def GET(self):
11+
data = web.input()
12+
name = data.name
13+
print("查询软件名称为: {}".format(name))
14+
data, total = self.getTxInfo(name)
15+
resp = {
16+
"data": data,
17+
"total": total
18+
}
19+
return json.dumps(resp)
20+
21+
def getTxInfo(self, name):
22+
url = 'https://s.pcmgr.qq.com/tapi/web/searchcgi.php?type=search&callback=searchCallback&keyword=%s&page=1&pernum=30&more=0' % name
23+
res = requests.get(url)
24+
info = res.content.decode(encoding='utf-8')
25+
info = re.sub(r'\\', '', eval("'{}'".format(info)))
26+
# 总共找到的软件数量
27+
self.total = re.findall(re.compile(r'"total":(\d+)'), info)
28+
# 应用名
29+
dname = re.findall(re.compile(r'"SoftName":"(.*?)",'), info)
30+
# 软件版本
31+
version = re.findall(re.compile(r'versionname>(.*?)<'), info)
32+
# 系统位数
33+
osbit = re.findall(re.compile(r'osbit="(\d)"'), info)
34+
# 软件大小
35+
filesize = re.findall(re.compile(r'filesize>(.*?)<'), info)
36+
# 发布时间
37+
publishdate = re.findall(re.compile(r'publishdate>(.*?)<'), info)
38+
# 软件描述
39+
feature_old = re.findall(re.compile(r'feature>.*\n.*CDATA\[(.*)]]>'), info)
40+
feature_new = []
41+
for i in range(len(feature_old)):
42+
if i % 2 != 0:
43+
feature_new.append(feature_old[i])
44+
# 文件名
45+
filename = re.findall(re.compile(r'filename>(.*?)<'), info)
46+
# 软件评分
47+
point = re.findall(re.compile(r'point>(.*?)<'), info)
48+
# 下载地址
49+
dUrl_old = (re.findall(re.compile(r'(http[s]?://.*)]]'), info))
50+
dUrl = []
51+
for i in range(len(dUrl_old)):
52+
if len(dUrl) == 0:
53+
dUrl.append(dUrl_old[i])
54+
elif dUrl_old[i].split('/')[-1] != dUrl[-1].split('/')[-1]:
55+
dUrl.append(dUrl_old[i])
56+
# 图片
57+
logo = re.findall(re.compile(r'logo48>(.*?)<'), info)
58+
self.data = {}
59+
if self.total is not None:
60+
for j in range(int(self.total[0])):
61+
box = []
62+
for i in dname, version, osbit, filesize, publishdate, feature_new, point, dUrl, filename, logo:
63+
box.append(i[j])
64+
self.data[j] = box
65+
return self.data, self.total
66+
67+
def getOtherInfo(self, name):
68+
url = "http://bapi.safe.360.cn/soft/search?keyword={}&page=1".format(name)
69+
res = requests.get(url)
70+
lst = res.json()['data']['list']
71+
total = res.json()['data']['total']
72+
data = {}
73+
for i in range(len(lst)):
74+
data[i] = lst[i]
75+
76+
return data, total
77+
78+
79+
urls = (
80+
'/list', Download,
81+
)
82+
83+
if __name__ == '__main__':
84+
app = web.application(urls, globals())
85+
app.run()

0 commit comments

Comments
 (0)