欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python實現(xiàn)電子詞典

 更新時間:2020年03月03日 08:32:22   作者:RareJie  
這篇文章主要為大家詳細介紹了python實現(xiàn)電子詞典的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了python實現(xiàn)電子詞典的具體代碼,供大家參考,具體內(nèi)容如下

服務(wù)端

#!/usr/bin/env python3
from __future__ import unicode_literals
# coding=utf-8


from socket import *
import os
import pymysql
import time
import sys
import signal

DICT_TEXT = "./dict.txt"
HOST = '0.0.0.0'
PORT = 8000
ADDR = (HOST, PORT)

# 主控制流程


def main():
 # 連接數(shù)據(jù)庫
 db = pymysql.connect\
 ('localhost', 'root', '123456', 'dict')

 # 創(chuàng)建流式套接字
 s = socket()
 s.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
 s.bind(ADDR)
 s.listen(5)
 # 或略子進程退出
 signal.signal(signal.SIGCHLD, signal.SIG_IGN)

 while True:
 try:
  c, addr = s.accept()
  print("Connect from", addr)
 except KeyboardInterrupt:
  s.close()
  sys.exit("服務(wù)器退出")
 except Exception as e:
  print(e)
  continue
 # 創(chuàng)建子進程處理客戶端請求
 pid = os.fork()
 if pid == 0:
  s.close()
  do_child(c, db)
 else:
  c.close()


def do_child(c, db):
 # 循環(huán)接收請求
 while True:
 data = c.recv(128).decode()
 print("Request:", data)
 if (not data) or data[0] == 'E':
  c.close()
  sys.exit(0)
 elif data[0] == 'R':
  do_register(c, db, data)
 elif data[0] == "L":
  do_login(c, db, data)
 elif data[0] == 'Q':
  do_query(c, db, data)
 elif data[0] == 'H':
  do_history(c, db, data)


def do_register(c, db, data):
 l = data.split(' ')
 name = l[1]
 passwd = l[2]

 cursor = db.cursor()
 sql = \
 "select * from user where name='%s'" % name
 cursor.execute(sql)
 r = cursor.fetchone()
 if r != None:
 c.send(b'EXISTS')
 return

 sql = "insert into user (name,passwd)\
 values ('%s','%s')" % (name, passwd)
 try:
 cursor.execute(sql)
 db.commit()
 c.send(b'OK')
 except:
 db.rollback()
 c.send(b'FALL')
 return
 else:
 print("%s注冊成功" % name)


def do_login(c, db, data):
 l = data.split(' ')
 name = l[1]
 passwd = l[2]
 cursor = db.cursor()

 sql = "select * from user where \
 name='%s' and passwd='%s'" % (name, passwd)

 cursor.execute(sql)
 r = cursor.fetchone()
 if r == None:
 c.send('用戶名或密碼不正確'.encode())
 else:
 c.send(b'OK')


def do_query(c, db, data):
 l = data.split(' ')
 name = l[1]
 word = l[2]
 cursor = db.cursor()

 def insert_history():
 tm = time.ctime()
 sql = "insert into hist (name,word,time)\
  values ('%s','%s','%s')" % (name, word, tm)
 try:
  cursor.execute(sql)
  db.commit()
 except:
  db.rollback()
  return

 try:
 f = open(DICT_TEXT, 'rb')
 except:
 c.send("500 服務(wù)端異常".encode())
 return
 while True:
 line = f.readline().decode()
 w = line.split(' ')[0]
 if (not line) or w > word:
  c.send("沒找到該單詞".encode())
  break
 elif w == word:
  c.send(b'OK')
  time.sleep(0.1)
  c.send(line.encode())
  insert_history()
  break
 f.close()


def do_history(c, db, data):
 name = data.split(' ')[1]
 cursor = db.cursor()

 try:
 sql = "select * from hist \
 where name='%s'" % name
 cursor.execute(sql)
 r = cursor.fetchall()
 if not r:
  c.send('沒有歷史記錄'.encode())
  return
 else:
  c.send(b'OK')
 except:
 c.send("數(shù)據(jù)庫查詢錯誤".encode())
 return
 n = 0
 for i in r:
 n += 1
 # 最多顯示10條
 if n > 10:
  break
 time.sleep(0.1)
 msg = "%s %s %s" % (i[1], i[2], i[3])
 c.send(msg.encode())
 time.sleep(0.1)
 c.send(b'##')


if __name__ == "__main__":
 main()

客戶端

#!/usr/bin/env python3
#coding=utf-8

from socket import *
import sys 
import getpass

def main():
 if len(sys.argv) < 3:
 print("argv is error")
 return
 HOST = sys.argv[1]
 PORT = int(sys.argv[2])
 ADDR = (HOST,PORT)

 s = socket()
 s.connect(ADDR)

 while True:
 print('''\n
  ===========Welcome=========
  --1.注冊 2.登錄 3.退出--
  ===========================
  ''')
 try:
  cmd = int(input("輸入選項>>"))
 except Exception:
  print("輸入命令錯誤")
  continue 

 if cmd not in [1,2,3]:
  print("對不起,沒有該命令")
  sys.stdin.flush() #清除輸入
  continue 
 elif cmd == 1:
  name = do_register(s)
  if name != 1:
  print("注冊成功,直接登錄!")
  login(s,name)
  else:
  print("注冊失??!")
 elif cmd == 2:
  name = do_login(s)
  if name != 1:
  print("登錄成功!")
  login(s,name)
  else:
  print("登錄失??!")
 elif cmd == 3:
  s.send(b"E")
  sys.exit("謝謝使用")

