|
| 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