mirror of
https://github.com/krateng/maloja.git
synced 2023-08-10 21:12:55 +03:00
Finally refactored lastfm import
This commit is contained in:
parent
dbc23ca73c
commit
e50cce28fa
@ -2,7 +2,7 @@ import tarfile
|
|||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
import glob
|
import glob
|
||||||
import os
|
import os
|
||||||
from globalconf import datadir
|
from .globalconf import datadir
|
||||||
|
|
||||||
|
|
||||||
user_files = {
|
user_files = {
|
||||||
|
@ -25,8 +25,17 @@ class CleanerAgent:
|
|||||||
#self.rules_regextitle = [[b,c] for [a,b,c,d] in raw if a=="regextitle"]
|
#self.rules_regextitle = [[b,c] for [a,b,c,d] in raw if a=="regextitle"]
|
||||||
# TODO
|
# TODO
|
||||||
|
|
||||||
|
#self.plugin_artistparsers = []
|
||||||
|
#self.plugin_titleparsers = []
|
||||||
|
#if settings.get_settings("USE_PARSE_PLUGINS"):
|
||||||
|
# for ep in pkg_resources.iter_entry_points(group='maloja.artistparsers'):
|
||||||
|
# self.plugin_artistparsers.append(ep.load())
|
||||||
|
# for ep in pkg_resources.iter_entry_points(group='maloja.titleparsers'):
|
||||||
|
# self.plugin_titleparsers.append(ep.load())
|
||||||
|
|
||||||
|
|
||||||
# we always need to be able to tell if our current database is made with the current rules
|
# we always need to be able to tell if our current database is made with the current rules
|
||||||
self.checksums = utilities.checksumTSV("rules")
|
self.checksums = utilities.checksumTSV(datadir("rules"))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -125,9 +134,12 @@ class CleanerAgent:
|
|||||||
|
|
||||||
for s in settings.get_settings("REMOVE_FROM_TITLE"):
|
for s in settings.get_settings("REMOVE_FROM_TITLE"):
|
||||||
if s in t:
|
if s in t:
|
||||||
t = t.replace(s,"").strip()
|
t = t.replace(s,"")
|
||||||
|
|
||||||
return t.strip()
|
t = t.strip()
|
||||||
|
#for p in self.plugin_titleparsers:
|
||||||
|
# t = p(t).strip()
|
||||||
|
return t
|
||||||
|
|
||||||
def parseTitleForArtists(self,t):
|
def parseTitleForArtists(self,t):
|
||||||
for d in self.delimiters_feat:
|
for d in self.delimiters_feat:
|
||||||
|
@ -144,10 +144,8 @@ def stop():
|
|||||||
|
|
||||||
def loadlastfm(filename):
|
def loadlastfm(filename):
|
||||||
|
|
||||||
try:
|
if not os.path.exists(filename):
|
||||||
filename = os.path.join(origpath,filename)
|
print("File could not be found.")
|
||||||
except:
|
|
||||||
print("Please specify a file!")
|
|
||||||
return
|
return
|
||||||
|
|
||||||
if os.path.exists(datadir("scrobbles/lastfmimport.tsv")):
|
if os.path.exists(datadir("scrobbles/lastfmimport.tsv")):
|
||||||
@ -157,7 +155,9 @@ def loadlastfm(filename):
|
|||||||
else:
|
else:
|
||||||
return
|
return
|
||||||
print("Please wait...")
|
print("Please wait...")
|
||||||
os.system("python3 -m maloja.lastfmconverter " + filename + " " + datadir("scrobbles/lastfmimport.tsv"))
|
from .lastfmconverter import convert
|
||||||
|
convert(filename,datadir("scrobbles/lastfmimport.tsv"))
|
||||||
|
#os.system("python3 -m maloja.lastfmconverter " + filename + " " + datadir("scrobbles/lastfmimport.tsv"))
|
||||||
print("Successfully imported your Last.FM scrobbles!")
|
print("Successfully imported your Last.FM scrobbles!")
|
||||||
|
|
||||||
def direct():
|
def direct():
|
||||||
|
@ -1,17 +1,23 @@
|
|||||||
import sys, os, datetime, re, cleanup
|
import os, datetime, re
|
||||||
from .cleanup import *
|
from .cleanup import *
|
||||||
from .utilities import *
|
from .utilities import *
|
||||||
|
|
||||||
|
|
||||||
log = open(sys.argv[1])
|
|
||||||
outputlog = open(sys.argv[2],"w")
|
|
||||||
checksumfile = open(sys.argv[2] + ".rulestate","w") #this file stores an identifier for all rules that were in place when the corresponding file was created
|
|
||||||
|
|
||||||
|
|
||||||
c = CleanerAgent()
|
c = CleanerAgent()
|
||||||
stamps = [99999999999999]
|
|
||||||
|
|
||||||
for l in log:
|
|
||||||
|
|
||||||
|
def convert(input,output):
|
||||||
|
|
||||||
|
log = open(input,"r")
|
||||||
|
outputlog = open(output,"w")
|
||||||
|
checksumfile = open(output + ".rulestate","w") #this file stores an identifier for all rules that were in place when the corresponding file was created
|
||||||
|
|
||||||
|
stamps = [99999999999999]
|
||||||
|
|
||||||
|
for l in log:
|
||||||
l = l.replace("\n","")
|
l = l.replace("\n","")
|
||||||
data = l.split(",")
|
data = l.split(",")
|
||||||
|
|
||||||
@ -56,8 +62,8 @@ for l in log:
|
|||||||
outputlog.write(entry)
|
outputlog.write(entry)
|
||||||
outputlog.write("\n")
|
outputlog.write("\n")
|
||||||
|
|
||||||
checksumfile.write(c.checksums)
|
checksumfile.write(c.checksums)
|
||||||
|
|
||||||
log.close()
|
log.close()
|
||||||
outputlog.close()
|
outputlog.close()
|
||||||
checksumfile.close()
|
checksumfile.close()
|
||||||
|
Loading…
Reference in New Issue
Block a user