local anime file database with deduplication and sorting
Project description
weltschmerz
Maintain a (local) database for anime files.
Contains scripts to hash and sort anime files,
as well as looking up files in AniDB utilizing the yumemi Python module.
This project is licensed under the terms of the MIT license. These third-party files are included:
pyselect.py: Copyright 2013 Matthew Behrens, under the terms of the MIT license.sorttable.js: Copyright 2007 Stuart Langridge, under the terms of the X11/MIT license.
See also LICENSE.md
Requirements
- Python 3 (>=3.6)
- yumemi Python module (optional, for interacting with AniDB)
- SQL database
- PostgreSQL works, and is recommended
- SQLite3 works, but does not support the
numericcollation, order for T/S/P/O episodes might be wrong
Configuration file
Copy weltschmerz.cfg.example to weltschmerz.cfg or $HOME/.config/weltschmerz/weltschmerz.cfg and adjust as necessary.
Import AniDB MyList export
It is recommended to import your MyList first, as that will populate the Anime, Episode, and File tables.
- Request an
xml-plain-fullexport of your MyList at AniDB - MyList Export - Download export file
- Extract the export file:
tar xf <mylist_export>.tgz - Parse the export and populate the local database:
./parse_mylist_export.py --mylist-xml-files anime/a*.xml
Hash local files
weltschmerz files hash --folder /anime/by-id/00/00/01/ --folder /anime/by-id/00/00/02/
Add files to your AniDB MyList
Lookup the local files in AniDB and add them to your MyList, if they are present in AniDB.
weltschmerz anidb lookup-files --folder /anime/by-id/00 --folder /anime/by-id/01 --debug --online --add-to-mylist --mylist-state 4
Deduplicate local files
Interactively deduplicate local files, as well as set the modified time of duplicate files to the oldest one.
weltschmerz files remove-duplicates --preferred-directory-pattern /anime/by-id
Sort local files
Sort/Move files, this will put the files into folders according to their anime ids (padded to 6 digits) from AniDB.
e.g. files for Seikai no Monshou (anime id 1) will be put in <target_basedir>/by-id/00/00/01.
weltschmerz files sort --source-basedir /anime/unsorted --target-basedir /anime
Create symlinks for local anime folders
To be able to look for local anime by name, create symlinks to point to the folders created by "Sort local files".
This creates a by-name folder under the target basedir.
- Download anime titles dump (XML) from AniDB, see AniDB Wiki - API/Anime Titles for instructions.
- Decompress the title dump:
gunzip anime-titles.xml.gz - Run script to create the symlinks:
./animetitle.py anime-titles.xml /anime/
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file weltschmerz-0.0.9.tar.gz.
File metadata
- Download URL: weltschmerz-0.0.9.tar.gz
- Upload date:
- Size: 20.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4a837be258e40874519a880d421f18afaea00854f163569d8c8669899b30338a
|
|
| MD5 |
84226edd49886b0c273b8cdfe52b2dee
|
|
| BLAKE2b-256 |
70b2e571b6e0e69678bcce83bc82d84839f2ce694c7fca6d04683c9c92b00df8
|
File details
Details for the file weltschmerz-0.0.9-py3-none-any.whl.
File metadata
- Download URL: weltschmerz-0.0.9-py3-none-any.whl
- Upload date:
- Size: 24.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
50452381a0e9c19e90c81391634e474242b466d4d7caa3ef97c92e495c416725
|
|
| MD5 |
ea93049220b79a969dd171bdd689bb93
|
|
| BLAKE2b-256 |
809ad9cad2e1dfb015e1ae312149fa4f17f860ee53e8343fbfaafbc4d53d5308
|