flask 第七章 简陋版智能玩具 +MongoDB初识和基本操作

2023-11-16

1.简陋版web智能玩具

FAQ.py文件

import os

from aip import AipSpeech, AipNlp
from uuid import uuid4
""" 你的 APPID AK SK """
APP_ID = '16027160'
API_KEY = 'uzx4SWZuimPqbE4LvxYScEhi'
SECRET_KEY = '3HBy8yi11ID9T4yyxkADuGYOGyavxPdG'

client = AipSpeech(APP_ID, API_KEY, SECRET_KEY)
client_nlp = AipNlp(APP_ID, API_KEY, SECRET_KEY)


# 语音识别,将你输入的文字转化为语音
def AI_voice(file):
    filename=f'{uuid4()}.mp3'
    result = client.synthesis(file, 'zh', 1, {
        'spd': 5,
        'vol': 5,
        'pit': 5,
        'per': 2
    })
    if not isinstance(result, dict):
        with open(filename, 'wb') as f:
            f.write(result)

    return filename

# 语音合成,通过语音生成文字,在这里只是读出文字,并没有写出来,下面这一步才是将语音中的文字return出来
def get_file_content(file):
    os.system(f"ffmpeg -y  -i {file} -acodec pcm_s16le -f s16le -ac 1 -ar 16000 {file}.pcm")
    with open(f'{file}.pcm', 'rb') as fp:
        return fp.read()

# 返回的是你语音中的消息
def voice_content(file):
    result = client.asr(get_file_content(file), 'pcm', 16000, {
        'dev_pid': 1536,
    })
    # print(result.get('result')[0])
    return result.get('result')[0]

def goto_tl(text, uid):
    URL = "http://openapi.tuling123.com/openapi/api/v2"
    import requests
    data = {
        "perception": {
            "inputText": {
                "text": "你叫什么名字"
            }
        },
        "userInfo": {
            "apiKey": "be41cf8596a24aec95b0e86be895cfa9",
            "userId": "123"
        }
    }

    data["perception"]["inputText"]["text"] = text
    data["userInfo"]["userId"] = uid
    res = requests.post(URL, json=data)

    return res.json().get("results")[0].get("values").get("text")

WebToy.html文件内容如下:

import os

from aip import AipSpeech, AipNlp
from uuid import uuid4
""" 你的 APPID AK SK """
#图灵机器人 APP_ID = '16027160' API_KEY = 'uzx4SWZuimPqbE4LvxYScEhi' SECRET_KEY = '3HBy8yi11ID9T4yyxkADuGYOGyavxPdG' client = AipSpeech(APP_ID, API_KEY, SECRET_KEY) client_nlp = AipNlp(APP_ID, API_KEY, SECRET_KEY) # 语音识别,将你输入的文字转化为语音 def AI_voice(file): filename=f'{uuid4()}.mp3' result = client.synthesis(file, 'zh', 1, { 'spd': 5, 'vol': 5, 'pit': 5, 'per': 2 }) if not isinstance(result, dict): with open(filename, 'wb') as f: f.write(result) return filename # 语音合成,通过语音生成文字,在这里只是读出文字,并没有写出来,下面这一步才是将语音中的文字return出来 def get_file_content(file): os.system(f"ffmpeg -y -i {file} -acodec pcm_s16le -f s16le -ac 1 -ar 16000 {file}.pcm") with open(f'{file}.pcm', 'rb') as fp: return fp.read() # 返回的是你语音中的消息 def voice_content(file): result = client.asr(get_file_content(file), 'pcm', 16000, { 'dev_pid': 1536, }) return result.get('result')[0] def goto_tl(text, uid): URL = "http://openapi.tuling123.com/openapi/api/v2" import requests data = { "perception": { "inputText": { "text": "你叫什么名字" } }, "userInfo": { "apiKey": "be41cf8596a24aec95b0e86be895cfa9", "userId": "123" } } data["perception"]["inputText"]["text"] = text data["userInfo"]["userId"] = uid res = requests.post(URL, json=data) return res.json().get("results")[0].get("values").get("text")

