def get_channel_video_info(self): # 获取UP所有频道的所有视频 if self.uid is None: raise BaseException('缺少必要的参数') if self.name is None: self.get_user_info() f.print_1('正在获取频道列表...', end='') param = {'mid': str(self.uid), 'guest': False, 'jsonp': 'jsonp'} http_result = requests.get(v.URL_UP_CHANNELS, params=param, headers=f.new_http_header( v.URL_UP_CHANNELS)) if http_result.status_code == 200: f.print_g('OK {}'.format(http_result.status_code)) else: f.print_r('RE {}'.format(http_result.status_code)) json_data = json.loads(http_result.text) if json_data['code'] != 0: raise BaseException('获取数据的过程发生错误') for channel in json_data['data']['list']: ch = Channel(self.uid, channel['cid']) ch.set_cookie(self.cookie) self.channel_list.append(ch) return copy.deepcopy(self.channel_list)
def get_user_info(self): if self.uid is None: raise BaseException('缺少必要的参数') f.print_1('正在获取用户信息...', end='') param = {'mid': str(self.uid), 'jsonp': 'jsonp'} http_result = requests.get(url=v.URL_UP_INFO, params=param, headers=f.new_http_header(v.URL_UP_INFO)) if http_result.status_code == 200: f.print_g('OK {}'.format(http_result.status_code)) else: f.print_r('RE {}'.format(http_result.status_code)) json_data = json.loads(http_result.text) if json_data['code'] != 0: raise BaseException('获取数据的过程发生错误') # 修改对象信息 self.uid = json_data['data']['mid'] self.name = json_data['data']['name'] self.birthday = json_data['data']['birthday'] self.coin = json_data['data']['coins'] self.face = json_data['data']['face'] self.time = json_data['data']['jointime'] self.level = json_data['data']['level'] self.sex = json_data['data']['sex'] self.sign = json_data['data']['sign'] return copy.deepcopy(vars(self))
def get_album_info(self, proxies=None): if self.aid is None: raise BaseException('缺少必要的参数') f.print_1('正在获取视频信息...', end='') param = {'aid': str(self.aid)} http_result = requests.get(v.URL_UP_ALBUM, params=param, proxies=proxies, headers=f.new_http_header(v.URL_UP_ALBUM)) if http_result.status_code == 200: f.print_g('OK {}'.format(http_result.status_code)) else: f.print_r('RE {}'.format(http_result.status_code)) json_data = json.loads(http_result.text) if json_data['code'] == -404 or json_data['code'] == -403: raise LookupError('稿件av{}异常或被锁定,无法下载'.format(self.aid)) elif json_data['code'] != 0: raise BaseException('获取数据的过程发生错误:av={},code={}'.format( self.aid, json_data['code'])) # 修改对象信息 self.aid = json_data['data']['aid'] self.time = json_data['data']['ctime'] self.desc = json_data['data']['desc'] self.name = json_data['data']['title'] self.zone = json_data['data']['tname'] self.num = json_data['data']['videos'] self.cover = json_data['data']['pic'] self.like = json_data['data']['stat']['like'] self.coin = json_data['data']['stat']['coin'] self.favorite = json_data['data']['stat']['favorite'] self.share = json_data['data']['stat']['share'] self.view = json_data['data']['stat']['view'] self.danmu = json_data['data']['stat']['danmaku'] self.video_list = list() for page in json_data['data']['pages']: cv = Video(self.aid, page['cid'], page['page'], page['part']) cv.set_cookie(self.cookie) self.video_list.append(cv) return copy.deepcopy(vars(self))
def get_video_info(self, qn=116): if self.aid is None or self.cid is None: raise BaseException('缺少必要的参数') f.print_1('正在获取分P信息...', end='') param = { 'avid': str(self.aid), 'cid': str(self.cid), 'qn': qn, # 默认使用最高画质下载 'otype': 'json', 'fnver': 0, 'fnval': 16 } http_result = requests.get(v.URL_UP_VIDEO, params=param, cookies=self.cookie, headers=f.new_http_header(v.URL_UP_INFO)) if http_result.status_code == 200: f.print_g('OK {}'.format(http_result.status_code)) else: f.print_r('RE {}'.format(http_result.status_code)) json_data = json.loads(http_result.text) if json_data['code'] != 0: raise BaseException('获取数据的过程发生错误') # 自动识别不同的数据来源 if 'dash' in json_data['data']: self.quality = json_data['data']['quality'] self.length = json_data['data']['timelength'] self.video = json_data['data']['dash']['video'][-1]['baseUrl'] self.audio = json_data['data']['dash']['audio'][0]['baseUrl'] elif 'durl' in json_data['data']: self.quality = json_data['data']['quality'] self.length = json_data['data']['timelength'] self.video = json_data['data']['durl'][-1]['url'] for index, val in enumerate(json_data['data']['accept_quality']): if val == self.quality: self.quality_des = json_data['data']['accept_description'][ index] break return self
def get_all_video_info(self): # 获取UP主的所有视频的列表信息 if self.uid is None: raise BaseException('缺少必要的参数') if self.name is None: self.get_user_info() f.print_1('正在获取视频列表...', end='') param = { 'mid': str(self.uid), 'pagesize': 30, 'tid': 0, 'page': 1, 'order': 'pubdate' } while True: http_result = requests.get(v.URL_UP_ALL_VIDEO, params=param, headers=f.new_http_header( v.URL_UP_ALL_VIDEO)) if http_result.status_code == 200: f.print_g('OK {}'.format(http_result.status_code)) else: f.print_r('RE {}'.format(http_result.status_code)) json_data = json.loads(http_result.text) if json_data['status'] is not True: raise BaseException('获取数据的过程发生错误') for video in json_data['data']['vlist']: av = Album(video['aid']) av.set_cookie(self.cookie) self.album_list.append(av) # 循环翻页获取并自动退出循环 if len(self.album_list) >= int(json_data['data']['count']): break else: param['page'] += 1 return copy.deepcopy(self.album_list)
def get_channel_info(self): if self.uid is None or self.cid is None: raise BaseException('缺少必要的参数') param = { 'mid': str(self.uid), 'cid': str(self.cid), 'pn': 1, # 当前页码下标 'ps': 30, # 每页视频数量 'order': 0 # 默认排序 } while True: f.print_1('正在获取视频列表-{}...'.format(param['pn']), end='') http_result = requests.get(v.URL_UP_CHANNEL, params=param, headers=f.new_http_header( v.URL_UP_CHANNEL)) if http_result.status_code == 200: f.print_g('OK {}'.format(http_result.status_code)) else: f.print_r('RE {}'.format(http_result.status_code)) json_data = json.loads(http_result.text) if json_data['code'] != 0: raise BaseException('获取数据的过程发生错误') self.name = json_data['data']['list']['name'] self.cover = json_data['data']['list']['cover'] self.count = str(json_data['data']['list']['count']) for album in json_data['data']['list']['archives']: av = Album(album['aid']) av.set_cookie(self.cookie) self.album_list.append(av) # 循环翻页获取并自动退出循环 if len(self.album_list) >= int(json_data['data']['page']['count']): break else: param['pn'] += 1 return copy.deepcopy(vars(self))