def do_register(s):
 while True:
 name = input("用戶名:")
 passwd = getpass.getpass("密 碼:")
 passwd1 = getpass.getpass("確認密碼:")

 if (' ' in name) or (' ' in passwd):
  print("用戶名密碼不允許空格")
  continue
 if passwd != passwd1:
  print("兩次密碼不一致")
  continue

 msg = "R {} {}".format(name,passwd)
 #發(fā)送請求
 s.send(msg.encode())
 #接收回復(fù)
 data = s.recv(128).decode()

 if data == "OK":
  return name
 elif data == 'EXISTS':
  print("該用戶已存在")
  return 1
 else:
  return 1
def do_login(s):
 name = input("用戶名:")
 passwd = getpass.getpass("密 碼:")
 msg = "L {} {}".format(name,passwd)
 s.send(msg.encode())
 data = s.recv(128).decode()

 if data == 'OK':
 return name
 else:
 print(data)
 return 1

def login(s,name):
 while True:
 print('''\n
  ===========查詢界面============
  1.查詞 2.歷史記錄 3.注銷
  =============================
  ''')
 try:
  cmd = int(input("輸入選項>>"))
 except Exception:
  print("命令錯誤")
  continue
 if cmd not in [1,2,3]:
  print("對不起,沒有該命令")
  sys.stdin.flush() #清除輸入
  continue 
 elif cmd == 1:
  do_query(s,name)
 elif cmd == 2:
  do_history(s,name)
 elif cmd == 3:
  return

def do_query(s,name):
 while True:
 word = input("單詞:")
 if word == "##":
  break 
 msg = "Q {} {}".format(name,word)
 s.send(msg.encode())
 data = s.recv(128).decode()
 if data == 'OK':
  data = s.recv(2048).decode()
  print(data)
 else:
  print(data)


def do_history(s,name):
 msg = "H {}".format(name)
 s.send(msg.encode())
 data = s.recv(128).decode()
 if data == 'OK':
 while True:
  data = s.recv(1024).decode()
  if data == "##":
  break
  print(data)
 else:
 print(data)


if __name__ == "__main__":
 main()

插入字典

import pymysql 
import re

f = open('dict.txt')
db = pymysql.connect\
('localhost','root','123456','dict')

cursor = db.cursor()

for line in f:
 try:
 l = re.split("[ ]+",line)
 except:
 pass 
 sql = "insert into words (word,interpret)\
 values ('%s','%s')"%(l[0],' '.join(l[1:]))

 try:
 cursor.execute(sql)
 db.commit()
 except:
 db.rollback()
 
f.close()

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python OrderedDict的使用案例解析

    Python OrderedDict的使用案例解析

    這篇文章主要介紹了Python OrderedDict的使用案例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • Python實現(xiàn)計算函數(shù)或程序執(zhí)行時間

    Python實現(xiàn)計算函數(shù)或程序執(zhí)行時間

    在Python程序的開發(fā)過程中,一些程序需要獲取函數(shù)或程序的開始時間、結(jié)束時間和時間間隔等內(nèi)容用來分析和處理內(nèi)容。本文就來聊聊具體實現(xiàn)方法
    2023-02-02
  • Python使用fastapi快速編寫一個增刪改查的接口

    Python使用fastapi快速編寫一個增刪改查的接口

    這篇文章主要為大家詳細介紹了Python如何使用fastapi快速編寫一個增刪改查的接口,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-04-04
  • Python程序中設(shè)置HTTP代理

    Python程序中設(shè)置HTTP代理

    本文主要給大家簡單講解了下http代理的概念以及如何在Python程序中設(shè)置http代理的方法,非常的詳細,有需要的小伙伴可以參考下
    2016-11-11
  • 為什么說Python可以實現(xiàn)所有的算法

    為什么說Python可以實現(xiàn)所有的算法

    在本篇文章里小編給各位整理的是關(guān)于一個Python就可以實現(xiàn)所有的算法的相關(guān)文章,需要的朋友們參考下。
    2019-10-10
  • Python讀取excel文件中的數(shù)據(jù),繪制折線圖及散點圖

    Python讀取excel文件中的數(shù)據(jù),繪制折線圖及散點圖

    這篇文章主要介紹了Python讀取excel文件中的數(shù)據(jù),繪制折線圖及散點圖,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • python實現(xiàn)淘寶秒殺腳本

    python實現(xiàn)淘寶秒殺腳本

    這篇文章主要為大家詳細介紹了python實現(xiàn)淘寶秒殺腳本,掃碼登錄版,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Python?的賦值,淺拷貝和深拷貝詳解

    Python?的賦值,淺拷貝和深拷貝詳解

    這篇文章主要為大家介紹了Python?的賦值,淺拷貝和深拷貝,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助<BR>
    2021-12-12
  • python如何實現(xiàn)最小矩形覆蓋問題

    python如何實現(xiàn)最小矩形覆蓋問題

    這篇文章主要介紹了python如何實現(xiàn)最小矩形覆蓋問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • Sklearn調(diào)優(yōu)之網(wǎng)格搜索與隨機搜索原理詳細分析

    Sklearn調(diào)優(yōu)之網(wǎng)格搜索與隨機搜索原理詳細分析

    這篇文章主要介紹了Sklearn調(diào)優(yōu)之網(wǎng)格搜索與隨機搜索原理,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-02-02

最新評論