Rev 49 | Go to most recent revision | Details | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
46 | szabot | 1 | #!/usr/bin/python |
2 | # -*- coding: utf-8 -*- |
||
3 | |||
4 | import tornado.database |
||
5 | import re |
||
6 | |||
7 | def getnavilist(): |
||
8 | ret = [] |
||
9 | current = u"" |
||
10 | db = tornado.database.Connection("127.0.0.1", "navi", user="navi", password="navi") |
||
11 | for row in db.query(""" |
||
12 | SELECT *, CHAR_LENGTH(navi) AS NL |
||
13 | FROM `metaWords` |
||
14 | ORDER BY NL DESC"""): |
||
15 | if row["partOfSpeech"] in (u"v.", u"vin.", u"vtr."): |
||
16 | current = unicode(row["ipa"]) |
||
17 | current = current.replace(ur"ɛ",ur"e").replace(ur".",ur"").replace(ur"ɾ",ur"r") \ |
||
18 | .replace(ur"ɪ",ur"ì").replace(ur"ˈ",ur"").replace(ur"'",ur"x") \ |
||
19 | .replace(ur"ŋ",ur"ng").replace(ur"j",ur"y").replace(ur"ʔ",ur"'") \ |
||
20 | .replace(ur"æ",ur"ä").replace(ur"ˌ",ur"").replace(ur"\t{ts}",ur"ts") \ |
||
21 | .replace(ur"ṛ",ur"rr").replace(ur"ḷ",ur"ll").replace(ur"k̚",ur"k ") \ |
||
22 | .replace(ur"p̚",ur"p ").replace(ur"t̚",ur"t ").replace(ur"'̚",ur"' ") \ |
||
23 | .replace(u"\\",ur"").replace(ur"(",ur"").replace(ur")",ur"") \ |
||
24 | .replace(ur"[",ur"").replace(ur"]",ur"").replace(ur" "," ") \ |
||
25 | .strip() |
||
26 | current = re.sub(ur" or.*","",current) |
||
27 | current = re.sub(ur"z(.*)engk(.*)e",ur"z\1enk\2e",current) |
||
28 | current = re.sub(ur"t(.*)ì(m|n)\ ",ur"t\1ìng ",current) |
||
29 | current = current.split(ur"$cdot$") |
||
30 | if len(current) == 3: |
||
31 | current = current[0] + u"<0><1>" + current[1] + u"<2>" + current[2] |
||
32 | elif len(current) == 2: |
||
33 | current = current[0] + u"<0><1><2>" + current[1] |
||
34 | else: |
||
35 | current = u"<0><1><2>" + current[0] |
||
36 | else: |
||
37 | current = unicode(row["navi"]) |
||
38 | ret.append([row["id"], row["navi"], current, row["partOfSpeech"]]) |
||
39 | db.close() |
||
40 | return ret |
||
41 | |||
42 | def getnavi(word): |
||
43 | ret = [] |
||
44 | db = tornado.database.Connection("127.0.0.1", "navi", user="navi", password="navi") |
||
45 | for row in db.query(""" |
||
46 | SELECT * |
||
47 | FROM `metaWords` |
||
48 | WHERE navi = ?""",word): |
||
49 | ret.append([row["id"],row["navi"], row["infix"], row["partOfSpeech"]]) |
||
50 | db.close() |
||
51 | return ret |
||
52 |