Fixed groups/categories
This commit is contained in:
parent
dd34e76002
commit
47aaef4053
95
channels.py
95
channels.py
@ -7,51 +7,70 @@ import sys
|
||||
from utils import m3u_url
|
||||
|
||||
def get_channels():
|
||||
"""
|
||||
Get a list of channels from the M3U playlist.
|
||||
"""
|
||||
Get a list of channels from the M3U playlist.
|
||||
|
||||
Returns:
|
||||
list: A list of channel dictionaries with name, url, logo, and group.
|
||||
"""
|
||||
if m3u_url:
|
||||
try:
|
||||
response = requests.get(m3u_url)
|
||||
response.raise_for_status() # Raise exception for HTTP errors
|
||||
except requests.RequestException as e:
|
||||
print(f"Error fetching M3U playlist: {e}")
|
||||
return []
|
||||
else:
|
||||
print("Error: IPMPV_M3U_URL not set. Please set this environment variable to the URL of your IPTV list, in M3U format.")
|
||||
sys.exit(1)
|
||||
Returns:
|
||||
list: A list of channel dictionaries with name, url, logo, and group.
|
||||
"""
|
||||
if m3u_url:
|
||||
try:
|
||||
response = requests.get(m3u_url)
|
||||
response.raise_for_status() # Raise exception for HTTP errors
|
||||
except requests.RequestException as e:
|
||||
print(f"Error fetching M3U playlist: {e}")
|
||||
return []
|
||||
else:
|
||||
print("Error: IPMPV_M3U_URL not set. Please set this environment variable to the URL of your IPTV list, in M3U format.")
|
||||
sys.exit(1)
|
||||
|
||||
lines = response.text.splitlines()
|
||||
lines = response.text.splitlines()
|
||||
|
||||
channels = []
|
||||
regex = re.compile(r'tvg-logo="(.*?)".*?group-title="(.*?)"', re.IGNORECASE)
|
||||
channels = []
|
||||
# Match tvg-logo and group-title attributes
|
||||
logo_group_regex = re.compile(r'tvg-logo="(.*?)".*?group-title="(.*?)"', re.IGNORECASE)
|
||||
|
||||
for i in range(len(lines)):
|
||||
if lines[i].startswith("#EXTINF"):
|
||||
match = regex.search(lines[i])
|
||||
logo = match.group(1) if match else ""
|
||||
group = match.group(2) if match else "Other"
|
||||
name = lines[i].split(",")[-1]
|
||||
url = lines[i + 1]
|
||||
for i in range(len(lines)):
|
||||
if lines[i].startswith("#EXTINF"):
|
||||
match = logo_group_regex.search(lines[i])
|
||||
|
||||
channels.append({"name": name, "url": url, "logo": logo, "group": group})
|
||||
logo = match.group(1) if match else ""
|
||||
|
||||
return channels
|
||||
# Handle multiple groups separated by semicolons
|
||||
groups = []
|
||||
if match and match.group(2):
|
||||
# Split by semicolon and create a channel entry for each group
|
||||
groups = [group.strip() for group in match.group(2).split(';')]
|
||||
|
||||
# Default to "Other" if no groups found
|
||||
if not groups:
|
||||
groups = ["Other"]
|
||||
|
||||
name = lines[i].split(",")[-1]
|
||||
url = lines[i + 1]
|
||||
|
||||
# Create a channel entry for the primary group
|
||||
primary_group = groups[0]
|
||||
channels.append({"name": name, "url": url, "logo": logo, "group": primary_group})
|
||||
|
||||
# Create additional channel entries for secondary groups if present
|
||||
for group in groups[1:]:
|
||||
if group: # Skip empty groups
|
||||
channels.append({"name": name, "url": url, "logo": logo, "group": group})
|
||||
|
||||
return channels
|
||||
|
||||
def group_channels(channels):
|
||||
"""
|
||||
Group channels by their group title.
|
||||
"""
|
||||
Group channels by their group title.
|
||||
|
||||
Args:
|
||||
channels (list): List of channel dictionaries.
|
||||
Args:
|
||||
channels (list): List of channel dictionaries.
|
||||
|
||||
Returns:
|
||||
dict: Dictionary of channel groups.
|
||||
"""
|
||||
grouped_channels = {}
|
||||
for channel in channels:
|
||||
grouped_channels.setdefault(channel["group"], []).append(channel)
|
||||
return grouped_channels
|
||||
Returns:
|
||||
dict: Dictionary of channel groups.
|
||||
"""
|
||||
grouped_channels = {}
|
||||
for channel in channels:
|
||||
grouped_channels.setdefault(channel["group"], []).append(channel)
|
||||
return grouped_channels
|
||||
|
||||
Loading…
Reference in New Issue
Block a user