Python 英語單詞本

supermao12 發表於 2021-12-28
Python

python pymysql re requests socket庫的簡單運用

要考試了,這裡用所學的知識做一個例項

pymysql庫

這個庫是用來連線資料庫的,使用資料庫語句在python裡建立表和資料庫

English.py

import pymysql
def init():            #建立資料庫和表
    sql_data='create database English'
    sql_table='create table word(id int(100),English char(50),Chinese varchar(100),time varchar(50))default charset=utf8;'
    DB=pymysql.connect(host='localhost',password='1234',charset='utf8',user='root')
    cursor=DB.cursor()
    cursor.execute(sql_data)
    cursor.execute('use English')
    cursor.execute(sql_table)
init()

requests庫

通過python來獲取網頁資訊
function.py這個檔案來實現單詞本的各種功能

function.py

import time
import pymysql
import requests

DB = pymysql.connect(host='localhost', password='1234', charset='utf8', user='root', database='English')
cursor = DB.cursor()

class Func():
    def __init__(self):
        self.sql_all = 'select * from word'

    def id(self):  # 獲取id值
        cursor.execute(self.sql_all)
        fin = cursor.fetchall()
        if fin:
            global id
            self.id = fin[-1][0] + 1
        else:
            self.id = 1


    def translate(self):
        url='https://fanyi.baidu.com/sug'
        headers={'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:95.0) Gecko/20100101 Firefox/95.0'}
        while True:
            word = input('請輸入被翻譯的單詞或句子(q==quit)')
            if word == 'q':
                break
            data={'kw':word}
            re=requests.post(url=url,headers=headers,data=data)
            a=re.json()
            for i in a['data']:
                print(i['k'] , '\t' , i['v'])

    def insert(self):  # 插入資料
        while True:
            e = input('請輸入英文 (q=quit)')
            if e == 'q':
                break
            c = input('請輸入中文')
            time1 = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time()))
            sql_insert = 'insert into word values(%d,"%s","%s","%s");' % (self.id, e, c, time1)
            cursor.execute(sql_insert)
            DB.commit()
            print(e, c, '以收入資料庫')
            self.id = self.id + 1



    def show(self):  # 顯示所有單詞
        cursor.execute(self.sql_all)
        fin = cursor.fetchall()
        print('序號      英文            中文              時間')
        for i in fin:
            if i != fin[0]:
                print()
            for j in i:
                print(j,end='      ')
        print()


    def show_something(self):
        a = input('請輸入以什麼為開頭的模糊查詢')
        sql_something = 'select * from word where english like "{0}%"'.format(a)
        #print(sql_something)
        print('序號      英文            中文              時間')
        cursor.execute(sql_something)
        a = cursor.fetchall()
        for i in a:
            if i != a[0]:
                print()
            for j in i:
                print(j,end='      ')
        print()

    def delete(self):
        a = int(input('請輸入單詞序號:  '))
        sql_del = 'delete from word  where  id={0} '.format(a)
        cursor.execute(self.sql_all)
        print('序號      英文            中文              時間')
        l = cursor.fetchall()
        for i in l:
            if i[0] == a:
                for j in i:
                    print(j,end='      ')
                print()
        #print(sql_del)
        cursor.execute(sql_del)
        DB.commit()


def main():
    fun = Func()
    fun.id()
    print('歡迎來到    <小茅背單詞>\n選擇功能  1.背單詞 2.查翻譯 3.顯示所有庫中單詞 4.顯示以什麼字元開頭的單詞'
        ' 5.刪除單詞 6.開啟遠端背單詞功能 7.q==quit')
    while True:
        ch = input('請輸入序號 (s=show)')
        if ch == '1':
            fun.insert()
        if ch == '2':
            fun.translate()
        if ch == '3':
            fun.show()
        if ch == '4':
            fun.show_something()
        if ch == '5':
            fun.delete()
        if ch == '6':
            import remotely
        if ch == 's':
            print('歡迎來到    <小茅背單詞>\n選擇功能  1.背單詞 2.查翻譯 3.顯示所有庫中單詞 4.顯示以什麼字元開頭的單詞'
                ' 5.刪除單詞 6.開啟遠端背單詞功能 7.q==quit')
        if ch == 'q':
            print('Bye')
            break

main()

def  rec():
    import re
    Pattern = re.compile(r"^[A-Za-z0-9\u4e00-\u9fa5][email protected][a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)$")
    word=input('word')
    if Pattern.match(word):
        print('成功')

通過bind繫結ip地址使遠端的使用者可以連線到remotely

remotely.py

import pymysql
import socket
import time
DB = pymysql.connect(host='localhost', password='1234', charset='utf8', user='root', database='English')
cursor = DB.cursor()
class reFunc():
    def __init__(self):
        self.sql_all = 'select * from word'

    def id(self):  # 獲取id值
        cursor.execute(self.sql_all)
        fin = cursor.fetchall()
        if fin:
            global id
            self.id = fin[-1][0] + 1
        else:
            self.id = 1


    def insert(self):  # 插入資料
        while True:
            e = con.recv(1024).decode('utf-8')
            if e == 'q':
                s.close()
                break
            c = con.recv(1024).decode('utf-8')
            time1 = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time()))
            sql_insert = 'insert into word values(%d,"%s","%s","%s");' % (self.id, e, c, time1)
            message = '{0},{1}以收入資料庫'.format(e, c)
            con.send(message.encode('utf-8'))
            cursor.execute(sql_insert)
            DB.commit()
            print(e, c, '以收入資料庫')
            self.id = self.id + 1




fun = reFunc()
fun.id()    # 先獲取id值
s = socket.socket()
s.bind(('10.104.45.223', 8888))
print('已準備')
s.listen(5)
con, address = s.accept()
print('連線成功')
message = ('歡迎來到    <小茅背單詞>\n     遠端功能,你所輸入的資料將會存放在主機庫中')
con.send(message.encode('utf-8'))
fun.insert()

socket

這是給遠端使用者使用的,兩個使用者連線時首先得相互ping通

客戶機.py

import socket
s=socket.socket()
s.connect(('10.104.45.223',8888))
rep=s.recv(1024).decode('utf-8')
print(rep)
def select1():
    while True:
        message=input('請輸入英文 q == quit:')
        if message == 'q':
            s.send(message.encode('utf-8'))
            s.close()
            break
        else:
            s.send(message.encode('utf-8'))
            message=input('請輸入中文')
            s.send(message.encode('utf-8'))
            rep=s.recv(1024).decode('utf-8')
            print(rep)

select1()