210 lines
6.0 KiB
Python
210 lines
6.0 KiB
Python
#!/usr/bin/env python
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
https://gist.github.com/blacktwin/4ccb79c7d01a95176b8e88bf4890cd2b
|
|
"""
|
|
from __future__ import print_function
|
|
|
|
from plexapi.server import PlexServer
|
|
import random
|
|
import re
|
|
|
|
baseurl = 'http://localhost:32400'
|
|
token = 'xxxxx'
|
|
plex = PlexServer(baseurl, token)
|
|
|
|
|
|
LIBRARIES_LST = ['Movies', 'TV Shows']
|
|
|
|
|
|
def sylco(word):
|
|
# pulled from https://github.com/eaydin/sylco/blob/master/sylco.py
|
|
word = word.lower()
|
|
|
|
# exception_add are words that need extra syllables
|
|
# exception_del are words that need less syllables
|
|
|
|
exception_add = ['serious', 'crucial']
|
|
exception_del = ['fortunately', 'unfortunately']
|
|
|
|
co_one = ['cool', 'coach', 'coat', 'coal', 'count', 'coin', 'coarse', 'coup', 'coif', 'cook', 'coign', 'coiffe',
|
|
'coof', 'court']
|
|
co_two = ['coapt', 'coed', 'coinci']
|
|
|
|
pre_one = ['preach']
|
|
|
|
syls = 0 # added syllable number
|
|
disc = 0 # discarded syllable number
|
|
|
|
# 1) if letters < 3 : return 1
|
|
if len(word) <= 3:
|
|
syls = 1
|
|
return syls
|
|
|
|
# 2) if doesn't end with "ted" or "tes" or "ses" or "ied" or "ies", discard "es" and "ed" at the end.
|
|
# if it has only 1 vowel or 1 set of consecutive vowels, discard. (like "speed", "fled" etc.)
|
|
|
|
if word[-2:] == "es" or word[-2:] == "ed":
|
|
doubleAndtripple_1 = len(re.findall(r'[eaoui][eaoui]', word))
|
|
if doubleAndtripple_1 > 1 or len(re.findall(r'[eaoui][^eaoui]', word)) > 1:
|
|
if word[-3:] == "ted" or \
|
|
word[-3:] == "tes" or \
|
|
word[-3:] == "ses" or \
|
|
word[-3:] == "ied" or \
|
|
word[-3:] == "ies":
|
|
pass
|
|
else:
|
|
disc += 1
|
|
|
|
# 3) discard trailing "e", except where ending is "le"
|
|
|
|
le_except = ['whole', 'mobile', 'pole', 'male', 'female', 'hale', 'pale', 'tale', 'sale', 'aisle', 'whale', 'while']
|
|
|
|
if word[-1:] == "e":
|
|
if word[-2:] == "le" and word not in le_except:
|
|
pass
|
|
|
|
else:
|
|
disc += 1
|
|
|
|
# 4) check if consecutive vowels exists, triplets or pairs, count them as one.
|
|
|
|
doubleAndtripple = len(re.findall(r'[eaoui][eaoui]', word))
|
|
tripple = len(re.findall(r'[eaoui][eaoui][eaoui]', word))
|
|
disc += doubleAndtripple + tripple
|
|
|
|
# 5) count remaining vowels in word.
|
|
numVowels = len(re.findall(r'[eaoui]', word))
|
|
|
|
# 6) add one if starts with "mc"
|
|
if word[:2] == "mc":
|
|
syls += 1
|
|
|
|
# 7) add one if ends with "y" but is not surrouned by vowel
|
|
if word[-1:] == "y" and word[-2] not in "aeoui":
|
|
syls += 1
|
|
|
|
# 8) add one if "y" is surrounded by non-vowels and is not in the last word.
|
|
|
|
for i, j in enumerate(word):
|
|
if j == "y":
|
|
if (i != 0) and (i != len(word) - 1):
|
|
if word[i - 1] not in "aeoui" and word[i + 1] not in "aeoui":
|
|
syls += 1
|
|
|
|
# 9) if starts with "tri-" or "bi-" and is followed by a vowel, add one.
|
|
|
|
if word[:3] == "tri" and word[3] in "aeoui":
|
|
syls += 1
|
|
|
|
if word[:2] == "bi" and word[2] in "aeoui":
|
|
syls += 1
|
|
|
|
# 10) if ends with "-ian", should be counted as two syllables, except for "-tian" and "-cian"
|
|
|
|
if word[-3:] == "ian":
|
|
# and (word[-4:] != "cian" or word[-4:] != "tian") :
|
|
if word[-4:] == "cian" or word[-4:] == "tian":
|
|
pass
|
|
else:
|
|
syls += 1
|
|
|
|
# 11) if starts with "co-" and is followed by a vowel, check if exists in the double syllable dictionary, if not, check if in single dictionary and act accordingly.
|
|
|
|
if word[:2] == "co" and word[2] in 'eaoui':
|
|
|
|
if word[:4] in co_two or word[:5] in co_two or word[:6] in co_two:
|
|
syls += 1
|
|
elif word[:4] in co_one or word[:5] in co_one or word[:6] in co_one:
|
|
pass
|
|
else:
|
|
syls += 1
|
|
|
|
# 12) if starts with "pre-" and is followed by a vowel, check if exists in the double syllable dictionary, if not, check if in single dictionary and act accordingly.
|
|
|
|
if word[:3] == "pre" and word[3] in 'eaoui':
|
|
if word[:6] in pre_one:
|
|
pass
|
|
else:
|
|
syls += 1
|
|
|
|
# 13) check for "-n't" and cross match with dictionary to add syllable.
|
|
|
|
negative = ["doesn't", "isn't", "shouldn't", "couldn't", "wouldn't"]
|
|
|
|
if word[-3:] == "n't":
|
|
if word in negative:
|
|
syls += 1
|
|
else:
|
|
pass
|
|
|
|
# 14) Handling the exceptional words.
|
|
|
|
if word in exception_del:
|
|
disc += 1
|
|
|
|
if word in exception_add:
|
|
syls += 1
|
|
|
|
# calculate the output
|
|
return numVowels - disc + syls
|
|
|
|
|
|
def check_roman(word):
|
|
roman_pattern = r"^M{0,3}(CM|CD|D?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})$"
|
|
|
|
if (re.search(roman_pattern, word.strip(), re.I)):
|
|
# print(word)
|
|
return True
|
|
else:
|
|
# print(word)
|
|
return False
|
|
|
|
|
|
def ran_words(sections_lst):
|
|
word_site = [line.split() for line in sections_lst]
|
|
WORDS = [item for sublist in word_site for item in sublist]
|
|
|
|
ran_word = random.choice(WORDS)
|
|
ran_word = ''.join(e for e in ran_word if e.isalpha() and not check_roman(ran_word))
|
|
sy_cnt = sylco(ran_word)
|
|
word_cnt = {ran_word: sy_cnt}
|
|
return word_cnt
|
|
|
|
|
|
def hi_build(sections_lst, cnt):
|
|
dd = ran_words(sections_lst)
|
|
while sum(dd.values()) < cnt:
|
|
try:
|
|
up = ran_words(sections_lst)
|
|
dd.update(up)
|
|
if sum(dd.values()) == cnt:
|
|
return [dd]
|
|
else:
|
|
if sum(dd.values()) > cnt:
|
|
dd = {}
|
|
except Exception:
|
|
pass
|
|
return [dd]
|
|
|
|
|
|
sections_lst = []
|
|
for x in LIBRARIES_LST:
|
|
sections = plex.library.section(x).all()
|
|
sections_lst += [section.title for section in sections]
|
|
|
|
m_lst = hi_build(sections_lst, 5) + hi_build(sections_lst, 7) + hi_build(sections_lst, 5)
|
|
# to see word and syllable count uncomment below print.
|
|
# print(m_lst)
|
|
|
|
stanz1 = ' '.join(m_lst[0].keys())
|
|
stanz2 = ' '.join(m_lst[1].keys())
|
|
stanz3 = ' '.join(m_lst[2].keys())
|
|
|
|
lines = stanz1, stanz2, stanz3
|
|
lines = '\n'.join(lines)
|
|
print('')
|
|
print(lines.lower())
|
|
print('')
|