Как импортировать / экспортировать список радиостанций Rhythmbox?


10

Есть ли способ импортировать / экспортировать список радиостанций Rhythmbox?

Если нет, то не могли бы вы мне предложить какой-нибудь хороший музыкальный проигрыватель с аналогичной функциональностью, например Rhythmbox?

Спасибо!


1
Вы имеете в виду радиостанции?
Хавьер Гонсалес

Да, я имею в виду радиостанции
Бахтиёр,

Ответы:


7

rhythmbox хранит информацию обо всех музыкальных файлах в ~ / .local / share / rhythmbox / rhythmdb.xml

Записи о радиостанциях начинаются с "iradio типа входа".


Да, вы правы, я знал это раньше. Но я ищу более легкий путь, если таковой существует.
Бахтиер

3

Вот скрипт Python, который делает то же самое, то есть извлекает имена и местоположения интернет-радиостанций из базы данных xml, используемой Rhythmbox:

import xml.sax.handler
import xml.sax
import pprint

class RhythmboxPlaylistHandler(xml.sax.handler.ContentHandler):
    def __init__(self):
        self.inRTitle = False
        self.inRLocation = False
        self.entrytype = "undefined"
        self.titlebuffer = ""
        self.locationbuffer = ""
        self.radiostations = {}

    def startElement(self, name, attributes):
        if name == "entry":
            self.entrytype = attributes["type"]  # we're interested in type="iradio"
        elif name == "title" and self.entrytype == "iradio":
            self.inRTitle = True
        elif name == "location" and self.entrytype == "iradio":
            self.inRLocation = True

    def characters(self, data):
        if self.inRTitle:
            self.titlebuffer += data
        elif self.inRLocation:
            self.locationbuffer += data

    def endElement(self, name):
        if name == "title":
            self.inRTitle = False
        elif name == "location":
            self.inRLocation = False
        elif name == "entry" and self.entrytype == "iradio":
            self.radiostations[self.titlebuffer] = self.locationbuffer
            self.titlebuffer=""
            self.locationbuffer=""

parser = xml.sax.make_parser(  )
handler = RhythmboxPlaylistHandler(  )
parser.setContentHandler(handler)
parser.parse("work_copy_of_rhythmdb.xml")
pprint.pprint(handler.radiostations)

rstations=handler.radiostations

rskeys=[key for key in rstations]
rskeys.sort()

ofile=open("rhytmbox_current_internet_radiostations.txt","w")
ofile.write("#   {0:41}  -->  {1}\r\n".format('radio station name','location'))
ofile.write("#"+120*'-'+"\r\n")
for key in rskeys:
    ofile.write("{0:45}  -->  {1}\r\n".format(key,rstations[key]))
ofile.close()

(Я начал с этого урока по работе с базами данных XML из Python: http://oreilly.com/catalog/pythonxml/chapter/ch01.html )


2

Вы можете использовать xmlstarlet для извлечения важных данных из вашего XML-файла. Смотрите здесь для деталей:

http://steffen67.blogspot.com/2011/05/how-to-export-rhythmbox-radio-stations.html


хороший указатель на учебник xmlstarlet для этого
Sabacon

1
Хотя это может теоретически ответить на вопрос, было бы предпочтительным включить сюда основные части ответа и предоставить ссылку для справки.
Марко Чеппи

Извини за это. Я только отредактировал это, чтобы включить основную идею. (Спасибо за ссылку. Я волновался, что перепечатка другой информации будет дублировать веб-данные без необходимости.)
colan

0

для экспорта прочитайте файл, ~/.local/share/rhythmbox/rhythmdb.xml
если вы хотите импортировать Создайте список воспроизведения файла M3U как:

#EXTM3U
#EXTINF:-1,Quran - Eman City  Quran & Islam Talk
http://206.72.199.180:9990/;stream.nsv

#EXTINF:-1,Quran - Radio Quraan
http://66.45.232.131:9994/;stream.nsv

#EXTINF:-1,Quran - Allahu Akbar Radio
http://66.45.232.1ls32:10196/;stream.nsv

#EXTINF:-1,Quran - izlam
http://66.45.232.133:9998/;stream.nsv

#EXTINF:-1,Quran - tafsir Al Sheikh Mohammad Ratib Al Nabulsi & Sheikh Muhammad Mitwalli Al Sharawi
http://206.72.199.179:9992/;stream.nsv

#EXTINF:-1,Quran - radioislamico
http://66.45.232.134:9996/;stream.nsv

и откройте его с помощью ритмбокса

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.