findarray30code/__main__.py
2016-03-30 08:08:27 +08:00

107 lines
2.9 KiB
Python
Executable file

#!/usr/bin/env python3
#-*-coding:utf-8-*-
import sqlite3
import sys
import ui, ui2
from PyQt4 import QtGui, QtCore
def table2list(table_tsv):
with open(table_tsv,'r',encoding='utf-16') as tsv:
code_list = []
for line in tsv:
line_stripped = line.strip()
code_char_mapping = tuple(line_stripped.split())
code_list.append(code_char_mapping)
return code_list
def connect_db(db_filename):
db = sqlite3.connect(db_filename)
c = db.cursor()
return db,c
def create_new_db(db_filename):
db, c = connect_db(db_filename)
c.execute('''CREATE TABLE ime (code text, char text)''')
return db, c
def list2sqlite(code_list,c):
c.executemany(
'INSERT INTO ime VALUES (?,?)', code_list)
def import_all_table():
import os
import re
main_dirname = os.path.dirname(os.path.abspath(__file__))
db ,c = create_new_db(':memory:')
table_folder = os.path.join(main_dirname, 'table')
table_folder_files = os.listdir(table_folder)
for file in table_folder_files:
if re.match('.+\.txt$',file):
file_path = os.path.join(table_folder,file)
list = table2list(file_path)
list2sqlite(list,c)
db.commit()
return db, c
def find_code(char,c):
raw_query = c.execute('''SELECT code FROM ime WHERE char = ?''', (char,))
raw_code = [i[0] for i in raw_query.fetchall()]
code = [rawcode2truecode(i) for i in raw_code]
code = sorted(code,reverse=True)
print(code)
return code, c
def rawcode2truecode(raw):
#1^ = Q, 1- = A, 1v = Z, 2^ = W, 2- = S ......, 0^ = P, 0- = :, 0v = ?
raw_code_order = "QAZWSXEDCRFVTGBYHNUJMIK<OL>P:?"
true_code = ""
for i in raw:
i_index = raw_code_order.index(i)
uncorrected_column = i_index // 3
#correct the column no. 2 -> 3; 9 -> 0
column = str(uncorrected_column + 1)[-1]
raw_number = i_index % 3
raw = ['^','-','v'][raw_number] # 0=^;1=-;2=v
column_and_raw = column + raw
true_code = true_code + column_and_raw
return true_code
class MainWindow(QtGui.QMainWindow, ui.Ui_MainWindow):
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
self.setupUi(self)
self.lineEdit.returnPressed.connect(self.input_characters)
self.pushButton.clicked.connect(self.input_characters)
def input_characters(self):
characters = self.lineEdit.text()
chinese_char_pattern = QtCore.QRegExp("[\u4e00-\u9fa5]+")
validator = QtGui.QRegExpValidator( chinese_char_pattern, characters)
if validator.validate():
print (characters)
else:
print("error")
#TODO: validate, and return result
def main():
app = QtGui.QApplication(sys.argv)
form = MainWindow()
form.show()
app.exec_()
if __name__ == '__main__':
main()
db,c = import_all_table()
find_code("",c)