目录

一、准备工作

1.准备爬虫工具

2.python库的安装

3.国内常用源镜像地址

4.镜像安装,下载速度更快

5.爬虫使用步骤

6.用到的工具

二、项目构思

1.创建基础窗口

2.创建按钮

3.添加动态背景

4.退出方法添加

5.按钮实现模块

三、整体代码

四、项目运行效果


一、准备工作

1.准备爬虫工具


爬取机器人回复数据:


  • 注册机器人平台:https://console.ownthink.com/
  • 获取Appid
  • 对机器人进行一些基本的设置和训练
2.python库的安装



pip install 库名
pip uninstall 库名
pip list 查询当前安装库和版本号
3.国内常用源镜像地址
附国内常用源镜像地址
清华:https://pypi.tuna.tsinghua.edu.cn/simple
阿里云:http://mirrors.aliyun.com/pypi/simple/
豆瓣(douban) :http://pypi.douban.com/simple/
中国科技大学 https://pypi.mirrors.ustc.edu.cn
华中理工大学:http://pypi.hustunique.com/
山东理工大学:http://pypi.sdutlinux.org/


4.镜像安装,下载速度更快
pip install 库名 -i
https://pypi.tuna.tsinghua.edu.cn/simple
5.爬虫使用步骤
  • 安装requests库
pip install requests -i
https://pypi.tuna.tsinghua.edu.cn/simple
  • 1. 导入爬虫库 2. 定义 url 3. 爬取并返回数据 4. 将数组转换为指定格式 5. 显示结果
6.用到的工具

1.运用python爬虫技术并使用Json解析工具进行格式转换

2.导入pillow库,进行图像处理

3.通过百度人工智能平台获取智能语音资源

4.导入playaudio库,进行声音的录制

5.导入jieba库,进行智能分词的实现

6.导入tqdm库,实现语音录制过程中进度条的显示

7.导入baidu-aip库,进行声音的识别

8.导入playsound库,进行语音的合成

二、项目构思

1.创建基础窗口


from tkinter import *
import dirsetting # 文件结构管理
dirsetting.mk_dir() # 创建基础文件夹
# 创建窗口
window = Tk()
window.geometry('640x480+500+200')
window.title('智能语音助手')
window.resizable(0,0) # 设置窗口尺寸不可更改
# 创建一个画布
bg = Canvas(window,width=640,height=480,bg='#3399ff')
bg.place(x=0,y=0)
window.mainloop()


2.创建按钮
# 按钮点击的函数
def click():
print('点我干哈!')
Button(window,text='点击对话',width=20,bg='#c2c2c2',
command=click).place(x=230,y=80)
3.添加动态背景
# pillow中的 图片工具 Tk图片工具 分割动态图片工具
from PIL import Image,ImageTK,ImageSequence
import time
# 添加背景函数
def pick():
im = Image.open(r'image\bg.gif')
while True:
# 图像分割后 得到静态图片的集合
iter = ImageSequence.Iterator(im)
# 将每张图片设置为背景
for pic in iter:
pic = ImageTk.PhotoImage(pic)
bg.create_image((320,240),image=pic)
time.sleep(0.1)
window.update_idletasks()
window.update()
# 和窗口一起运行 (定时器)
window.after(0,pick)
4.退出方法添加


from MyAudio import * # 语音合成文件
import os
# 退出方法
def on_closing():
getAudio("期待下次再见!")
os._exit(0)
# 添加背景函数
def pick():
略
while True:
# 添加退出方法
window.protocol('WM_DELETE_WINDOW',on_closing)
略
5.按钮实现模块
  • 多线程功能——解决按钮使用,其他位置不能运行的问题
import threading # 线程库
# 自定义线程
def thread_it(func,*args):
# 创建线程
t = threading.Thread(target=func,args=args)
# 守护线程 另一段代码也执行
t.setDaemon(True)
# 启动线程
t.start()
# 修改按钮的command命令
Button(window,text='点击对话',width=20,bg='#c2c2c2',
command=lambda:thread_it(click)).place(x=200,y=80)
  • 实现按钮的主要功能
