Skip to content

Seasons, absolute mode, Subfolders and plexignore support...

Notifications You must be signed in to change notification settings

saedo/Absolute-Series-Scanner

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 

Repository files navigation

#Absolute Series Scanner

The Plex Scanner will make the video files showing in Plex, if not showing in Plex, it is a scanner issue. A Plex series scanner choose the following from the folders and file names:

  • Serie name
  • Season number
  • Episode number
  • Episode title (not filled by plex default series scanner, until the metadata agent refreshes it)
  • Episode year

The Plex metadata agent will find metadata (Serie Title, summary year, episode title, summary, posters, fanart, tags, ... ) for files showing in Plex. Anything missing there while the file shows up in Plex is an Agent issue, refer to the Agent readme here: https://github.com/ZeroQI/Hama.bundle/blob/master/README.md

###Which Metadata/Title source to select?

  • Anime: AniDB.net, Hama use an offline title database from them ("main title" is the best, or romaji "x-jat". "En" titles have hoorrors like "bombshells from the sky" for "Asobi ni Iku yo!" serie). AniDB use small posters, no background. Hama use ScudLee's xml mapping files to crosss reference the anidb id to the tvdb series
  • TV Series: TheTVDB.com or TVrage or TheMovieDB (yep support series now), no db site will store (DVD) boxset specific files (nor sport or porn for tvdb). TVDB has high resolution posters, background images, screenshots, and episodes summaries, all lacking from AniBD.net, but they do not carry porn series so no metadata for this type. TheTVDB uses seasons which can be practical for long anime.
  • Movies: TheMovieDB.org, naming convention: "Movie Title (Year).ext"

###File Naming Conventions This scanner supports absolute and season numbering, but here are two references for guidelines

Grouping folder

  • If you use "Grouping folder / Show Name / Season 1 / Show Name e01.ext" convention from the root, it will now be skipped. You can just add it as additionnal root folder in the library: "D:/Anime/Dragon Ball/" for "D:/Anime/Dragon Ball/[2] Dragon Ball Z" folder for example...

Series

  • Specials chars handling ("CØDE:BREAKER") and files starting with dots (".Hack")
  • Movie files in Series libraries accepted if they are in a folder with the same name (or 01|ep 01|s01e01, or " - Complete Movie" at the end)

Season folders

  • Seasons folders can have serie name afterwards ("Zero no tsukaima / Season 1 Zero no tsukaima")
  • Files in "Extras" folders will be ignored.
  • Allow grouping in Ark xxxxx folders transparently with seasons folders inside, or within a season folder
  • Specials go in "Specials" or "Season 0" folders.
    • Single seasons series will follow anidb specials numbering (unless specific tvdb guid forced).
    • Multiple seasons series will follow tvdb specials numbering
    • You can use Anidb numbering for specials (OP1a, NCOP, etc...) or explicitely label them as follow (s00e101, etc...).
    • Include all files not recognised as Season 0 episode 501+

Files

File naming convention Template / Folder Exemple
Splitting folders: 0-9 0-9, A,...,Z folder. Add EACH as folder. Do not use the parent folder
Episode Name Pattern: Season %S/%SN s%0Se%0E Season 2/Show Name s02e03.ext
Multi-Episode style: Extend Season 2/Show Name s02e03-05.ext
Multi-part episodes: cdX, discX, diskX, dvdX, partX, ptX Season 2/Show Name s02e03 - pt1.ext
Multi-Media Version: Movie Name (year) - 1080p.ext Movie Name (year) - 1080p.ext
Specials scrapped: Specials, Season 0 s00e01/OP1/Ed3a/NCOP/S01/S1.ext
Other non scrapped: Extras Extras/Show Name xxxx.ext
BD rips /path/to/series-library/Series Name Season 2 Series.Name.Disc1.S02.E01-E12/BDMV/STREAM

Local metadata It is supported but through "local media assets" agent, add it and and put it before HAMA in the priority order.
https://support.plex.tv/hc/en-us/articles/200220717-Local-Media-Assets-TV-Shows

Data type Source Comment
fanart art/backdrop/background/fanart-1.ext -1 can be ommited (same level as Video TS)
Serie poster Serie folder: Show name-1/folder/poster/show.ext (jpg, jpeg, png, tbn)
Season poster Season folder: Season01a.ext (jpg, jpeg, png, tbn)
Banner banner/banner-1.jpg
Theme song theme.mp3
Subtitles file name.ext (srt, smi, ssa, ass)
Plexignore files .plexignore

