From 1e204536ba792efb8891894f95b5285814d6dafe Mon Sep 17 00:00:00 2001 From: "guorong.zheng" <360996299@qq.com> Date: Wed, 25 Dec 2024 15:44:20 +0800 Subject: [PATCH] chore:speed and resolution --- utils/channel.py | 2 +- utils/speed.py | 35 ++++++++++++++++++----------------- 2 files changed, 19 insertions(+), 18 deletions(-) diff --git a/utils/channel.py b/utils/channel.py index c7749cdd441..04ded3a5422 100644 --- a/utils/channel.py +++ b/utils/channel.py @@ -576,7 +576,7 @@ async def process_sort_channel_list(data, ipv6=False, callback=None): need_sort_data = copy.deepcopy(data) process_nested_dict(need_sort_data, seen=set(), flag=r"cache:(.*)", force_str="!") result = {} - semaphore = asyncio.Semaphore(5) + semaphore = asyncio.Semaphore(10) async def limited_get_speed(info, ipv6_proxy, filter_resolution, timeout, callback): async with semaphore: diff --git a/utils/speed.py b/utils/speed.py index 82373ccbf3f..163880888f7 100644 --- a/utils/speed.py +++ b/utils/speed.py @@ -100,13 +100,13 @@ async def get_speed_m3u8(url: str, filter_resolution: bool = config.open_filter_ segments = m3u8_obj.segments if not segments and playlists: parsed_url = urlparse(url) - url = f"{parsed_url.scheme}://{parsed_url.netloc}{parsed_url.path.rsplit('/', 1)[0]}/{playlists[0].get('uri', '')}" - uri_headers = await get_m3u8_headers(url, session) + uri = f"{parsed_url.scheme}://{parsed_url.netloc}{parsed_url.path.rsplit('/', 1)[0]}/{playlists[0].get('uri', '')}" + uri_headers = await get_m3u8_headers(uri, session) if not check_m3u8_valid(uri_headers): if uri_headers.get('Content-Length'): - info.update(await get_speed_with_download(url, session, timeout)) + info.update(await get_speed_with_download(uri, session, timeout)) raise Exception("Invalid m3u8") - m3u8_obj = m3u8.load(url, timeout=2) + m3u8_obj = m3u8.load(uri, timeout=2) segments = m3u8_obj.segments if not segments: raise Exception("Segments not found") @@ -120,8 +120,7 @@ async def get_speed_m3u8(url: str, filter_resolution: bool = config.open_filter_ speed_list.append(download_info['speed']) if info['delay'] is None and download_info['delay'] is not None: info['delay'] = download_info['delay'] - info['speed'] = sum(speed_list) / len(speed_list) if speed_list else 0 - url = ts_urls[0] + info['speed'] = (sum(speed_list) / len(speed_list)) if speed_list else 0 elif headers.get('Content-Length'): info.update(await get_speed_with_download(url, session, timeout)) except: @@ -206,17 +205,19 @@ async def get_resolution_ffprobe(url: str, timeout: int = config.sort_timeout) - resolution = None proc = None try: - probe_args = ["ffprobe", "-show_format", "-show_streams", "-of", "json", url] - proc = await asyncio.create_subprocess_exec( - *probe_args, - stdout=asyncio.subprocess.PIPE, - stderr=asyncio.subprocess.PIPE - ) - out, err = await asyncio.wait_for(proc.communicate(), timeout) - if proc.returncode != 0: - raise Exception("FFprobe failed") - video_stream = json.loads(out.decode("utf-8"))["streams"][0] - resolution = f"{int(video_stream['width'])}x{int(video_stream['height'])}" + probe_args = [ + 'ffprobe', + '-v', 'error', + '-select_streams', 'v:0', + '-show_entries', 'stream=width,height', + "-of", 'json', + url + ] + proc = await asyncio.create_subprocess_exec(*probe_args, stdout=asyncio.subprocess.PIPE, + stderr=asyncio.subprocess.PIPE) + out, _ = await asyncio.wait_for(proc.communicate(), timeout) + video_stream = json.loads(out.decode('utf-8'))["streams"][0] + resolution = f"{video_stream['width']}x{video_stream['height']}" except: if proc: proc.kill()