webtoy.py文件内容如下:

from flask import Flask, render_template, request, jsonify, send_file
from uuid import uuid4  # 这个是导入的一串数字,唯一的

from flask_cors import CORS

from day07.FAQ import AI_voice, goto_tl, voice_content, client_nlp

app = Flask(__name__)
#跨域请求
CORS(app)

@app.route('/')
def WebToy():
    return render_template('WebToy.html')


@app.route("/uploader",methods=["POST","GET"])
def uploader():
    filename = f"{uuid4()}.wav"
    file = request.files.get("reco")
    file.save(filename)

    text = voice_content(filename)
    # 自然语言处理 LowB
    score = client_nlp.simnet("你叫什么名字", text).get("score")
    print(score)
    if score >= 0.75:
        filename = AI_voice("我的名字叫嘻嘻")
    else:
        answer = goto_tl(text, "qiaoxiaoqiang")
        filename = AI_voice(answer)

    return jsonify({"code":0,"msg":"文件上传成功","filename":filename})


@app.route('/getaudio/<filename>')
def getaudio(filename):
    return send_file(filename)


if __name__ == '__main__':
    app.run('0.0.0.0', 5000, debug=True)

2.MongoDB初识

在启动mongoDB前,先配置环境变量 ,安装后找到bin目录(包含mongod.exe和mongo.exe)

MongoDB的默认服务端口为27017 ,redis的默认端口为6379,mysql的默认端口为3306

1.启动MongoDB服务 

  mongod -dbpath  D:\data\db

  mongod -dbpath 数据库的存放路径

      -install  安装Windows服务

      -remove 卸载Windows服务

2.客户端的连接

  推荐使用mongodb自带的客户端  -mongo

  show databases    查看本地磁盘数据库

  use dbname     切换到当前使用的数据库

  db        查看当前使用的数据库

  show tables      查看当前数据库存放在磁盘上的数据表

 

  use 不存在的数据库    - 创建了数据库 ,当前创建的数据库没有存放在磁盘中

数据库中没有users数据库,如果使用了 use  users命令,他会在内存中创建一个users的数据库

  db.tablename 不存在的表名 - 创建数据表  当前数据表没有存放在磁盘中

通过前面创建的数据库,use 不存在的表名,如果你在后面再表中添加了数据,那么这个表和内容都存放到了磁盘中

  概念: - 使用了不存在的对象即创建了该对象  - 不限制数据结构

使用第三方客户端 :  --图形化工具 -NoSQLBooster4MongoDB for windows for mac

3.MongoDB的增删改查

添加数据:

db.tablename.insert({'key':'value'})

官方推荐的写法:
    #在图形化客户端和数据库中是这个写法
    db.table.insertOne({'key':'value'})
    db.table.insertMany({k1:v1},{k2:v2},,{k3:v3})
    #在pycharm中的写法为
    db.tablename.insert_one({})
    db.tablename.insert_many({},{},{})

删除数据:

db.tablename.remove({k:v})
db.tablename.remove({age:34}) #删除所有age=34的数据

官方推荐的写法:
#数据库和图形化操作写法
db.tablename.deleteOne()  #删除符合条件的第一条数据
db.tablename.deleteMany() # 删除符合条件的所有数据
#在pycharm中的写法为
db.tablename.delete_one({})
db.tablename.delete_many({},{},{})

更新数据:

#查询出name为xx的数据,将符合条件的一条数据进行修改
db.tablename.update({name:'xx'},{$set:{age:23}}) 

$set -set修改器   强制替换覆盖

官方推荐写法

  #数据库和图形化操作的写法
  #更新符合条件的第一条数据,第一条数据就是你第一个插入的数据
  db.tablename.updateOne({k1:v1},{$set:{k2:v2}}) 
  #更新符合条件的所有数据
  db.tablename.updateMany({k1:v1},{$set:{k2:v2}})

  pycharm写法
  db.tablename.update_one({},{})
  db.tablename.update_many({},{})

