สคริปต์ Rhythmbox-Banshee นำเข้าจะโยกย้ายจำนวนการเล่นและการจัดอันดับ ขอบคุณ @xiphosurus อย่างไรก็ตามสำหรับสคริปต์ในการทำงานคุณต้องบอกว่าฐานข้อมูล banshee และ rhythmbox อยู่ที่ใด
กำลังเตรียมสคริปต์
ค้นหา rhythmbox ของคุณและไฟล์ banshee db ตำแหน่งเริ่มต้นจะเป็น:
/home/YOUR_USERNAME/.local/share/rhythmbox/rhythmdb.xml
/home/YOUR_USERNAME/.config/banshee-1/banshee.db
สำรองข้อมูลไว้! ฉันจะพูดอีกครั้ง ทำการสำรองข้อมูล
ตอนนี้คัดลอกไฟล์ banshee.db ลงในโฟลเดอร์เดียวกันกับสคริปต์ rhythmbox-banshee-import จากนั้นปรับเปลี่ยนสคริปต์ rhythmbox-banshee-import ที่บรรทัดบอกว่า:
RB_DB = 'rhythmdb.xml'
ใส่ไฟล์ path / to / your / rhythmboxdb.xml เช่น:
RB_DB = '/home/YOUR_USERNAME/.local/share/rhythmbox/rhythmdb.xml'
ตอนนี้เรียกใช้สคริปต์และจำนวนการเล่นและเพลย์ลิสต์ทั้งหมดจะได้รับการอัปเดต
การแก้ไขปัญหา
ไม่มีโมดูลชื่อ lxml
หากคุณได้รับข้อผิดพลาด... ImportError: No module named lxml ...
คุณต้องติดตั้ง Python Xml Parsers :
sudo apt-get install python-lxml
ปฏิเสธการอนุญาต
หากคุณได้รับ "การอนุญาตที่ถูกปฏิเสธ" อาจเป็นเพราะคุณไม่มีสิทธิ์เพียงพอในการเข้าถึงไฟล์ในไดเรกทอรีของผู้ใช้รายอื่นหรือเนื่องจากไฟล์นั้นไม่สามารถเรียกใช้งานได้ เพื่อให้สามารถเรียกใช้งานได้ให้เรียกใช้:
chmod +x /path/to/your/rhythmbox-banshee-import-script
ภาคผนวก
rhythmbox-banshee-import Script
#!/usr/bin/python
"""
Copyright (c) 2009 Wolfgang Steitz
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software Foundation,
Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
"""
import sys
import sqlite3
from lxml import etree
RB_DB = 'rhythmdb.xml'
BA_DB = 'banshee.db'
class banshee_db():
def __init__(self, file):
self.con = sqlite3.connect(file)
def get_song_info(self, url):
try:
res = self.con.execute('select Rating, Playcount from CoreTracks where uri = ?', (url,) ).fetchone()
if res is None:
return None, None
else:
return res
except:
return None, None
banshee = banshee_db(BA_DB)
tree = etree.parse(RB_DB)
root = tree.getroot()
for song in root:
if song.get("type") == 'song':
rating = None
playcount = None
for attr in song:
if attr.tag == 'location':
location = attr.text
if attr.tag == 'rating':
rating = attr.text
if attr.tag == 'play-count':
playcount = int(attr.text)
song.remove(attr)
rating_banshee, playcount_banshee = banshee.get_song_info(location)
if rating is None:# noch kein rating in db
if not (rating_banshee == 0 or rating_banshee is None):
rating = rating_banshee
if not (playcount_banshee == 0 or playcount_banshee is None):
if playcount is None:
playcount = playcount_banshee
else:
playcount += playcount_banshee
#insert rating into rb db
if rating is not None:
element = etree.Element('rating')
element.text = str(rating)
song.append( element)
#update playcount
if playcount is not None:
element = etree.Element('play-count')
element.text = str(playcount)
song.append( element)
tree.write(RB_DB)