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 103
| image_dict = { '...': 0, '...': 6, '...': 8, '...': 1, '...': 9, '...': 4, '...': 2, '...': 3, '...': 7, '...': 5 }
answer_num_list = []
def get_base64_data(page_num): url = 'http://match.yuanrenxue.com/api/match/4?page={}'.format(page_num) headers = { 'Host': 'match.yuanrenxue.com', 'Pragma': 'no-cache', 'Referer': 'http://match.yuanrenxue.com/match/4', 'User-Agent': 'yuanrenxue.project', 'X-Requested-With': 'XMLHttpRequest' } res = requests.get(url=url, headers=headers) # print(res.text) return res.json()['info'], res.json()['key'], res.json()['value']
def b642jpg(b64str, name): data = base64.b64decode(b64str) with open('{}.jpg'.format(name), 'wb') as f: f.write(data) print('打印完毕')
# var j_key = '.' + hex_md5(btoa(data.key + data.value).replace(/=/g, '')); # 利用key和value计算出属性为display=none的md5索引值 def get_j_key(key, value): return hashlib.md5(base64.b64encode((key + value).encode()).replace(b'=', b'')).hexdigest()
# 获取td中4个图片 def parse_every_group_nums(info_data): pattern = re.compile(r'<td>(.*?)</td>') every_group_nums_list = pattern.findall(info_data) return every_group_nums_list
# 利用j_key和每个图片对应的hash值,确定出要被用的所有数字子图片,及其相对位置偏移值 def parse_real_use_num_info(every_group_nums, j_key): # 找到base64 pattern = re.compile(r'img_number (.*?)"') img_number_list = pattern.findall(every_group_nums) # 找到图片 pattern = re.compile(r'base64,(.*?)"') ba64_str_list = pattern.findall(every_group_nums) # 找到样式 pattern = re.compile(r'style="(.*?)"') number_style_list = pattern.findall(every_group_nums)
# 寻找所有要用的子图 ba64_str_list = [ba64_str_list[index] for index, img_number in enumerate(img_number_list) if img_number != j_key] num_list = [image_dict['data:image/png;base64,' + __] for __ in ba64_str_list]
# 匹配每个子图实际对应的偏移量 6801 -> ['0', '11.5', '-11.5', '0.0'] number_style_list = [number_style_list[index].replace('left:', '').replace('px', '') for index, img_number in enumerate(img_number_list) if img_number != j_key]
# 根据偏移值,计算真实的数字顺序 ture_order_list = caculate_css_left(number_style_list, num_list)
# 将每小组数字拼接并保存 temp_num = 0 for index, num in enumerate(ture_order_list[::-1]): temp_num += num * 10 ** index answer_num_list.append(temp_num)
# 根据图片映射的数字和图片的偏移值,计算出数字的真实顺序,列表排序返回 def caculate_css_left(number_style_list, num_list): # [0, 1, -1, 0] number_style_list = [round(float(__) / 11) for __ in number_style_list] # 定义数组 ture_order_list = ['']*len(number_style_list) for index, number_style in enumerate(number_style_list): ture_order_list[int(index + number_style)] = num_list[index] return ture_order_list
if __name__ == '__main__': # info, _, __ = get_base64_data(1) # # <td>有10组 left有63个 display有0个,需要md5计算进行拼接base64 ed501a5e229d41330bee8399441bfbfb有39次 57feebf056bfb527e9ad8561e0694b0a有24次 # ''' # b642jpg(b64str, 'test') for page_num in range(1, 6): info_data, key, value = get_base64_data(page_num) j_key = get_j_key(key, value) every_group_nums_list = parse_every_group_nums(info_data) for every_group_nums in every_group_nums_list: parse_real_use_num_info(every_group_nums, j_key) print(sum(answer_num_list))
|