python實(shí)現(xiàn)電子詞典
本文實(shí)例為大家分享了python實(shí)現(xiàn)電子詞典的具體代碼,供大家參考,具體內(nèi)容如下
# -*- coding: utf-8 -*-
#youdanTest.py
import urllib
import json
# 設(shè)置一個(gè)退出程序的出口
isOut = False
# 不斷調(diào)用爬取翻譯頁(yè)面的功能
# 直到isOut被設(shè)置為T(mén)rue,退出程序
def query(keys):
while True:
if isOut == True:
break
# 假定用戶輸入“CloseMe”,則退出
key = keys
if key == "CloseMe":
isOut = True
continue # 回到循環(huán)開(kāi)始處,然后結(jié)果條件滿足退出
# 做真正的查詢操作
url = "http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=null"
# 構(gòu)造headers
headers = {"User-Agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.181 Safari/537.36",
"X-Requested-With": "XMLHttpRequest",
"Accept": "application/json, text/javascript, */*; q=0.01",
"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8"
}
# 把form數(shù)據(jù)轉(zhuǎn)規(guī)范化,然后post給服務(wù)端
formdata = {
"i": key,
"from": "AUTO",
"to": "AUTO",
"smartresult": "dict",
"client": "fanyideskweb",
"salt": "1523933959290",
"sign": "248f5d216c45a64c38a3dccac0f4600d",
"doctype": "json",
"version": "2.1",
"keyfrom": "fanyi.web",
"action": "FY_BY_REALTIME",
"typoResult": "false"
}
data = bytes(urllib.parse.urlencode(
formdata),
encoding="utf-8")
# 給服務(wù)器發(fā)送post請(qǐng)求
req = urllib.request.Request(url,
data,
headers,
method="POST")
response = urllib.request.urlopen(req)
info = response.read().decode("utf-8")
jsonLoads = json.loads(info)
return jsonLoads['translateResult'][0][0]["tgt"]
服務(wù)端
#!/usr/bin/python3
# coding=utf-8
from signal import *
from socket import *
import pymysql
from time import *
import sys
import os
from youdaoTest import query
def do_child(connfd, db):
while True:
msg = connfd.recv(128).decode()
print("msg : ", msg)
if msg[0] == 'R':
do_register(connfd, msg, db)
if msg[0] == 'L':
do_login(connfd, msg, db)
if msg[0] == 'Q':
do_query(connfd, msg, db)
if msg[0] == 'H':
do_history(connfd, msg, db)
if msg[0] == 'E':
connfd.close()
sys.exit(0)
return
def do_register(connfd, msg, db):
print("in register.......")
cursor = db.cursor()
s = msg.split(' ')
name = s[1]
passwd = s[2]
sql = "select * from user where name = '%s'" % name
cursor.execute(sql)
data = cursor.fetchone()
print(data)
if data != None:
connfd.send("FALL".encode())
return
sql = "insert into user values ('%s','%s')" % (name, passwd)
try:
cursor.execute(sql)
db.commit()
connfd.send('OK'.encode())
except:
connfd.send("FALL".encode())
db.rollback()
return
else:
print("register OK !")
def do_login(connfd, msg, db):
print("in login.......")
cursor = db.cursor()
s = msg.split(' ')
name = s[1]
passwd = s[2]
try:
sql = "select * from user where name = '%s' and passwd = '%s'" % (
name, passwd)
cursor.execute(sql)
data = cursor.fetchone()
print(data)
except:
pass
if data == None:
connfd.send("FALL".encode())
else:
connfd.send('OK'.encode())
return
def do_query(connfd, msg, db):
print("in query.......")
start = time()
cursor = db.cursor()
s = msg.split(' ')
words = s[1]
name = s[2]
msg = query(words)
connfd.send(msg.encode())
insert_history(db, words, name)
def do_history(connfd, msg, db):
print('in history...')
s = msg.split(' ')
name = s[1]
cursor = db.cursor()
sql = 'select * from history where name = "%s"' % name
try:
cursor.execute(sql)
data = cursor.fetchall()
connfd.send('OK'.encode())
except:
connfd.send('FALL'.encode())
sleep(0.1)
for msg in data:
name = msg[0]
word = msg[1]
time = msg[2]
sleep(0.01)
connfd.send(('%s %s %s' % (name, word, time)).encode())
sleep(0.1)
connfd.send('over'.encode())
def insert_history(db, words, name):
time = ctime()
cursor = db.cursor()
sql = 'insert into history values ("%s","%s","%s")' % (name, words, time)
try:
cursor.execute(sql)
db.commit()
except:
print('into history failed')
db.rollback()
def main():
signal(SIGCHLD, SIG_IGN)
db = pymysql.connect('localhost', 'root', '123456', 'dict')
HOST = sys.argv[1]
PORT = int(sys.argv[2])
sockfd = socket()
sockfd.bind((HOST, PORT))
sockfd.listen(5)
while True:
try:
connfd, addr = sockfd.accept()
print("connect addr : ", addr)
except KeyboardInterrupt:
raise
except:
continue
pid = os.fork()
if pid < 0:
print("create child process failed")
connfd.close()
continue
elif pid == 0:
sockfd.close()
do_child(connfd, db)
else:
connfd.close()
continue
db.close()
sockfd.close()
sys.exit(0)
if __name__ == "__main__":
main()
電子詞典客戶端
#!/usr/bin/python
# coding=utf-8
from signal import *
from socket import *
from time import *
import sys
import os
def do_register(sockfd, msg):
name = input("input your user name >>")
passwd = input("input your user passwd >>")
msg = 'R %s %s' % (name, passwd)
sockfd.send(msg.encode())
msg = sockfd.recv(128).decode()
if msg[0:2] == 'OK':
return 0
else:
return -1
def do_login(sockfd, msg):
name = input("input your user name >>")
passwd = input("input your user passwd >>")
msg = 'L %s %s' % (name, passwd)
sockfd.send(msg.encode())
msg = sockfd.recv(128).decode()
if msg[0:2] == 'OK':
return name
else:
return -1
def do_query(sockfd, msg, name):
while True:
word = input("input word >>")
if word == '##':
return
msg = 'Q %s %s' % (word, name)
sockfd.send(msg.encode())
msg = sockfd.recv(128).decode()
if msg[0:2] == 'OK':
msg = sockfd.recv(1024).decode()
if msg == " ":
print("not found this word")
print(msg)
# elif msg[:11] == 'found error':
# print('found error')
# continue
else:
print("fail to query")
continue
def do_history(sockfd, msg, name):
msg = 'H %s' % name
sockfd.send(msg.encode())
msg = sockfd.recv(128).decode()
if msg[0:2] == 'OK':
while True:
data = sockfd.recv(1024).decode()
if data == 'over':
break
print(data)
else:
print("fail to history")
return -1
def main():
HOST = sys.argv[1]
PORT = int(sys.argv[2])
msg = None
sockfd = socket()
sockfd.connect((HOST, PORT))
def login(name):
while True:
print('''
==========query commend=========
---1:查詞 2:歷史記錄 3:退出---
================================
''')
try:
cmd = int(input("Input commend >> "))
except:
print("Input error!")
continue
if cmd not in [1, 2, 3]:
print("input error!")
sys.stdin.flush()
continue
if cmd == 1:
do_query(sockfd, msg, name)
if cmd == 2:
do_history(sockfd, msg, name)
if cmd == 3:
break
return
while True:
print('''
=============Welcome=============
----1: 注冊(cè) 2: 登陸 3: 退出----
=================================
''')
try:
cmd = int(input("Input command >> "))
except:
print("Input error")
continue
if cmd not in [1, 2, 3]:
print("input error!")
sys.stdin.flush()
continue
if cmd == 1:
if do_register(sockfd, msg) == 0:
print("register OK!")
else:
print("register FALL")
if cmd == 2:
name = do_login(sockfd, msg)
if name != -1:
print("login OK!")
login(name)
else:
print("register FALL")
if cmd == 3:
msg = 'E'
sockfd.send(msg.encode())
sockfd.close()
sys.exit(0)
if __name__ == "__main__":
main()
查詞時(shí)將單詞發(fā)送到網(wǎng)絡(luò)上,從有道中查詢出單詞翻譯再返回給客戶端。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python光學(xué)仿真實(shí)現(xiàn)光線追跡之空間關(guān)系
這篇文章主要介紹了python光學(xué)仿真中實(shí)現(xiàn)光線追跡的空間關(guān)系示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2021-10-10
jupyter note 實(shí)現(xiàn)將數(shù)據(jù)保存為word
這篇文章主要介紹了jupyter note 實(shí)現(xiàn)將數(shù)據(jù)保存為word,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04
OpenCV2.3.1+Python2.7.3+Numpy等的配置解析
這篇文章主要介紹了OpenCV2.3.1+Python2.7.3+Numpy等的配置解析,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01
Python中urllib2模塊的8個(gè)使用細(xì)節(jié)分享
這篇文章主要介紹了Python中urllib2模塊的8個(gè)使用細(xì)節(jié)分享,本文講解了Proxy設(shè)置、Timeout設(shè)置、加入特定Header、Redirect、Cookie、PUT和DELETE方法等內(nèi)容,需要的朋友可以參考下2015-01-01
python 日志模塊logging的使用場(chǎng)景及示例
這篇文章主要介紹了python 日志模塊logging的使用場(chǎng)景及示例,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2021-01-01
python實(shí)現(xiàn)簡(jiǎn)單飛機(jī)大戰(zhàn)小游戲
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)簡(jiǎn)單飛機(jī)大戰(zhàn)小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
Python 窗體(tkinter)按鈕 位置實(shí)例
今天小編就為大家分享一篇Python 窗體(tkinter)按鈕 位置實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06
Python列表中多元素刪除(移除)的實(shí)現(xiàn)
本文主要介紹了Python列表中多元素刪除(移除)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
python如何實(shí)現(xiàn)數(shù)組元素兩兩相加
這篇文章主要介紹了python如何實(shí)現(xiàn)數(shù)組元素兩兩相加,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05