Specials Hama is a anidb (single season) & tvdb (multiple seasons) agent so either naming convention is fine. It will detect either successfully but you can convert one convention to the other whicle displaying by forcing ids (further down)

Let's use One piece special "Heart of Gold":

TVDB seasons

Anidb (single) season

Anidb type special numbering is detailed below:

Type Internal letter Episode number
OPs C Episodes 101-150
EDs C Episodes 151-200
Trailers T Episodes 201-300
OPs/EDs P Episodes 301-400
Others O Episodes 401-500
unmapped Episodes 501-600

###Forcing the series ID You can specify the guid to use the following way:

  • In custom search serie name by adding " [guid_type-id_number]" at the end
  • In Serie folder name by adding " [guid_type-id_number]" at the end
  • In guid_type.id inside serie folder with the id in it (ex: tvdb.id file with tvdbid "114801" without double quotes in it)

Hama supports the following guid_type:

  • anidb for AniDB.net (and and the behaviour changing mode anibd2)
  • tvdb for TheTVDB.com (and the behaviour changing modes: tvdb2, tvdb3, tvdb4)
  • tmdb For TheMovieDB.net (and the serie part of TheMovieDB: tsdb)
  • imdb For the International Movie DataBase (ids starts with "tt...")

You can have absolutely numbered series (i.e. without season number apart from Specials/season 0) being displayed in Plex with seasons without the need to rename the files with season numbering or creating season folders and moving absolutely numbered episodes inside by using the following custom modes, and episodes will be displayed as:

guid_type Seasons numbering Episodes numbering Use case (example)
anib2 None Absolute Map to the tvdb at the right season and ep number to show 1 serie only
tvdb2 TVDB Season Multiple single season series (Sword Art online)
tvdb3 TVDB Absolute Long series (Detective Conan)
tvdb4 Custom/Arc database Absolute Long series with arc (one piece, dragon ball)

Examples of force guid in all modes and their applications:

