This repository has been archived on 2023-04-13. You can view files and clone it, but cannot push or open issues or pull requests.
CloudBot/plugins/dictionary.py

109 lines
2.9 KiB
Python
Raw Normal View History

2011-11-20 10:23:31 +01:00
import re
from util import hook, http
@hook.command('u')
@hook.command
def urban(inp):
2012-02-28 03:03:43 +01:00
".urban <phrase> -- Looks up <phrase> on urbandictionary.com."
2011-11-20 10:23:31 +01:00
url = 'http://www.urbandictionary.com/iphone/search/define'
page = http.get_json(url, term=inp)
defs = page['list']
2011-11-20 10:23:31 +01:00
if page['result_type'] == 'no_results':
2012-02-24 04:17:59 +01:00
return 'Not found.'
2011-11-20 10:23:31 +01:00
out = defs[0]['word'] + ': ' + defs[0]['definition']
2011-11-20 10:23:31 +01:00
if len(out) > 400:
out = out[:out.rfind(' ', 0, 400)] + '...'
return out
2012-02-29 09:29:53 +01:00
2011-11-20 10:23:31 +01:00
# define plugin by GhettoWizard & Scaevolus
@hook.command('dictionary')
@hook.command
def define(inp):
2012-02-28 03:03:43 +01:00
".define <word> -- Fetches definition of <word>."
2011-11-20 10:23:31 +01:00
url = 'http://ninjawords.com/'
h = http.get_html(url + http.quote_plus(inp))
definition = h.xpath('//dd[@class="article"] | '
'//div[@class="definition"] |'
'//div[@class="example"]')
if not definition:
return 'No results for ' + inp + ' :('
def format_output(show_examples):
result = '%s: ' % h.xpath('//dt[@class="title-word"]/a/text()')[0]
correction = h.xpath('//span[@class="correct-word"]/text()')
if correction:
2012-02-24 04:17:59 +01:00
result = 'Definition for "%s": ' % correction[0]
2011-11-20 10:23:31 +01:00
sections = []
for section in definition:
if section.attrib['class'] == 'article':
sections += [[section.text_content() + ': ']]
elif section.attrib['class'] == 'example':
if show_examples:
sections[-1][-1] += ' ' + section.text_content()
else:
sections[-1] += [section.text_content()]
for article in sections:
result += article[0]
if len(article) > 2:
result += ' '.join('%d. %s' % (n + 1, section)
for n, section in enumerate(article[1:]))
else:
result += article[1] + ' '
synonyms = h.xpath('//dd[@class="synonyms"]')
if synonyms:
result += synonyms[0].text_content()
result = re.sub(r'\s+', ' ', result)
result = re.sub('\xb0', '', result)
return result
result = format_output(True)
if len(result) > 450:
result = format_output(False)
if len(result) > 450:
result = result[:result.rfind(' ', 0, 450)]
result = re.sub(r'[^A-Za-z]+\.?$', '', result) + ' ...'
return result
@hook.command('e')
@hook.command
def etymology(inp):
2012-02-28 03:03:43 +01:00
".etymology <word> -- Retrieves the etymology of <word>."
2011-11-20 10:23:31 +01:00
url = 'http://www.etymonline.com/index.php'
h = http.get_html(url, term=inp)
etym = h.xpath('//dl')
if not etym:
return 'No etymology found for ' + inp + ' :('
etym = etym[0].text_content()
etym = ' '.join(etym.split())
if len(etym) > 400:
etym = etym[:etym.rfind(' ', 0, 400)] + ' ...'
return etym