Spaces:
Sleeping
Sleeping
File size: 4,305 Bytes
a1de66d fbfdf9e a830900 00a404f a1de66d 00a404f a1de66d 00a404f fbfdf9e a1de66d a830900 e2e910d a830900 e2e910d fbfdf9e a830900 fbfdf9e a830900 e2e910d a830900 e2e910d a830900 00a404f a830900 e2e910d a830900 e2e910d 00a404f a830900 cc2c8d6 fbfdf9e e2e910d |
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 |
import streamlit as st
import re
import os
import glob
st.set_page_config(layout="wide")
def process_line(line):
if re.search(r'\b[A-G][#b]?m?\b', line):
line = re.sub(r'\b([A-G][#b]?m?)\b', r"<img src='\1.png' style='height:20px;'>", line)
return line
def process_chord_sheet(chord_sheet):
processed_lines = []
for line in chord_sheet.split('\n'):
processed_line = process_line(line)
processed_lines.append(processed_line)
return '<br>'.join(processed_lines)
def create_search_url_wikipedia(artist_song):
base_url = "https://www.wikipedia.org/search-redirect.php?family=wikipedia&language=en&search="
return base_url + artist_song.replace(' ', '+').replace('–', '%E2%80%93').replace('&', 'and')
def create_search_url_youtube(artist_song):
base_url = "https://www.youtube.com/results?search_query="
return base_url + artist_song.replace(' ', '+').replace('–', '%E2%80%93').replace('&', 'and')
def create_search_url_chords(artist_song):
base_url = "https://www.ultimate-guitar.com/search.php?search_type=title&value="
return base_url + artist_song.replace(' ', '+').replace('–', '%E2%80%93').replace('&', 'and')
def create_search_url_lyrics(artist_song):
base_url = "https://www.google.com/search?q="
return base_url + artist_song.replace(' ', '+').replace('–', '%E2%80%93').replace('&', 'and') + '+lyrics'
def main():
with st.sidebar:
st.title('🎵 Song Files')
with st.expander("Select Song File", expanded=True):
all_files = [f for f in glob.glob("*.txt") if 'by' in f]
selected_file = st.selectbox("Choose a file", all_files)
if selected_file:
song_name, artist_name = os.path.splitext(selected_file)[0].split(' by ')
song_name = song_name.replace("_", " ")
artist_name = artist_name.replace("_", " ")
else:
song_name, artist_name = "", ""
col1, col2 = st.columns([2, 1])
with col1:
with st.expander("🎶 Song and Artist", expanded=True):
song_name_input = st.text_input("🎵 Song Name", value=song_name)
artist_name_input = st.text_input("🎤 Artist Name", value=artist_name)
chord_sheet_input = st.text_area("Chord Sheet", height=300)
if st.button("💾 Save", key="save_song"):
if song_name_input and artist_name_input:
filename = f"{song_name_input} by {artist_name_input}.txt".replace(" ", "_")
with open(filename, "w") as file:
file.write(chord_sheet_input)
st.success("Chord sheet saved.")
else:
st.error("Both Song Name and Artist Name are required.")
with col2:
if selected_file:
load_song_file(selected_file)
song_info = os.path.splitext(selected_file)[0].replace("_", " ")
st.markdown(f"**Selected Song:** {song_info}")
st.markdown(f"[📚Wikipedia]({create_search_url_wikipedia(song_info)})")
st.markdown(f"🎥YouTube")
st.markdown(f"🎸Chords")
st.markdown(f"🎶Lyrics")
st.header("🎼 Available Songs")
for file in all_files:
song_info = os.path.splitext(file)[0].replace("_", " ")
col1, col2, col3, col4, col5 = st.columns([4, 1, 1, 1, 1])
with col1:
st.markdown(f"* {song_info}")
with col2:
st.markdown(f"[📚Wikipedia]({create_search_url_wikipedia(song_info)})")
with col3:
st.markdown(f"[🎥YouTube]({create_search_url_youtube(song_info)})")
with col4:
st.markdown(f"[🎸Chords]({create_search_url_chords(song_info)})")
with col5:
st.markdown(f"[🎶Lyrics]({create_search_url_lyrics(song_info)})")
def load_song_file(filename):
with open(filename, "r") as file:
chord_sheet = file.read()
st.text_area("Chord Sheet", chord_sheet, height=300)
processed_sheet = process_chord_sheet(chord_sheet)
st.markdown(processed_sheet, unsafe_allow_html=True)
if name == 'main':
main() |