array(数组,列表) + object(字典) :db.tablename.updateOne({cp.name:'装X'},{$set:{cp.$.score:'100'}}) #此处cp.$.score,$的意思为前面查询出的索引

查询操作:

db.filename.find()  #查询所有数据
db.user.find({name:xixi}) #查询出name为xixi的数据

#查询符合条件的一条数据
db.tablename.findOne({k:v}) 

4.MongoDB的数据类型

ObjectId :Documents 自动生成的 _id
_id:ObjectId("5cb69a23815ea7295f8bad43") 自动生成的 json数据中不包含ObjectId类型 id类型uuid
String: 字符串,必须是utf-8
Boolean:布尔值,true 或者false (这里有坑哦~在我们大Python中 True False 首字母大写)
Integer:整数 (Int32 Int64 你们就知道有个Int就行了,一般我们用Int32)
Double:浮点数 (没有float类型,所有小数都是Double)
Arrays:数组或者列表,多个值存储到一个键 (list哦,大Python中的List哦)
Object:深度<=4 如果你学过Python的话,那么这个概念特别好理解,就是Python中的字典,这个数据类型就是字典
Null:空数据类型 , 一个特殊的概念,None Null
Timestamp:时间戳 通常不用这个数据类型 如果存储时间 Double
Date:存储当前日期或时间unix时间格式 (我们一般不用这个Date类型,时间戳可以秒杀一切时间类型)

5.数学比较符

$lt : 小于 √
$lte: 小于等于 √
$gt : 大于 √
$gte: 大于等于 √
	
$ne : 不等于
$eq or 冒号 : 等于

6.查询关键字

  array数据类型会自动遍历

  $in 或者等于相同字段 db.filename.fiind({age:{$in:[19,109]}})         #就是age=19或age=109的数据 

  $or 或者等于不同字段 db.filename.find({$or:[{age:19},{age:109}] })   #也是age=19或age=109的数据,与$in不同之处在于 ,$in写的必须是相同的字段,而$or可以写不同的字段

  $and or 逗号  -- 并列条件

  $all --Array 数据类型 子集查询 db.filename.find({hobby:{$all : [ '玉凤','玉霞' ]}})

7.$字符特殊用法:

  存储符合条件的元素的下标索引

  用于修改字段

8.修改器

  $set -- set修改器   强制替换覆盖

  $unset  -- 强制删除字段

  $inc   -- 引用增加   #就相当于我查询出的数据进行增加,没有减,如果想实现减的操作,加负的即可

   array操作:

  $push  相当于append  在array中追加 

  $pushAll  相当于extend  在array中追加列表中的所有元素

  $pull   相当于remove  在array中删除一个元素

  $pullAll  在array中删除一堆元素

  $pop  相当于pop 删除第一个 -1 或 最后一个 1 的值

9. sort(排序) skip(跳过) limit(选取条目)

 sort 排序

#找到name为xixi的数据,根据age排序
db.filename.find({name:xixi}).sort({age:18})

#找到name为xixi的数据,根据age排序,如果age有相同的,再根据birthday倒序排序
db.filename.find({name:xixi}).sort({age:18,birthday:-1})

skip 跳过

#找到name为xixi的数据,然后根据插入顺序跳过第一条
db.filename.find(name:xixi).skip(1)

limit 选取条目

#找到name为xixi的数据,根据插入顺序选取出3条数据展示
db.filename.find({name:xixi}).limit(3)

sort,limit,skip是有执行顺序的

先排序(sort),在跳过(skip),最后显示条目(limit)

分页 

(page-1)*num

db.filename.find({name:xixi}).skip((page-1)*num).limit(num)

10.pymongo

*************************

11.MongoDB偷换的概念

MySql               MongoDB

DataBase            DataBase 
Table               Collection
Colunm              Field
Row                 Dcouments

  

 