from Record import * # 录音
from xiaoKu import * # 机器人
from take_photo import * # 拍照
from findsongs import * # 找歌
import jieba # 智能分词
完整代码
# 按钮点击的函数
def click():
# 提示音
getAudio('你好,我是小艺,有什么能帮助你的吗?')
# 录音并转换为文字
say = record()
# 智能分词
keyword = jieba.lcut_for_search(say)
# print(keyword)
# 根据关键词 执行指令
# 访问机器人
if '天气' in keyword or '笑话' in keyword:
result = getReply(say)
elif '播放' in keyword or '音乐' in keyword:
getAudio('请告诉我歌曲名称,例如:刘德华的忘情水!')
say = record()
getsong(say)
return
elif '拍照' in keyword or '照相' in keyword:
take_photo()
return
else:
result = getReply()
getAudio(result)


三、整体代码

from tkinter import *
import dirsetting     #文件结构管理
#pillow中的图片工具库,TK图片工具,分割动态图片工具
from PIL import Image,ImageTk,ImageSequence
import time
from MyAudio import *      #语音合成文件
import os
import threading           #线程库

from Record import *       #录音
from xiaoKu import *       #机器人
from take_photo import *   #拍照
from findsongs import *    #找歌
import jieba               #智能分词

dirsetting.mk_dir()        #创建基础文件夹

#1.创建窗口
window = Tk()
window.geometry("640x480+500+200")
window.title('智能语音助手')
window.resizable(0,0)   #设置窗口尺寸不可更改
#创建一个画布
bg = Canvas(window,width=640,height=480,bg='#3399ff')
bg.place(x=0,y=0)

#自定义线程
def thread_it(func,*args):
    #创建线程
    t = threading.Thread(target=func,args=args)
    #守护线程  另一段代码也执行
    t.setDaemon(True)
    #启动线程
    t.start()
#点击按钮退出
def exit():
    # 提示音
    getAudio('这么快就要说再见了吗?')
    # 录音并转换为文字
    say = record()
    # 智能分词
    keyword = jieba.lcut_for_search(say)
    # print(keyword)
    getAudio("期待下次再见!")

#按钮点击的函数
def click():
    #提示音   
    getAudio("你好,我是小艺,有什么能帮助你的吗?")
    #录音并转换为文字
    while TRUE:
        say = record()
        #智能分词
        keyword = jieba.lcut_for_search(say)
        print(keyword)
        #根据关键词,执行指令
        #访问机器人
        
        if '再见' in  keyword or '拜拜' in keyword:
            getAudio('小艺会想你的')
            break  
        elif '头痛' in  keyword or '头疼' in keyword:
            result = getReply(say)
        elif '肚子疼' in  keyword or '肚子痛' or '腹部疼痛' in keyword:
            result = getReply(say)
        elif '不开心' in  keyword or '心情不好' or '难过' in keyword:
            result = getReply(say)
        elif '失眠' in  keyword or '睡不着' in keyword:
            result = getReply(say)
        elif '烫伤' in  keyword or '烫到' in keyword:
            result = getReply(say)
        elif '口腔溃疡'  in keyword:
            result = getReply(say)
        elif '感冒的症状' in  keyword:
            result = getReply(say)
        elif '感冒' in keyword:
            result = getReply(say)
        elif '发烧' in  keyword or '发热' in keyword:
            result = getReply(say)
       
        elif '天气' in  keyword or '笑话' in keyword:
            result = getReply(say)
        elif '播放' in keyword or '音乐' in keyword:
            getAudio('请告诉我歌曲名称,例如刘德华的《忘情水》')
            say = record()
            getsong(say)
        elif '拍照' in  keyword or '照相' in keyword:
            take_photo()
            return
        else:
            result = getReply()
        getAudio(result)


#退出方法
def on_closing():
    getAudio("小艺去睡觉咯!")
    os._exit(0)


#添加背景函数
def pick():
    im = Image.open('image/8.gif')
    while True:
        #添加退出方法
        window.protocol('WM_DELETE_WINDOW',on_closing)
        #图像分割后, 得到静态图片的集合
        iter = ImageSequence.Iterator(im)
        #将每张图片设置为背景
        for pic in iter:
            pic = ImageTk.PhotoImage(pic)
            bg.create_image((320,240),image=pic)
            time.sleep(0.1)
            window.update()
#和窗口一起运行,反复执行(定时器)
window.after(0,pick)
    
Button(window,text='点击对话',width=20,bg='#c2c2c2',
       command=lambda:thread_it(click)).place(x=210,y=80)
Button(window,text='结束对话',width=20,bg='#c2c2c2',
       command=lambda:thread_it(exit)).place(x=210,y=300)

window.mainloop()

四、项目运行效果


智能医疗语音助手