When you have all episodes of a series in a single parent folder:

  • " [anidb-xxxxx]" for anime in absolute numbering. Force the anidb serie id
  • " [tvdb-xxxxxx]" for tvdb season numbering. You can put separate anidb series as seasons as per tvdb numbering. SAO can be split at file level into "Season 1 - Sword Art Online" [1-25], "Season 2 - Alfheim & Gun Gale Online [1-25]".
  • " [tvdb2-xxxxx]" for absolute numbering displayed virtually as tvdb numbering, episode number resets to 1 each season, for series like Sword art Online(1-50, will be split into Season 1 [1-25] and Season 2 [1-25])
  • " [tvdb3-xxxxx]" for absolute numbering episodes displayed virtually using tvdb season numbering for long running series like One piece (1-700+, will be split into seasons while keeping the absolute episode number intact without having to create seasons in the real folder
  • " [tvdb4-xxxxx]" for absolute numbering episodes displayed using series arc as season for long running series with arcs like Dragon Ball Kai, or separated anidb series considered as half seasons by thetvdb (like 'Seraph of the end' numbered 1-24 splitted into 2 seasons). The arc definition to split into seasons the absolute numbering is done using the following order:
    • Seasons folders manually created by the user with absolute numbered episodes inside (seasons already mapped manually)
    • in a local "tvdb.mapping" file inside serie folder FORMAT: <season_num>|<starting_ep_num>|<ending_ep_num>|<freeform_text_naming_the_season>(optional)
    • without doing anything using the online arc database github tvdb4.mapping.xml Format:
      <tvdb4entries>
      <anime tvdbid="289906" name="Seraph of the End">
      01|001|012|Vampire Reign
      02|013|024|Battle in Nagoya
      </anime>
      

Advanced modes for when you have episodes of a series in SEPARATE parent folders but want them to show as a single series in Plex:

  • " [anidb2-xxxxx]"

    • will find the season & eposide offset defiend in the ScudLee file and add into Plex with it's corresponding TVDB series/season/episode numbers
  • " [tvdb/2/3/4-xxxxx-sY]"

    • episode numbers found in the files are left alone and added to season Y
  • " [tvdb/2/3/4-xxxxx-eZ]"

    • episode numbers found in the files are adjusted (epNum+Z-1)
  • " [tvdb/2/3/4-xxxxx-sYeZ]"

    • episode numbers found in the files are adjusted (epNum+Z-1) and added to season Y
    • Z is the offset for the episodes in season Y for when we want it to start mid tvdb season
  • !!IMPORTANT NOTES FOR ADVANCED MODES!!

    • When defining you modes on your folders:
      • If you don't use the same mode or compatible modes for all separate folders for a series, you will run into issues.
        • "anidb2", "tvdb", & "tvdb2" will work together
      • You might have to manually merge Plex series if "anidb2"/"tvdb2" or "tvdb"/"tvdb2" are both used.
      • "anidb2"/"tvdb" should automatically merge (but Plex is not perfect so you still might have to manually merge)
      • "tvdb3" will not work correctly with any other modes so all folders of a series will have to have this mode
      • "tvdb4" will not work correctly with any other modes so all folders of a series will have to have this mode

    Examples:

    
    == Example 1 ==
    Bakuman [anidb2-7251]       =  Bakuman [tvdb-193811-s1]      = Bakuman [tvdb-193811]
    Bakuman 2011 [anidb2-8150]  =  Bakuman 2011 [tvdb-193811-s2]
    Bakuman 2012 [anidb2-8836]  =  Bakuman 2012 [tvdb-193811-s3]
    == Example 2 ==
    "Sailor Moon Crystal [tvdb2-275039]"
    "Sailor Moon Crystal Season 3 [anidb2-11665]"  (or "[tvdb-275039-s3]" or "[tvdb2-275039-s3]")
    == Example 3 ==
    "Bleach [tvdb3-74796]"
    "Bleach movie 1 Memories in the Rain [tvdb3-74796-s0e3]"
    "Bleach movie 2 The Diamond Dust Rebellion [tvdb3-74796-s0e4]"
    == Example 4 ==
    https://github.com/ZeroQI/Absolute-Series-Scanner/blob/master/tvdb4.mapping.xml
    <anime tvdbid="79604" name="Black Lagoon">
    01|001|012|The First Barrage
    02|013|024|The Second Barrage
    03|025|029|Roberta's Blood Trail
    </anime>
    "Black Lagoon [tvdb4-79604]"  (or "[tvdb4-79604-s1]")
    "Black Lagoon - The Second Barrage [tvdb4-79604-s2]"
    "Black Lagoon - Roberta`s Blood Trail [tvdb4-79604-s3]"
    

Install

Put latest scanner file from:

###Logs Absolute series Scanner uses a pre-made list of folders to try to locate Plex Logs folder. If custom logs are not present, then either you created a library using default Plex scanner and not my "Absolute Series Scanner" or you have an unknown Logs folder location and will need to forward me the path to add in the source code... If the scanner crash, you will get either no files (library creation) or no change (library already created) and will need to attach the Plex log "Plex Media Scanner.log"

List of logs files:

  • Plex Media Scanner (custom ASS) - Library_Name.log contain all folders and files processed in a readable fashion, perfect for troubleshooting scanner issues.
  • Plex Media Scanner (custom ASS) - Library_Name - filelist Root_Folder_name.log contain all files in the root folder, so i can re-create your library with zero size files. I use a batch file to recreate a user's library after converting to utf-8 with notepad
  • Plex Media Scanner.log - Standard Plex Scanner Log, contain crash error in case of a bug in the scanner code

List of configuration files, to put in logs folder, can be found the (blank) config files in GitHub > ASS > releases > logs.7z

Troubleshooting:

If the scanner not listed in scanner list:

  • Make sure you did not create a movie library, as it will mot show a SERIES scanner....
  • check size and open file to check for corruption
  • If you have HTML tags at the beginning you saved the scanner file wrong and should feel bad

On windows install https://www.microsoft.com/en-us/download/details.aspx?id=5555 if you experience this error:


Jul 23, 2016 12:55:54.558 [5288] ERROR - Error scanning directory .
Jul 23, 2016 12:55:54.574 [5288] ERROR - No module in Absolute Series Scanner
Jul 23, 2016 12:55:54.574 [5288] ERROR - Error in Python: Looking up module:
Traceback (most recent call last):
File "C:\Users\Administrator\AppData\Local\Plex Media Server\Scanners\Series\Absolute Series Scanner.py", line 8, in 
from lxml import etree # fromstring
ImportError: DLL load failed: The specified module could not be found.

On linux, permissions issues could prevent the scanner execution. Check hama readme for commands and posts the ones not documented if any.

If you have these or similar symptoms (or others):

  • nothing is scanned
  • episodes are missing
  • Series are missing
  • library doesn't add new content (after scanner update) then most likelly the scanner is crashing and revert any changed to the library

Include the following logs (in any case, specify if file not present):

  • [...]/Plex Media Server/Logs/Plex Media Scanner.log (scanner crash info)
  • [...]/Plex Media Server/Logs/Plex Media Scanner (custom ASS).log (episodes info)
  • [...]/Plex Media Server/Logs/Plex Media Scanner (custom ASS) filelist.log (library file list)

And post in:

###Folder Structure for massive storages I thought my folder structure could help many, you can store anything in htere Implied is original language, folder named dubbed otherwise

  • Series

    • Xx (En/Fr/Sp/Jap sub En/...)
    • Xx Reality-Shows
    • Xx Stand-Up Comedy
    • Xx Dubbed
  • Movies

    • Xx (En/Fr/Sp/Jap sub En/...)
    • Xx Reality-Shows
    • Xx Stand-Up Comedy
  • Anime

    • Xx (Jap sub En)
    • Xx Movies (En/Fr/...)
    • Xx Series (En/Fr/...)
  • Knowledge

    • Documentaries
    • Hobbies
    • Litterature
    • Trainings
  • Music

    • Albums [\Group\Album (Year)]

    • Compilations

    • Soundtracks

      • Ads
      • Anime
      • Movies
      • Series
    • Videos

      • Xx
      • Xx Concerts
    • Games

      • Karaoke
      • Guitar
      • DDR
    • Pictures

      • Wallpapers
      • Maps
      • Textures
    • Scans

      • Art Books
      • Xx Comics
      • Xx Mangas
    • Software

      • Computer
        • 1977 Apple II
        • Linux
        • Mac-OS
        • Synology DSM
        • Windows
      • Console Cartridge
      • Console CD
      • Console DVD
      • Handheld
      • Multi-Systems (Mame, Mess)
      • Phone

###Japanese Media Manager It uses anidb as source and uses hash info from file to determine what the show is (release included) and where it goes. So this means that shows like SOA/Fate stay night..etc are all in there own folder for each part of the series. Movies are also in there own folder since anidb treats every movie as its own show. http://jmediamanager.org/jmm-desktop/utilities/file-renaming/

Renaming Script:

IF I(eng) DO ADD '%eng'
IF I(ann);I(!eng) DO ADD '%ann'
DO REPLACE '[' ''
DO REPLACE ']' ''
IF T(!Movie);H(!S);T(!OVA) DO ADD ' - %enr - '
IF H(S),T(OVA),T(Movie) DO ADD ' - %enr - '
DO ADD '%epr '
DO ADD '[%grp]'

// Replace all illegal file name characters DO REPLACE '<' '(' DO REPLACE '>' ')' DO REPLACE ':' ' -' DO REPLACE '"' '`' DO REPLACE '/' '-' DO REPLACE '' '' DO REPLACE '|' '' DO REPLACE '?' '' DO REPLACE '*' '+' //DO REPLACE 'S0' '0' DO REPLACE '[%grp]' ''

###Batch file to create filelist.txt or re-create a library from the filelist with 0 size files

@ECHO OFF
REM 1 - if no filelist create filelist no folders
REM 2 - if file there restore
chcp 1252>nul

IF EXIST filelist.txt goto RESTORE ECHO Press Enter to create listfile.txt containing all files relative path rundll32 user32.dll,MessageBeep -1 PAUSE SETLOCAL DisableDelayedExpansion SET "r=%CD%" type nul > filelist.txt FOR /R . %%F IN (*) DO ( SET "p=%%F" SETLOCAL EnableDelayedExpansion ECHO(!p:%r%=! ENDLOCAL ) >> filelist.txt ECHO [filelist.txt] created list rundll32 user32.dll,MessageBeep -1 GOTO EXIT

:RESTORE ECHO Press enter to create all dummy files from filelist.txt rundll32 user32.dll,MessageBeep -1 PAUSE rem for /f "tokens=2 delims=:." %%x in ('chcp') do set cp=%%x rem chcp 437>nul

REM IMPORTANT LOOP DOING ALL THE WORK for /f "tokens=*" %%a in (filelist.txt) do ( IF NOT EXIST "%%~pa" mkdir "%%~pa" IF NOT EXIST "%%a" TYPE nul > "%%a" ) rem chcp %cp%>nul ECHO [filelist.txt] processed, blank files created rundll32 user32.dll,MessageBeep -1 GOTO EXIT

:EXIT ECHO Finished! PAUSE

###Task list

  • Support Media stubs .Disc files ? http://kodi.wiki/view/Media_stubs
  • Shall i write a Movie scanner using the same code? The Plex default movie scanner does an good job i believe ?

Reference: Link to Markdown or https://help.github.com/articles/basic-writing-and-formatting-syntax/

About

Seasons, absolute mode, Subfolders and plexignore support...

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%