转载于:https://www.cnblogs.com/zty1304368100/p/10726968.html

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

flask 第七章 简陋版智能玩具 +MongoDB初识和基本操作 的相关文章

  • 用于将 cython 中的许多 C++ 类包装到单个共享对象的项目结构

    我在文档 邮件列表和这个问题在这里 https stackoverflow com questions 10300660 cython and distutils 但我想得到一个更直接的答案来解决我的具体情况 我正在通过尝试一点一点地包装我
  • 使用 pythonbrew 编译 Python 3.2 和 2.7 时出现问题

    我正在尝试使用构建多个版本的 python蟒蛇酿造 http pypi python org pypi pythonbrew 0 7 3 但我遇到了一些测试失败 这是在运行的虚拟机上 Ubuntu 8 04 32 位 当我使用时会发生这种情
  • Python 中的 Lanczos 插值与 2D 图像

    我尝试重新缩放 2D 图像 灰度 图像大小为 256x256 所需输出为 224x224 像素值范围从 0 到 1300 我尝试了两种使用 Lanczos 插值来重新调整它们的方法 首先使用PIL图像 import numpy as np
  • 在 python 程序中合并第三方库的最佳实践是什么?

    下午好 我正在为我的工作编写一个中小型Python程序 该任务需要我使用 Excel 库xlwt and xlrd 以及一个用于查询 Oracle 数据库的库 称为CX Oracle 我正在通过版本控制系统 即CVS 开发该项目 我想知道围
  • SQLAlchemy 通过关联对象声明式多对多自连接

    我有一个用户表和一个朋友表 它将用户映射到其他用户 因为每个用户可以有很多朋友 这个关系显然是对称的 如果用户A是用户B的朋友 那么用户B也是用户A的朋友 我只存储这个关系一次 除了两个用户 ID 之外 Friends 表还有其他字段 因此
  • 将 Matplotlib 误差线放置在不位于条形中心的位置

    我正在 Matplotlib 中生成带有错误栏的堆积条形图 不幸的是 某些层相对较小且数据多样 因此多个层的错误条可能重叠 从而使它们难以或无法读取 Example 有没有办法设置每个误差条的位置 即沿 x 轴移动它 以便重叠的线显示在彼此
  • Spark KMeans 无法处理大数据吗?

    KMeans 有几个参数training http spark apache org docs latest api python pyspark mllib html highlight kmeans pyspark mllib clus
  • 以编程方式停止Python脚本的执行? [复制]

    这个问题在这里已经有答案了 是否可以使用命令在任意行停止执行 python 脚本 Like some code quit quit at this point some more code that s not executed sys e
  • OpenCV 无法从 MacBook Pro iSight 捕获

    几天后 我无法再从 opencv 应用程序内部打开我的 iSight 相机 cap cv2 VideoCapture 0 返回 并且cap isOpened 回报true 然而 cap grab 刚刚返回false 有任何想法吗 示例代码
  • Python 函数可以从作用域之外赋予新属性吗?

    我不知道你可以这样做 def tom print tom s locals locals def dick z print z name z name z guest Harry print z guest z guest print di
  • AWS EMR Spark Python 日志记录

    我正在 AWS EMR 上运行一个非常简单的 Spark 作业 但似乎无法从我的脚本中获取任何日志输出 我尝试过打印到 stderr from pyspark import SparkContext import sys if name m
  • BeautifulSoup 中的嵌套标签 - Python

    我在网站和 stackoverflow 上查看了许多示例 但找不到解决我的问题的通用解决方案 我正在处理一个非常混乱的网站 我想抓取一些数据 标记看起来像这样 table tbody tr tr tr td td td table tr t
  • Flask如何获取请求的HTTP_ORIGIN

    我想用我自己设置的 Access Control Allow Origin 标头做出响应 而弄清楚请求中的 HTTP ORIGIN 参数在哪里似乎很混乱 我在用着烧瓶 0 10 1 以及HTTP ORIGIN似乎是这个的特点之一object
  • IO 密集型任务中的 Python 多线程

    建议仅在 IO 密集型任务中使用 Python 多线程 因为 Python 有一个全局解释器锁 GIL 只允许一个线程持有 Python 解释器的控制权 然而 多线程对于 IO 密集型操作有意义吗 https stackoverflow c
  • python获取上传/下载速度

    我想在我的计算机上监控上传和下载速度 一个名为 conky 的程序已经在 conky conf 中执行了以下操作 Connection quality alignr wireless link qual perc wlan0 downspe
  • 如何在Python中对类别进行加权随机抽样

    给定一个元组列表 其中每个元组都包含一个概率和一个项目 我想根据其概率对项目进行采样 例如 给出列表 3 a 4 b 3 c 我想在 40 的时间内对 b 进行采样 在 python 中执行此操作的规范方法是什么 我查看了 random 模
  • 将图像分割成多个网格

    我使用下面的代码将图像分割成网格的 20 个相等的部分 import cv2 im cv2 imread apple jpg im cv2 resize im 1000 500 imgwidth im shape 0 imgheight i
  • 使用其构造函数初始化 OrderedDict 以便保留初始数据的顺序的正确方法?

    初始化有序字典 OD 以使其保留初始数据的顺序的正确方法是什么 from collections import OrderedDict Obviously wrong because regular dict loses order d O
  • 在 Qt 中自动调整标签文本大小 - 奇怪的行为

    在 Qt 中 我有一个复合小部件 它由排列在 QBoxLayouts 内的多个 QLabels 组成 当小部件调整大小时 我希望标签文本缩放以填充标签区域 并且我已经在 resizeEvent 中实现了文本大小的调整 这可行 但似乎发生了某
  • 如何将输入读取为数字?

    这个问题的答案是社区努力 help privileges edit community wiki 编辑现有答案以改进这篇文章 目前不接受新的答案或互动 Why are x and y下面的代码中使用字符串而不是整数 注意 在Python 2

