Python 简易聊天机器人

时间:2021-02-16 17:47:50
聊天机器人
|
|-----MySql
|
|---module--“逻辑运算层”
| |
| |---ciku--“与词库交互”
| |
| |---dicty.txt--"词库"
| |---sever--
| |
| |
| |---sqlo--
| |
| |
| |---sqlsever--
| |
| |
|
|---utility-
| |---sqlhelper--“与数据库交互”
|
|
|----index---“服务器端”
|
|----client---“客户端”

代码

index:

import os,sys

path_db=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
sys.path.append(path_db) from module import server def main():
server.severmain() if __name__ == '__main__':
main()

client:

import socket

client = socket.socket()
ip_port = ("127.0.0.1",6666)
client.connect(ip_port)
flag = True
while flag:
say = client.recv(1024)
print(say.decode())
inp = input("root:")
client.send(inp.encode())
if inp == "exit":
break

module:

ciku:

from module import sqlsever
from module import sqlo
import random def checkdata(data):
f = open("module\dicty","r",encoding="utf-8") for info in f:
if info == "\n":
continue
elif info.strip() in data:
say = f.__next__()
print(say.strip())
return say.strip() say = [data,"笨蛋我不知道","哎吆,人家不懂","嘿嘿","儿子"]
say = say[random.randint(0,4)]
return say

dicty:

只选择词库中一小部分,用的酷Q机器人词库

不要哭
我不哭谁哭啊,你来? 55555~~~ 谢谢
不用谢,对我来说是小菜一碟的事。 谢谢
你太客气了,跟我还客气什么啊! 回来吧
好吧,听你的。 回来吧
这样的晚上要是有你在身边多好啊!不过你要是陪我玩我会更开心的,发送“游戏”给我吧! 回来吧
不回,就是不回! 你骂人
我还要打你呢!!! 你骂人
不服气么?宝贝儿 唱歌
我会唱好多歌?想听吗? 算了
那该怎么办? 有啊
真的有吗? 什么
不知道 什么
我也不知道。 什么
回去帮你查查。 什么
你说是什么? 笨蛋
我是很笨哦,聪明的话就不跟你聊天了。 笨蛋
笨蛋很好吃的,里面是黄色的。 笨蛋
嘿嘿。。。 笨蛋
你都看出来了。 多少
你说多少就多少。 沉默
沉默也是一种美德,你知道吗? 沉默
沉默就是胜利。。。 是啊
是就好。 是啊
你讲得到很干脆。 是啊
呵呵,是就行。 公司
哪个公司? 注册
开什么? 产品
是啊,做产品辛苦呢 问题
什么问题,告诉我吧,我来帮你 服务
我不是服务员 作者
什么作者 我的
没关系~我有着宽广的胸怀。 方式
什么方式?你喜欢什么方式 因为
还所以呢 北京
北京是*的首都,中国*四个直辖市之一,中国的政治、文化、外交中心,国内国际交往中心之一,全国第二大城市(仅次于上海市),中国北方最大的城市。这个拥有1700多万人口的城市已经成为一个现代化国际大都市。

sever:

import socket
from module import ciku
from module import sqlo def checkinfo(info,data,conn):
'判断用户输入'
if info != "".encode():
sqlo.write_sql("root", data.encode())
conn.send(data.encode())
flag = True
elif info.decode() == "exit":
flag = False
else:
say = sqlo.read_sql()
conn.send(str(say).encode())
return flag def severcon():
'建立连接'
sk = socket.socket()
ip_port = ("127.0.0.1", 6666)
sk.bind(ip_port)
sk.listen(5)
return sk def severmain():
sk = severcon()
conn,address = sk.accept()
say = "你好,我是小白!"
sqlo.write_sql("root",say.encode())
conn.send(say.encode()) flag = True
while flag:
info = conn.recv(1024)
sqlo.write_sql("用户".encode(),info)
data =ciku.checkdata(info.decode())
flag =checkinfo(info, data, conn)
conn.close()

sqlo:

from module.sqlsever import userinfo

user = userinfo()

def write_sql(username,says):
user.write_record(username,says) def read_sql():
sql_data =user.record()
return sql_data

sqlsever

from utility.sql_helper import MySqlHelper

class userinfo(object):

    def __init__(self):
self.__helper = MySqlHelper() def write_record(self,username,says):
sql = "insert into jiqiren(username,says) values(%s,%s)"
params = (username,says)
return self.__helper.Get_one(sql,params)
def record(self):
sql = "select * from jiqiren"
return self.__helper.Get_one1(sql)

utility:

import  pymysql

conn_dict = dict(host = "127.0.0.1",user = "root",passwd = "xxxx",db ="xxxx",charset='utf8' )

class MySqlHelper(object):

    def __init__(self):
self.__conn_dict = conn_dict def Get_one(self,sql,params):
conn = pymysql.connect(**self.__conn_dict)
cur = conn.cursor(pymysql.cursors.DictCursor)
reCount = cur.execute(sql, params)
conn.commit()
cur.close()
conn.close() def Get_one1(self,sql):
conn = pymysql.connect(**self.__conn_dict)
cur = conn.cursor(pymysql.cursors.DictCursor) reCount = cur.execute(sql)
data = cur.fetchall()
conn.commit()
cur.close()
conn.close()
return data

 聊天与词库交互部分仍不完善。