mirror of
https://github.com/283375/arcaea-offline.git
synced 2025-07-03 21:26:26 +00:00
refactor: chart info database importer
This commit is contained in:
@ -1,3 +0,0 @@
|
||||
from .parser import ChartInfoDbParser
|
||||
|
||||
__all__ = ["ChartInfoDbParser"]
|
@ -1,35 +0,0 @@
|
||||
import contextlib
|
||||
import sqlite3
|
||||
from typing import List
|
||||
|
||||
from sqlalchemy.orm import Session
|
||||
|
||||
from ...models.songs import ChartInfo
|
||||
|
||||
|
||||
class ChartInfoDbParser:
|
||||
def __init__(self, filepath):
|
||||
self.filepath = filepath
|
||||
|
||||
def parse(self) -> List[ChartInfo]:
|
||||
results = []
|
||||
with sqlite3.connect(self.filepath) as conn:
|
||||
with contextlib.closing(conn.cursor()) as cursor:
|
||||
db_results = cursor.execute(
|
||||
"SELECT song_id, rating_class, constant, notes FROM charts_info"
|
||||
).fetchall()
|
||||
for result in db_results:
|
||||
chart = ChartInfo(
|
||||
song_id=result[0],
|
||||
rating_class=result[1],
|
||||
constant=result[2],
|
||||
notes=result[3] or None,
|
||||
)
|
||||
results.append(chart)
|
||||
|
||||
return results
|
||||
|
||||
def write_database(self, session: Session):
|
||||
results = self.parse()
|
||||
for result in results:
|
||||
session.merge(result)
|
42
src/arcaea_offline/external/importers/chart_info_database.py
vendored
Normal file
42
src/arcaea_offline/external/importers/chart_info_database.py
vendored
Normal file
@ -0,0 +1,42 @@
|
||||
import sqlite3
|
||||
from contextlib import closing
|
||||
from typing import List, overload
|
||||
|
||||
from arcaea_offline.constants.enums.arcaea import ArcaeaRatingClass
|
||||
from arcaea_offline.database.models.v5 import ChartInfo
|
||||
|
||||
|
||||
class ChartInfoDatabaseParser:
|
||||
@classmethod
|
||||
@overload
|
||||
def parse(cls, conn: sqlite3.Connection) -> List[ChartInfo]: ...
|
||||
|
||||
@classmethod
|
||||
@overload
|
||||
def parse(cls, conn: sqlite3.Cursor) -> List[ChartInfo]: ...
|
||||
|
||||
@classmethod
|
||||
def parse(cls, conn) -> List[ChartInfo]:
|
||||
if isinstance(conn, sqlite3.Connection):
|
||||
with closing(conn.cursor()) as cur:
|
||||
return cls.parse(cur)
|
||||
|
||||
if not isinstance(conn, sqlite3.Cursor):
|
||||
raise ValueError("conn must be sqlite3.Connection or sqlite3.Cursor!")
|
||||
|
||||
db_items = conn.execute(
|
||||
"SELECT song_id, rating_class, constant, notes FROM charts_info"
|
||||
).fetchall()
|
||||
|
||||
results: List[ChartInfo] = []
|
||||
for item in db_items:
|
||||
(song_id, rating_class, constant, notes) = item
|
||||
|
||||
chart_info = ChartInfo()
|
||||
chart_info.song_id = song_id
|
||||
chart_info.rating_class = ArcaeaRatingClass(rating_class)
|
||||
chart_info.constant = constant
|
||||
chart_info.notes = notes
|
||||
|
||||
results.append(chart_info)
|
||||
return results
|
Reference in New Issue
Block a user