随机推荐

  • SIFT特征简介

    过程 1 尺度空间建立及极值点搜索 初步搜索 2 关键点精确定位 直线拟合使得关键点精确定位 x y sigma 消除边缘响应 初步搜寻特征点后 得到特征点的层数 像素坐标 x y 方向 文中分为18或36个离散方向 1 SIFT算法具的特
  • python dict遍历性能,Python:遍历list vs over dict items效率

    这取决于您使用的是哪个版本的Python 在Python 2中 some dict items 创建一个新的列表 这将占用一些额外的时间并占用更多的内存 另一方面 一旦创建了列表 它就是一个列表 因此在完成列表创建的开销之后 应该具有相同的
  • 用户行为路径数据埋点方案设计案例

    用户行为路径数据埋点方案设计案例 案例背景 业务需要对用户行为进行数据分析 现缺失这部分数据 需要设计采集方案获取数据满足业务分析需求 定义 数据采集方案是为埋点所设计的采集方案 所谓埋点就是在产品 通常是网页 app 中需要提取数据的地方
  • 小程序上传线上地址文件

    web上传的时候可以使用new Blob 但是在小程序中不能使用 当时的文件还是二进制的文件流 小程序上传不能使用线上地址 后来想了很多办法 最后把文件流使用wx saveFile先保存到本地 拿到result savedFilePath的
  • FPGA基础知识点

    FPGA知识点 Verilog基础语法 基础知识 逻辑值 逻辑0 表示低电平 也就是对应电路GND 逻辑1 表示高电平 也就是对应电路VCC 逻辑X 表示未知 有可能是高电平也有可能是低电平 逻辑Z 表示高阻态 外部没有激励信号 是一个悬空
  • Docker第七回(私有Registry)

    一 Docker Registry的分类 Registry用来保存docker镜像 包括镜像的层次结构和元数据 用户可以自建Registry 也可以使用官方的docker hub Sponsor Registry 第三方的Registry
  • 如何解决fiddler抓包时出现443的问题

    之前公司的app使用的http协议 因此不需要安装证书也能够转包 后来改成https协议后 在使用fiddler进行抓包时 一直出现tunnel to 443 百度了好久也没有具体的解决办法 后来发现需要在手机端安装fiddler的证书才行
  • stylefeng 文档_基于SpringBoot+spring mvc+Mybatis+beetl+bootstrap实现的简洁开源网站后台管理系统Guns...

    package com stylefeng guns config import io swagger annotations ApiOperation import org springframework boot autoconfigu
  • 面经——嵌入式常见面试题总结100题(上)

    参考 嵌入式常见面试题总结 1 作者 天泉证道 发布时间 2018 11 08 09 33 43 网址 https guoyanzhang blog csdn net article details 83855895 目录 1 字符型驱动设
  • oracle nvl函数

    1 nul函数将一个null值转换为一个实际的值 数据类型可以是日期 数字 字符 数据类型必须匹配 nvl commision 0 nvl hiredate 01 JAN 87 nvl job id no manager nvl to ch
  • 西电机器学习简答题核心考点汇总(期末真题,教材西瓜书)

    文章目录 前言 一 机器学习和深度学习区别以及原因 二 卷积核 池化层作用 三 SVM转化为对偶问题的优点 四 核函数的作用 五 特征的相似度定义 性质 六 预剪枝与后剪枝优缺点 七 密度直接可达 密度可达 密度相连定义 八 DBSCAN相
  • 前端:上传图片upload组件(传formData格式,后端返回图片文件流)

    使用组件 iview中的upload组件 html
  • 深入理解Flink的水位线

    Apache Flink是一个流处理框架 它支持事件时间和处理时间的概念 在处理流数据时 Flink通过水位线 Watermark 来追踪事件时间的进度 从而支持事件时间的操作 水位线是一种特殊的事件 它表示在此时间戳之前的所有事件都已经到
  • java八股文合集(附免费0积分下载链接)

    下面是地址 Java八股文一 java基础知识 Java八股文二 java集合框架 Java八股文三 Java多线程 Java八股文四 Java虚拟机 Java八股文五 MySQL Inno DB Java八股文六 spring相关 Jav
  • Python项目开发

    今天任务 1 创建Python项目为pythontest1以及test1 py文件 2 修改字号 3 输入九九乘法表程序 编译调试执行 4 配置全局pip镜像为阿里镜像 5 命令行中下载安装pygame包 新建项目 选择 Create Ne
  • Python解决OpenCV系列库安装报错问题

    1 pip install dlib 这个库的安装很大概率出现问题 可以去参考 Python dlib 无需编译安装 dlib 19 23 0 cp39 cp39 win amd64 whl 这里放一个百度网盘的链接 要求Python3 9
  • C#中Linq用法汇集

    C 中Linq常用用法 LINQ查询语法 有两种基本的方法来编写一个LINQ查询IEnumerable集合或IQueryable数据源 1 查询语法或查询表达式语法 2 方法语法或方法扩展语法或Fluent LINQ查询语法 查询语法与数据
  • linux各目录详细介绍

    bin 二进制可执行命令 dev 设备特殊文件 etc 系统管理和配置文件 etc rc d 启动的配置文件和脚本 home 用户主目录的基点 比如用户user的主目录就是 home user 可以用 user表示 lib 标准程序设计库
  • stm32定时器外部计数模式 最大频率计算。

    本 外部时钟模式下 外部信号通过内部时钟 CK INT 采样得到 外部信号周期的计算方法是 2xTINT 20ns 这里的TINT是CK INT的周期时间 例如 内部时钟频率为72MHz 则TINT 13 89ns 这时外部信号的最高频率是
  • flask 第七章 简陋版智能玩具 +MongoDB初识和基本操作

    1 简陋版web智能玩具 FAQ py文件 import os from aip import AipSpeech AipNlp from uuid import uuid4 你的 APPID AK SK APP ID 16027160 A