-
Notifications
You must be signed in to change notification settings - Fork 83
/
Dictionary.py
72 lines (61 loc) · 1.8 KB
/
Dictionary.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
# -*- coding: utf-8 -*-
import urllib
import re
from urllib import urlencode
import sys
reload(sys)
sys.setdefaultencoding('utf8')
SLUG = "dictionary"
WORDS = ["CHENGYU"]
def getHtml(words):
url = 'http://dict.baidu.com/s'
values = {'wd' : words}
data = urlencode(values)
html = ""
try:
response = urllib.urlopen("%s?%s" % (url, data))
html = response.read()
except :
pass
return html
def handleHtml(html):
patten1 = re.compile('<div class="tab-content">.*?</div>', re.S)
results = re.findall(patten1, html)
str = ""
for i in results:
if "出自" in i:
patten2 = re.compile("<li>(.*?)</li>", re.S)
results2 = re.findall(patten2, i)
str = results2[0] + results2[1]
return str
def getWords(text):
pattern1 = re.compile("成语.*?")
pattern2 = re.compile(".*?的成语意思")
if re.match(pattern1, text) != None:
words = text.replace("成语", "")
elif re.match(pattern2, text) != None:
words = text.replace("的成语意思", "")
else:
words = ""
words = words.replace(",","")
words = words.replace(",","")
return words
def info(html):
pass
def handle(text, mic, profile, wxbot=None):
words = getWords(text)
if words:
html = getHtml(words)
info(html)
if html:
str = handleHtml(html)
if str:
mic.say(words + str, cache=True)
else:
mic.say("成语" + words +"有误 请重试", cache=True)
else:
mic.say(u"网络连接有误 请重试", cache=True)
else:
mic.say(u"没有听清楚 请重试", cache=True)
def isValid(text):
return u"成语" in text