Merge remote-tracking branch 'lastfm/master'
This commit is contained in:
commit
4d02714b81
2 changed files with 56 additions and 0 deletions
17
fill_influxdb.py
Executable file
17
fill_influxdb.py
Executable file
|
@ -0,0 +1,17 @@
|
|||
#!/usr/bin/env python3
|
||||
# pip install influxdb
|
||||
from influxdb import InfluxDBClient # type: ignore
|
||||
from my.lastfm import get_scrobbles
|
||||
|
||||
|
||||
def main():
|
||||
scrobbles = get_scrobbles()
|
||||
client = InfluxDBClient()
|
||||
# TODO client.create_database('lastfm')
|
||||
|
||||
jsons = [{"measurement": 'scrobble', "tags": {}, "time": str(sc.dt), "fields": {"name": sc.track}} for sc in scrobbles]
|
||||
client.write_points(jsons, database='lastfm')
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
main()
|
39
lastfm/__init__.py
Executable file
39
lastfm/__init__.py
Executable file
|
@ -0,0 +1,39 @@
|
|||
#!/usr/bin/env python3
|
||||
from functools import lru_cache
|
||||
from typing import Dict, List, NamedTuple
|
||||
from datetime import datetime
|
||||
from pathlib import Path
|
||||
import os
|
||||
import json
|
||||
|
||||
import pytz
|
||||
|
||||
_PATH = Path("/L/backups/lastfm")
|
||||
|
||||
class Scrobble(NamedTuple):
|
||||
dt: datetime
|
||||
track: str
|
||||
|
||||
|
||||
# TODO memoise...?
|
||||
|
||||
# TODO watch out, if we keep the app running it might expire
|
||||
def _iter_scrobbles():
|
||||
last = max(_PATH.glob('*.json'))
|
||||
# TODO mm, no timezone? wonder if it's UTC...
|
||||
j = json.loads(last.read_text())
|
||||
|
||||
for d in j:
|
||||
ts = int(d['date'])
|
||||
dt = datetime.fromtimestamp(ts, tz=pytz.utc)
|
||||
track = f"{d['artist']} — {d['name']}"
|
||||
yield Scrobble(dt, track)
|
||||
|
||||
|
||||
@lru_cache(1)
|
||||
def get_scrobbles():
|
||||
return list(_iter_scrobbles())
|
||||
|
||||
|
||||
def test():
|
||||
assert len(get_scrobbles()) > 1000
|
Loading…
Add table
Reference in a new issue