标签:估计 出现 on() temp time lse inpu 线程 sel
import threadingqa = {‘你好‘ : ‘你好‘, ‘我爱你‘ : ‘我也爱你‘,‘猪猪‘:‘猪是一种动物‘,‘猪猪侠‘:‘猪猪侠是一部动画片‘}
questionqueue = queue.Queue(1) # 问题队列,
condition = threading.Condition()
class robotthread(threading.Thread):
def init(self):
threading.Thread.init(self)
pass
pass
def run(self):
while True:
condition.acquire() # 加锁
if questionqueue.full(): # 队列是否满了
qs = questionqueue.get() # 出队列
# print(qs)
word = list(tuple(qs)) # 拆词,小技巧。 元组接受字符串,会自动打散
# print(tuple(qs))
keylist = list(qa.keys()) # 获取所有的key
times = 0 # 记录频次
maxkey = ‘‘ # 保存出现频次最大的key
# 得到频次最大的key,这里只是取出现次数最多的语句
for tempkey in keylist:
temp = 0
for w in word:
temp += tempkey.count(w) # str自带的count计数
pass
if temp > times:
times = temp
maxkey = tempkey
pass
pass
if times > 0: # 如果找到了对应的key,times就会大于0,key也存在
print(qa[maxkey]) # 答应机器人的回答
else:
print("不好意思,你说的太难了,我理解不了!")
if questionqueue.empty():
condition.notify() # 通知已回答问题,可以再问了
condition.wait() # 本线程同时进入阻塞状态
pass
pass
condition.release() # 解锁
pass
class askthread(threading.Thread):
def init(self):
threading.Thread.init(self)
pass
def run(self):
while True:
condition.acquire() # 加锁
ask = input("你说吧,我在呢:") # 自带阻塞线程,等待用户输入
questionqueue.put(ask) # 入队列
condition.notify() # 通知其他线程可以答题了
condition.wait()
condition.release()
pass
if name == ‘main‘:
athread = askthread()
athread.start()
# 启动答题线程
rthread = robotthread()
rthread.start()
athread.join() # 阻塞调用线程,一般是指主线程(存在子线程下再起子线程的可能) 估计以后都不会用
rthread.join()
print("主线程running......")
标签:估计 出现 on() temp time lse inpu 线程 sel
原文地址:http://blog.51cto.com/11478096/2330341