107 lines
3.1 KiB
Python
107 lines
3.1 KiB
Python
from .symbology_object import SymbologyObject
|
|
|
|
class Symbology(SymbologyObject):
|
|
"""
|
|
/symbology
|
|
|
|
Positional arguments:
|
|
No arguments are required.
|
|
|
|
Optional arguments:
|
|
All arguments are inherited from SymbologyObject
|
|
|
|
Attributes:
|
|
object : str . Returns the type of object it is. (card, error, etc)
|
|
has_more : bool . True if there are more pages to the object.
|
|
data : list . A list of all data returned.
|
|
data_length : int . The length of the data returned.
|
|
|
|
The following require an integer as an arg, which acts as a tuple.
|
|
symbol_symbol(num) : str . The plaintext symbol, usually written with curly braces.
|
|
symbol_loose_variant(num) : str . The alternate version of the symbol, without curly braces.
|
|
symbol_transposable(num): bool . True if it's possibly to write the symbol backwards.
|
|
symbol_represents_mana(num): bool . True if this is a mana symbol.
|
|
symbol_cmc(num): float . The total converted mana cost of the symbol.
|
|
symbol_appears_in_mana_costs(num): bool . True if the symbol appears on the mana cost of any card.
|
|
symbol_funny(num): bool . True if the symbol is featured on any funny cards.
|
|
symbol_colors(num): float . An array of all colors in the given symbol.
|
|
|
|
Example usage:
|
|
>>> symbol = scrython.symbology.Symbology()
|
|
"""
|
|
def __init__(self):
|
|
self.url = 'symbology?'
|
|
super(Symbology, self).__init__(self.url)
|
|
|
|
def _checkForKey(self, key):
|
|
try:
|
|
return self.scryfallJson[key]
|
|
except Exception:
|
|
raise KeyError('This object ahs no key \'{}\''.format(key))
|
|
|
|
def _checkForTupleKey(self, parent, num, key):
|
|
try:
|
|
return self.scryfallJson[parent][num][key]
|
|
except Exception:
|
|
raise KeyError('This object has no key \'{}\''.format(key))
|
|
|
|
def object(self):
|
|
self._checkForKey('object')
|
|
|
|
return self.scryfallJson['object']
|
|
|
|
def has_more(self):
|
|
self._checkForKey('has_more')
|
|
|
|
return self.scryfallJson['has_more']
|
|
|
|
def data(self):
|
|
self._checkForKey('has_more')
|
|
|
|
return self.scryfallJson['data']
|
|
|
|
def data_length(self):
|
|
self._checkForKey('data')
|
|
|
|
return len(self.scryfallJson['data'])
|
|
|
|
def symbol_symbol(self, num):
|
|
self._checkForTupleKey('data', num, 'symbol')
|
|
|
|
return self.scryfallJson['data'][num]['symbol']
|
|
|
|
def symbol_loose_variant(self, num):
|
|
self._checkForTupleKey('data', num, 'loose_variant')
|
|
|
|
return self.scryfallJson['data'][num]['loose_variant']
|
|
|
|
def symbol_transposable(self, num):
|
|
self._checkForTupleKey('data', num, 'transposable')
|
|
|
|
return self.scryfallJson['data'][num]['transposable']
|
|
|
|
def symbol_represents_mana(self, num):
|
|
self._checkForTupleKey('data', num, 'represents_mana')
|
|
|
|
return self.scryfallJson['data'][num]['represents_mana']
|
|
|
|
def symbol_cmc(self, num):
|
|
self._checkForTupleKey('data', num, 'cmc')
|
|
|
|
return self.scryfallJson['data'][num]['cmc']
|
|
|
|
def symbol_appears_in_mana_costs(self, num):
|
|
self._checkForTupleKey('data', num, 'appears_in_mana_costs')
|
|
|
|
return self.scryfallJson['data'][num]['appears_in_mana_costs']
|
|
|
|
def symbol_funny(self, num):
|
|
self._checkForTupleKey('data', num, 'funny')
|
|
|
|
return self.scryfallJson['data'][num]['funny']
|
|
|
|
def symbol_colors(self, num):
|
|
self._checkForTupleKey('data', num, 'colors')
|
|
|
|
return self.scryfallJson['data'][num]['colors']
|