图像识别技术文档

GitHub传送门

项目概述

  • 项目名称:面部表情识别

  • 项目背景:在与客户交流的过程中,通过客户的面部表情来判断用户对话题是否感兴趣,营销人员或者沟通人员可以从中找到客户感兴趣的方面,或者判断客户的购买欲望

  • 图像识别是指利用计算机对图像进行处理、分析、理解,图像识别的过程可分为图像处理和图像分析两个过程
    图像处理是指对所需要分析的图像进行一系列的图形操作,包括拉伸缩放、旋转翻转、颜色变换、像素保留……,图像分析是指通过图像的特征来反馈图像信息并且分类,最简单的是基于统计的方法、最常用的是深度学习方法

  • 技术支持
    图像处理:VoTT、OpenCV、PIL
    图像分析:TensorFlow、Keras、CNN



应用领域

  • 总体目标
    a) 一级目标
    通过客户的面部表情变化,来抓住客户感兴趣的点,提高沟通效率
    b) 二级目标
    学习图像识别的技术
    c) 三级目标
    学习深度学习实现工具
    d) 四级目标
    了解图像识别技术实现的步骤,技术原理


实验步骤

  • 资源

    • 数据资源:本次实验为面部表情的二分类识别,情绪为高兴和沮丧,各表情图像5000张

    • 技术支持:Keras、TensorFlow、VoTT、OpenCV、PIL

      • Keras

        Keras是一个由Python编写的开源人工神经网络库,可以作为Tensorflow、Microsoft-CNTK和Theano的高阶应用程序接口,进行深度学习模型的设计、调试、评估、应用和可视化,Keras的神经网络API是在封装后与使用者直接进行交互的API组件,在使用时可以调用Keras的其它组件。除数据预处理外,使用者可以通过神经网络API实现机器学习任务中的常见操作,包括人工神经网络的构建、编译、学习、评估、测试等。

      • TensorFlow

        TensorFlow由谷歌人工智能团队谷歌大脑(Google Brain)开发和维护,拥有包括TensorFlow Hub、TensorFlow Lite、TensorFlow Research Cloud在内的多个项目以及各类[应用程序接口]( API) [2] 。自2015年11月9日起,TensorFlow依据阿帕奇授权协议(Apache 2.0 open source license)开放源代码,TensorFlow是一个基于数据流编程(dataflow programming)的符号数学系统,被广泛应用于各类机器学习(machine learning)算法的编程实现,谷歌大脑自2011年成立起开展了面向科学研究和谷歌产品开发的大规模深度学习应用研究,其早期工作即是TensorFlow的前身DistBelief。

      • VoTT

        VoTT是一个用TypeScript编写的React + Redux Web应用程序。该项目是通过Create React App启动的,用于图像和视频资产的开源注释和标签工具,VoTT可以作为本机应用程序安装,也可以从源代码运行。VoTT也可以作为独立的Web应用程序使用,并且可以在任何现代Web浏览器中使用。

      • OpenCV

        OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库,可以运行在Linux、Windows、Android和Mac OS操作系统上。它轻量级而且高效——由一系列 C 函数和少量 C++ 类构成,同时提供了Python、Ruby、MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法。

      • PIL

        python图像处理库,这个库支持多种文件格式,并提供了强大的图像处理和图形处理能力。


  • 方法

    • 试验阶段

      • 在项目开始初步试验阶段,通过人工百度搜索人像表情图像,利用VoTT工具进行裁切和标注,各表情100张,并按照7,2,1的比列把数据分为训练集、测试集、验证集。
      • 利用Keras深度学历框架搭建简单的CNN进行训练,结果显示CNN在图像处理领域效果很不错,在模型未经过调整前准确率能超过50%。

    • 中期工作

      • 扩大数据集,利用爬虫批量获取人像图片,在爬取百度图片的过程中,如果直接获取那最多只能获取到30张图像,之后程序就自动停止了,采用的解决方法是,通过观察url发现可以添加page页码这个选择来达到滚轮向下刷新图片的作用,因此添加一个页码循环来爬取图像。


        # 爬取图片
        import re
        import requests
        from urllib import error
        from bs4 import BeautifulSoup
        import osnum = 0
        numPicture = 0
        file = ''
        List = []def Find(url):global Listprint('正在检测图片总数,请稍等.....')t = 0i = 1s = 0while t < 1000:Url = url + str(t)try:Result = requests.get(Url, timeout=7)except BaseException:t = t + 60continueelse:result = Result.textpic_url = re.findall('"objURL":"(.*?)",', result, re.S)  # 先利用正则表达式找到图片urls += len(pic_url)if len(pic_url) == 0:breakelse:List.append(pic_url)t = t + 60return sdef recommend(url):Re = []try:html = requests.get(url)except error.HTTPError as e:returnelse:html.encoding = 'utf-8'bsObj = BeautifulSoup(html.text, 'html.parser')div = bsObj.find('div', id='topRS')if div is not None:listA = div.findAll('a')for i in listA:if i is not None:Re.append(i.get_text())return Redef dowmloadPicture(html, keyword):global num# t =0pic_url = re.findall('"objURL":"(.*?)",', html, re.S)  # 先利用正则表达式找到图片urlprint('找到关键词:' + keyword + '的图片,即将开始下载图片...')for each in pic_url:
        #         print('正在下载第' + str(num + 1) + '张图片,图片地址:' + str(each))print('\r',"已下载"+str(num+1).ljust(10)+"张图片",end='')try:if each is not None:pic = requests.get(each, timeout=7)else:continueexcept BaseException:print('错误,当前图片无法下载')continueelse:string = file + r'\\' + keyword + '_' + str(num) + '.jpg'fp = open(string, 'wb')fp.write(pic.content)fp.close()num += 1if num >= numPicture:returnif __name__ == '__main__':  # 主函数入口word = input("请输入搜索关键词(可以是人名,地名等): ")#add = 'http://image.baidu.com/search/flip?tn=baiduimage&ie=utf-8&word=%E5%BC%A0%E5%A4%A9%E7%88%B1&pn=120'url = 'http://image.baidu.com/search/flip?tn=baiduimage&ie=utf-8&word=' + word + '&pn='tot = Find(url)Recommend = recommend(url)  # 记录相关推荐print('经过检测%s类图片共有%d张' % (word, tot))numPicture = int(input('请输入想要下载的图片数量 '))file = input('请建立一个存储图片的文件夹,输入文件夹名称即可')words=input("请输入图片前缀")y = os.path.exists(file)if y == 1:print('该文件已存在,请重新输入')file = input('请建立一个存储图片的文件夹,)输入文件夹名称即可')os.mkdir(file)else:os.mkdir(file)t = 0tmp = urlwhile t < numPicture:try:url = tmp + str(t)result = requests.get(url, timeout=10)print(url)except error.HTTPError as e:print('网络错误,请调整网络后重试')t = t+60else:dowmloadPicture(result.text, words)t = t + 60


      • 再利用VoTT工具时框选的图像只记录位置大小,并不能裁切保存图像,所以采用VoTT加Python的方式来完成图像标注和裁切,在VoTT新建项目,选择图像位置进行框选和标注,完成后保存导出json格式文件,在利用Python读取json文件,打开对应图像按照框选的大小进行裁切,然后转化为数组也就是像素保存,按照6,2,2的比例划分数据集保存CSV文件。


      • 打开VoTT,选择新建项目
        在这里插入图片描述



      • 新建连接点
        在这里插入图片描述



      • 选择为添加位置
        在这里插入图片描述



      • 选择图像所在文件夹位置,添加确认
        在这里插入图片描述
        在这里插入图片描述



      • 工作界面右上角区域为标签处理区域,可以进行标签的添加删除和位置更改操作
        在这里插入图片描述



      • 正上方区域为框选工作区域
        在这里插入图片描述



      • 左边为文件选项,可以选择框选图像已经导出
        在这里插入图片描述



      • 标注好的图像导出为json格式
        在这里插入图片描述



        #图像按照框选大小进行裁切保存
        import pandas as pd
        import os
        import json
        from PIL import Imagepath=os.path.abspath(".")
        path_image=path+"\\dat_20191202"
        for i,j in zip(os.listdir(path_image),range(len(os.listdir(path_image)))):if i.endswith("json"):with open(path_image+"\\"+i,"r") as f:data2=json.load(f)path_i=data2["asset"]["name"]labe=data2["regions"][0]["tags"][0]box=(data2["regions"][0]["points"][0]["x"],data2["regions"][0]["points"][0]["y"],data2["regions"][0]["points"][2]["x"],data2["regions"][0]["points"][2]["y"])im=Image.open(path_image+"\\"+path_i).crop(box)try:im.save(path+"\\image\\0\\"+str(j)+".jpg")except:print("格式错误")
        
        #讲图像转换为数据保存
        import pandas as pd
        import numpy as np
        from PIL import Image
        import ospath=os.path.abspath(".")
        emotion_Yes=path+"\\image\\1"
        emotion_No=path+"\\image\\0"Y=[]
        for i in os.listdir(emotion_Yes):im=Image.open(emotion_Yes+"\\"+i)im=im.resize((48,48))im=im.convert("L")Y.append(np.array(im))N=[]
        for i in os.listdir(emotion_No):im=Image.open(emotion_No+"\\"+i)im=im.resize((48,48))im=im.convert("L")N.append(np.array(im))d=[]
        for i in Y:d1=[]for j in i:for n in j:d1.append(n)d.append(str(d1).replace("[","").replace("]","").replace(",",""))e=[]
        for i in N:e1=[]for j in i:for n in j:e1.append(n)e.append(str(e1).replace("[","").replace("]","").replace(",",""))dat1=pd.DataFrame({"emotion":[1]*len(d),"pixels":d})
        jh1=["Training"]*int(dat1.shape[0]*0.7)+["PrivateTest"]*(int(dat1.shape[0]*0.2))+["PublicTest"]*(int(dat1.shape[0]-int(dat1.shape[0]*0.7)-int(dat1.shape[0]*0.2)))
        #训练集、测试集、验证集=70%,20%,10%
        dat1["Usage"]=jh1dat2=pd.DataFrame({"emotion":[0]*len(e),"pixels":e})
        jh2=["Training"]*int(dat2.shape[0]*0.7)+["PrivateTest"]*(int(dat2.shape[0]*0.2))+["PublicTest"]*(int(dat2.shape[0]-int(dat2.shape[0]*0.7)-int(dat2.shape[0]*0.2)))
        dat2["Usage"]=jh2data_x=pd.concat([dat1,dat2],ignore_index=True)
        data_x.to_csv(path+"\\emotion_file.csv",index=False)print(data_x.shape)
        

      • 读取CSV文件,根据标签将图像划分为训练集、测试集、验证集三个文件夹,每个文件夹在根据图像的分类标签保存在所属标签的子文件夹下,在保存时要紧图像进行灰度处理,也就是只保留一个通道,这样的好处是可以减少计算量,加快处理速度。

        #将数据集根据根据标签分成训练集、测试集、验证集
        import csv
        import ospath = os.path.abspath(".")
        database_path = os.path.abspath(".")
        datasets_path = os.path.abspath(".")
        csv_file = database_path+'emotion_file.csv'
        train_csv = datasets_path+'train.csv'
        val_csv = datasets_path+'val.csv'
        test_csv = datasets_path+ 'test.csv'with open(csv_file) as f:csvr = csv.reader(f)header = next(csvr)print(header)rows = [row for row in csvr]trn = [row[:-1] for row in rows if row[-1] == 'Training']csv.writer(open(train_csv, 'w+'), lineterminator='\n').writerows([header[:-1]] + trn)print(len(trn))val = [row[:-1] for row in rows if row[-1] == 'PublicTest']csv.writer(open(val_csv, 'w+'), lineterminator='\n').writerows([header[:-1]] + val)print(len(val))tst = [row[:-1] for row in rows if row[-1] == 'PrivateTest']csv.writer(open(test_csv, 'w+'), lineterminator='\n').writerows([header[:-1]] + tst)print(len(tst))
        

        #图像转化为灰色通道并保存在子文件夹下
        import csv
        import os
        from PIL import Image
        import numpy as npdatasets_path = os.path.abspath(".")
        train_csv = os.path.join(datasets_path, 'train.csv')
        val_csv = os.path.join(datasets_path, 'val.csv')
        test_csv = os.path.join(datasets_path, 'test.csv')train_set = os.path.join(datasets_path, 'train')
        val_set = os.path.join(datasets_path, 'val')
        test_set = os.path.join(datasets_path, 'test')for save_path, csv_file in [(train_set, train_csv), (val_set, val_csv), (test_set, test_csv)]:if not os.path.exists(save_path):os.makedirs(save_path)num = 1with open(csv_file) as f:csvr = csv.reader(f)header = next(csvr)for i, (label, pixel) in enumerate(csvr):pixel = np.asarray([float(p) for p in pixel.split()]).reshape(48, 48)subfolder = os.path.join(save_path, label)if not os.path.exists(subfolder):os.makedirs(subfolder)im = Image.fromarray(pixel).convert('L')image_name = os.path.join(subfolder, '{:05d}.jpg'.format(i))im.save(image_name)
        


    • 搭建CNN

      • 卷积神经网络介绍,神经网络就是利用计算机来模拟人体大脑学历思考问题的方式和能力,不断向前传输计算值,向后反馈误差,不断学习,直到误差也就是损失最小时停止训练,将训练好的模型进行保存用于预测。当我们基于一个有限的固定特征集合解决分类问题的时候,这种方法是很奏效的——例如,我们根据足球运动员在比赛中记录的统计数据来预测他的位置。

        ​ 但是,当处理照片的时候,问题变得更加复杂。当然,我们可以把每个像素的亮度视作一个单独的特征,然后将它作为密集网络的输入传递进去。不幸的是,为了让它能够应付一张典型的智能手机照片,我们的网络必须包含数千万甚至上亿的神经元。另一方面,虽然我们可以将照片缩小,但是我们也会在这个过程中损失有价值的信息。所以我们马上就会发现,传统的策略是没有用的——我们需要一种新的聪明的方法,来尽可能多的利用数据,但同时还要减少必需的计算量和参数。这就是 CNN 发挥作用的时候了。
        在这里插入图片描述

      • 卷积神经网络和普通神经网络的区别主要在于“卷积”二字,卷积也就是我们说的内积计算方式,就是将矩阵相乘再相加,卷积的操作是为了提取区域的主要特征,也是一种减少维度的方法,并且在图像识别中这种方式也是很合理的,卷积这个操作最开始来自于计算机波纹处理,后来应用到计算机视觉领域得到了显著的作用。

      • 卷积操作可以作为物体的边缘检测,这在图像识别上提供了很大的帮助,在将我们的滤波器放在选中的像素上之后,我们将卷积核中的每一个数值和图像中对应的数值成对相乘。最后将乘积的结果相加,然后把结果放在输出特征图的正确位置上。我们在上边的动画中可以以一个微观的形式看到这个运算的过程,但是更有趣的是我们在整幅图像上执行这个运算得到的结果。


      + “池化”操作是和“卷积”配合使用,池化操作也是一种提取重要特征的方式,但是在这一环节中没有权重产生,它的工作方式是指定池化的大小,对数据进行扫描保留区域内最大数值,这个操作也可以保留区域内的平均数值。除了卷积层,CNN 通常会用到所谓的池化层。它们最早被用来减小张量的大小以及加速运算。这些层是比较简单的——我们需要将我们的图像分成不同的区域,然后在每一个部分上执行一些运算。例如,对 Max Pool 层而言,我们会选择每个区域的最大值,并将它放到对应的输出区域。与卷积层的情况一样,我们有两个可用的超参数——滤波器大小和步长。最后但同样重要的一点是,如果你对一个多通道的图像执行池化操作,那么每一个通道的池化应该单独完成。

      + “全连接”,此操作是将图像数组进行平压之后全连接,之后的操作和普通的神经网络原理一致,最后的输出层利用逻辑函数进行预测。
      • 数据输入,在数据输入过程中添加Keras图像生成器模块,扩大数据集。

        import keras
        from keras.layers import Dense, Dropout, Activation, Flatten,Conv2D, MaxPooling2D
        from keras.layers.normalization import BatchNormalization
        from keras.models import Sequential
        from keras.preprocessing.image import ImageDataGenerator
        from keras.callbacks import EarlyStopping
        from keras.optimizers import SGD
        batch_siz = 128
        num_classes = 2 
        nb_epoch = 10
        img_size=48
        root_path=os.path.abspath(".")import tensorflow as tf
        import keras.backend.tensorflow_backend as KTF
        KTF.set_session(tf.Session(config=tf.ConfigProto(device_count={'gpu':0})))class Model:def __init__(self):self.model = Nonedef build_model(self):self.model = Sequential()self.model.add(Conv2D(32, (3, 3), strides=1, padding='same', input_shape=(img_size, img_size, 1)))self.model.add(Activation('relu'))self.model.add(Conv2D(32, (5, 5), padding='same'))self.model.add(Activation('relu'))self.model.add(MaxPooling2D(pool_size=(2, 2)))self.model.add(Conv2D(32, (3, 3), padding='same'))self.model.add(Activation('relu'))self.model.add(MaxPooling2D(pool_size=(2, 2)))self.model.add(Conv2D(64, (5, 5), padding='same'))self.model.add(Activation('relu'))self.model.add(MaxPooling2D(pool_size=(2, 2)))self.model.add(Flatten())self.model.add(Dense(2048))self.model.add(Activation('relu'))self.model.add(Dropout(0.5))self.model.add(Dense(1024))self.model.add(Activation('relu'))self.model.add(Dropout(0.5))self.model.add(Dense(num_classes))self.model.add(Activation('softmax'))self.model.summary()def train_model(self):sgd=SGD(lr=0.01, decay=1e-6, momentum=0.9, nesterov=True)self.model.compile(loss='categorical_crossentropy',optimizer=sgd,metrics=['accuracy'])#自动扩充训练样本train_datagen = ImageDataGenerator(rescale = 1./255,shear_range = 0.2,zoom_range = 0.2,horizontal_flip=True)#归一化验证集val_datagen = ImageDataGenerator(rescale = 1./255)eval_datagen = ImageDataGenerator(rescale = 1./255)#以文件分类名划分labeltrain_generator = train_datagen.flow_from_directory(root_path+'/train',target_size=(img_size,img_size),color_mode='grayscale',batch_size=batch_siz,class_mode='categorical')#categoricalval_generator = val_datagen.flow_from_directory(root_path+'/val',target_size=(img_size,img_size),color_mode='grayscale',batch_size=batch_siz,class_mode='categorical')eval_generator = eval_datagen.flow_from_directory(root_path+'/test',target_size=(img_size,img_size),color_mode='grayscale',batch_size=batch_siz,class_mode='categorical')early_stopping = EarlyStopping(monitor='loss',patience=3)history_fit=self.model.fit_generator(train_generator,steps_per_epoch=800/(batch_siz/32),#28709nb_epoch=nb_epoch,validation_data=val_generator,validation_steps=500)history_predict=self.model.predict_generator(eval_generator,steps=500)with open(root_path+"\\model"+'/model_fit_log','w') as f:f.write(str(history_fit.history))with open(root_path+"\\model"+'/model_predict_log','w') as f:f.write(str(history_predict))print('model trained')def save_model(self):model_json=self.model.to_json()with open(root_path+"\\model"+"/model_json.json", "w") as json_file:json_file.write(model_json)self.model.save_weights(root_path+"\\model"+'/model_weight.h5')self.model.save(root_path+"\\model"+'/model.h5')print('model saved')if __name__=='__main__':model=Model()model.build_model()print('model built')model.train_model()print('model trained')model.save_model()print('model saved')
        

    • 图像预测结果

      • 加载模型预测图像表情

        import numpy as np
        import cv2
        import sys
        import json
        import time
        import os
        from keras.models import model_from_json
        root_path=os.path.abspath(".")
        model_path = root_path + '/model_50/'
        img_size = 48
        emotion_labels = ["happy",'disgust']
        num_class = len(emotion_labels)
        json_file = open(model_path + 'model_json.json')
        loaded_model_json = json_file.read()
        json_file.close()
        model = model_from_json(loaded_model_json)
        model.load_weights(model_path + 'model_weight.h5')def predict_emotion(face_img):img_size=48face_img = face_img * (1. / 255)resized_img = cv2.resize(face_img, (img_size, img_size))results = []rsh_img=resized_img.reshape(1,img_size, img_size, 1)list_of_list = model.predict_proba(rsh_img, batch_size=32, verbose=1)result = [prob for lst in list_of_list for prob in lst]results.append(result)return resultsdef face_detect(image_path):cascPath = root_path+"/data/haarcascade_frontalface_alt2.xml"faceCasccade = CascadeClassifier(cascPath)img = imread(image_path)img_gray = cvtColor(img, COLOR_BGR2GRAY)faces = faceCasccade.detectMultiScale(img_gray,scaleFactor=1.1,minNeighbors=1,minSize=(10, 10))return faces, img_gray, imgif __name__ == '__main__':images = []A=input("请输入待预测图片所在文件夹名称:")dir = root_path +"\\"+ Aif isdir(dir):files = listdir(dir)for file in files:if file.endswith('jpg') or file.endswith('png') or file.endswith('PNG') or file.endswith('JPG'):images.append(dir + '\\' + file)else:images.append(dir)for image in images:faces1, img_gray, img = face_detect(image)if faces1==():faces1=array([[0,0,img_gray.shape[1],img_gray.shape[0]]])faces=[]for i in faces1:x,y,w,h=iif w >= max(faces1[:,2])*0.8:j=(x,y,w,h)faces.append(j)spb = img.shapesp = img_gray.shapeheight = sp[0]width = sp[1]size = 600emo = ""face_exists = 0for (x, y, w, h) in faces:face_exists = 1face_img_gray = img_gray[y:y + h, x:x + w]results = predict_emotion(face_img_gray)  # face_img_grayresult_sum = array([0]*num_class)for result in results:result_sum = result_sum + array(result)disgust,happy= result_sumprint('disgust:', disgust,' happy:', happy)label = argmax(result_sum)emo = emotion_labels[label]print('Emotion : ', emo)t_size = 2ww = int(spb[0] * t_size / 300)www = int((w + 10) * t_size / 100)www_s = int((w + 20) * t_size / 100) * 2 / 5rectangle(img, (x, y), (x + w, y + h), (0, 0, 255), ww)putText(img, emo, (x+2, y+h-10),FONT_HERSHEY_TRIPLEX,www_s, (255, 0, 0), thickness=www, lineType=1)if face_exists:HoughLinesPnamedWindow(emo, 0)cent = int((height * 1.0 / width) * size)resizeWindow(emo, (size, cent))imshow(emo, img)k = waitKey(0)destroyAllWindows()if k & 0xFF == ord('q'):break
        
      • 效果展示

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 模型评估

    • 训练集

      0 1
      0 4749 216
      1 283 6933
      评估 百分比
      真阳率 96.98%
      假阳率 3.02%
      真阴率 5.62%
      假阴率 94.38%
      召回率 96.08%
    • 测试集

      0 1
      0 562 64
      1 76 803
      评估 百分比
      真阳率 92.62%
      假阳率 7.38%
      真阴率 11.91%
      假阴率 88.09%
      召回率 91.35%

  • 实时预测

    ​ 对面部表情进行实时识别需要计算机获取摄像头的信息,思路是通过获取计算机摄像头的权限,打开摄像头进行实时画面的捕捉,获取当前画面的一帧来做预测,根据刷新率不同识别的实时速率也不同

    #-*- coding: utf-8 -*-import cv2
    import sys
    import gc
    import json
    import numpy as np
    from keras.models import Sequential
    from keras.models import model_from_json
    root_path=os.path.abspath(".")
    model_path=root_path+'/model/'
    img_size=48
    emo_labels = ["happy", 'disgust']
    num_class = len(emo_labels)
    json_file=open(model_path+'model_json.json')
    loaded_model_json = json_file.read()
    json_file.close()
    model = model_from_json(loaded_model_json)
    model.load_weights(model_path+'model_weight.h5')if __name__ == '__main__':if len(sys.argv) == 1:print(len(sys.argv))print("Usage:%s camera_id\r\n" % (sys.argv[0]))sys.exit(0)#框住人脸的矩形边框颜色color = (0, 0, 2555)#捕获指定摄像头的实时视频流cap = cv2.VideoCapture(0)#人脸识别分类器本地存储路径cascade_path ="C:/ProgramData/Anaconda3/lib/site-packages/cv2/data/haarcascade_frontalface_alt.xml"#循环检测识别人脸while True:_, frame = cap.read()   #读取一帧视频#图像灰化,降低计算复杂度frame_gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)#使用人脸识别分类器,读入分类器cascade = cv2.CascadeClassifier(cascade_path)#利用分类器识别出哪个区域为人脸faceRects = cascade.detectMultiScale(frame_gray, scaleFactor = 1.1,minNeighbors = 1, minSize = (120, 120))if len(faceRects) > 0:for faceRect in faceRects:x, y, w, h = faceRectimages=[]rs_sum=np.array([0.0]*num_class)image = frame_gray[y: y + h, x: x + w ]image=cv2.resize(image,(img_size,img_size))image=image*(1./255)images.append(image)images.append(cv2.flip(image,1))images.append(cv2.resize(image[2:45,:],(img_size,img_size)))for img in images:image=img.reshape(1,img_size,img_size,1)list_of_list = model.predict_proba(image,batch_size=32,verbose=1)result = [prob for lst in list_of_list for prob in lst]rs_sum+=np.array(result)print(rs_sum)label=np.argmax(rs_sum)emo = emo_labels[label]print ('Emotion : ',emo)cv2.rectangle(frame, (x - 10, y - 10), (x + w + 10, y + h + 10), color, thickness = 2)font = cv2.FONT_HERSHEY_SIMPLEXcv2.putText(frame,'%s' % emo,(x + 30, y + 30), font, 1, (255,0,255),4)cv2.imshow("识别朕的表情!", frame)#等待10毫秒看是否有按键输入k = cv2.waitKey(30)#如果输入q则退出循环if k & 0xFF == ord('q'):break#释放摄像头并销毁所有窗口cap.release()cv2.destroyAllWindows()

总结

  • 面部表情识别的准确率和数据集的质量密切相关,在训练时最好选用高清无水印的人像表情进行训练,否则OpenCV在进行面部识别的时候会出现错误,以至于影响到预测结果

  • 对于面部表情的二分类卷积神经网络能较为出色的完成,在于客户交流沟通的时候可以通过客户表情的反馈来不断更正我们的营销策略

  • 面部表情还可以用于多方面,可作为一个技术支持来辅佐其它行业,需要继续探索和完善

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 朝阳行业高薪职业的选择-RHC@注册健康管理师

    中调网(年红) 2020年8月8日第十二个“全民健身日”来临之时,RHC注册健康管理师考评管理中心在京成立,该中心是由北京西商国际心理医学研究院联合国内外有关资深健康管理专家,共同成立的一个非赢利性的考评管理机构。RHC注册健康管理师考评管理中心是根据2020年7月20日国家…...

    2024/4/25 1:45:36
  2. 真Unity3d_分享一下UI

    谈一下很久没谈的UI,虽然之前也分享过一些UI的Unity插件好像一直以来很不屑UI,包括我,还有其他很多很多人有些同事工作2年,写的一手好UI,分享项目也是纯客户端,纯UI,连逻辑都省了看到某些面试官问UGUI和NGUI就烦,都5年没用过NGUI了,你还问??当然这5年也肯定不少团队…...

    2024/4/24 22:27:26
  3. Netty——经典面试题

    TCP和UDP的根本区别TCP面向连接,如打电话要先拨号建立连接;UDP是无连接的,即发送数据之前不需要建立连接 TCP提供可靠的服务。也就是说,通过TCP连接传送的数据,无差错,不丢失,不重复,且按序到达;UDP尽最大努力交付,即不保证可靠交付 TCP通过校验和、重传控制、序号标…...

    2024/4/11 19:54:24
  4. 个人身份认证接口介绍

    个人身份认证接口主要是用于互联网核验用户信息的真实性,比如在各类网站发布信息需要实名、注册域名需要实名、办理固定电话入网需要实名、线上购买金融产品需要实名等,总之,在很多业务场景中都会需要用户进行实名,这不仅仅是业务需求还是法规要求,同时要想确保实名信息的…...

    2024/4/24 5:40:30
  5. Hive源码阅读--导读

    总述 Hive的执行流程大致分为两部分,即任务的提交与返回,命令的编译与执行。 前者在CliDriver类中流转,后者主要在Driver与ParseDriver类,核心编译在BaseSemanticAnalyzer和QueryPlan类中。 任务的提交与返回 调用顺序:main --(程序的开始)–> run --(任务的开始,读取…...

    2024/4/24 12:46:38
  6. oracle学习笔记,完整目录结构

    Oracle学习笔记 1、sql执行顺序 1、常见的select、from、where的顺序from -> where -> select 2、完整的select、from、where、group by、having、order by的顺序from -> where -> group by -> having -> select -> order by2、oracle组成 1、参数文件,口…...

    2024/5/1 7:45:23
  7. 【JAVA】安装jdk和集成开发环境MyEclipse\Eclipse\Intellij IDEA (64位 Window10)并运行代码检验实验环境安装成功,Hello World!

    JAVA实验一 Hello World! (一)实验任务: 1、安装jdk和对应的编辑器; 2、在编辑器里写入:Hello World!生成Java文件,并运行结果。 (二)实验方法 参考官方文档,进行按步骤的下载和安装,熟悉实验环境。 我的电脑环境: Windows10 64位操作系统 建议每次下载时,新建一个…...

    2024/4/24 17:44:40
  8. 使用POI给word文档加水印

    在网上收罗了半天 发现大多数解决方案在word含有页眉的时候会报错 我整理了如下代码 希望以后不要在遇到这样的坑。 本文使用的poi版本为 poi-4.1.2, poi-scratchpad-4.1.2, poi-ooxml-schemas-4.1.2, poi-ooxml-4.1.2 import java.io.FileNotFoundException; import java.io.F…...

    2024/4/11 19:54:18
  9. 格式化json字符串

    格式化以后的效果1.上代码/*** 格式化** @param jsonStr* @return* @author peng2.li(李鹏1203962)* @Date 2015-10-14 下午1:17:35* @Modified 2017-04-28 下午8:55:35*/public String formatJson(String jsonStr) {if (null == jsonStr || "".equals(jsonStr))ret…...

    2024/5/5 3:29:58
  10. Springboot整合Shiro 完整版

    1.shiro是什么? Apache Shiro是一个强大且易用的Java安全框架,执行身份验证、授权、密码和会话管理。使用Shiro的易于理解的API,您可以快速、轻松地获得任何应用程序,从最小的移动应用程序到最大的网络和企业应用程序。 官方架构图如下:2.主要功能 shiro主要有三大功能模块:…...

    2024/4/11 19:54:16
  11. 面试精选

    面试精选数据类型面向对象集合框架多线程ServletJSPJDBCMySQLSpringSpringMVCMybatisSpringBootSpringCloudRedisSolrElasticSearchNginxDubbo&Zookeeper**Zookeeper同步流程**FastDFSLinuxDocker 数据类型java中基本数据类型各占多少字节? byte:1字节 short:2字节 int:…...

    2024/4/25 13:02:30
  12. 怎么给自己Linux远程登录设置:SSH证书登录

    SSH 是服务器登录工具,提供密码登录和密钥登录。但是,SSH 还有第三种登录方法,那就是证书登录。很多情况下,它是更合理、更安全的登录方法,本文就介绍这种登录方法。 一、非证书登录的缺点密码登录和密钥登录,都有各自的缺点。密码登录需要输入服务器密码,这非常麻烦,也…...

    2024/4/11 19:54:14
  13. 如何刷提高直播间真实观看人数人气及点击获得更高收入

    到现在直播模式已经深入各个领域中,尤其是偶像明星的加入,让不少直播平台都充满着生机,热闹非凡,而直播的形式也逐渐引领了互联网的又一个高潮,不少网红主播就出自于直播间中,他们依靠所获得的在线人数以及人气,每次直播都可以赚取不少的酬劳。 随着全民直播时代的到来,…...

    2024/4/25 3:17:01
  14. rtable

    对于创建路由表项,系统着会再调用rt_new来继续工作rt_new函数会对我们传入的参数进行判断,看是否符合创建路由表项的条件。首先,函数先从传入的rt.rt_dev来判断要创建路由表项的设备是否存在,如果不存在则退出,因为创建一个路由表项,其实就是要对路由表项结构体的各个成员…...

    2024/4/11 19:54:13
  15. 跟我一起学.NetCore之选项(Options)核心类型简介

    前言.NetCore中提供的选项框架,我把其理解为配置组,主要是将服务中可供配置的项提取出来,封装成一个类型;从而服务可根据应用场景进行相关配置项的设置来满足需求,其中使用了依赖注入的形式,使得更加简单、便捷;另外和配置(Configuration)系统的无缝结合,使得服务更加灵…...

    2024/4/11 19:54:12
  16. 速围观!上千款“AI黑科技”在此集结

    尬舞机器人、AI虚拟主播、自动驾驶车、5G无人机、仿生人形机器人,在 AIExpo 展会上可谓吸足了眼球。8月14日,全球人工智能产品博览会(AIExpo 2020)在苏州国际博览中心盛大启幕。为期3天的智博会以“万物复苏,智启未来”为主题,在2万余平的展馆设置了12大重磅展区,集结了…...

    2024/4/24 11:58:52
  17. 华为 AR路由器点到多点ipsec 打通 后某分点不能访问主网段的服务器 ,求解答!!!

    华为 AR路由器点到多点ipsec 打通 后某分点不能访问主网段的服务器问题:分点2的网段ping不通主网络的0.150服务器;而分点1的网段ping可以通主网络的0.150服务器区别:现在2.0和1.0的区别就是 2.0是直接跑公网地址过去的 ;1.0是跑私网地址;二分地的路由器配置都是一样的.有…...

    2024/4/21 19:12:06
  18. Redis基础复习

    Redis 复习 文章目录Redis 复习一、基本介绍1.1 Redis 优势1.2 Redis与其他key-value存储有什么不同?1.3 编辑配置语法实例参数说明二、Redis的数据类型2.1 String(字符串)存储数据上限**注意:一个键最大能存储 512MB**2.2 Hash(哈希)每个 hash 可以存储232−12^{32}-123…...

    2024/4/17 16:06:50
  19. 小程序ColorUI使用简易教程

    本教程配合官方示例食用更佳!!!目录前言快速上手使用UniApp开发开始使用自定义导航栏使用原生小程序开发从现有项目开始从新项目开始使用自定义导航栏组件基础元素layout布局Background背景 Text文字Icon图标Button按钮Tag标签Avatar头像Progress进度条 Border&Shadow边…...

    2024/4/25 1:46:30
  20. windows小工具大全

    今天又给大家推荐一款windows的工具神器哦~~~~,快来尝鲜吧!!!核心工具箱(PC端)这是一款功能很强大,并且集合了多家神器于一身的软件,软件可以jihuo系统、GIF录屏、看各种电影、不限速下载或者diy自己的软件库等等超多使用功能!获取软件之后解压到电脑上,点击应用程序…...

    2024/4/24 13:59:00

最新文章

  1. TRIZ理论助力充电桩产业跨越技术瓶颈,实现产业升级!

    随着新能源汽车市场的迅猛发展和电动汽车保有量的不断增加&#xff0c;充电桩作为电动汽车的“能量补给站”&#xff0c;其重要性日益凸显。然而&#xff0c;充电桩产业在发展过程中也面临着诸多技术瓶颈&#xff0c;如何突破这些瓶颈&#xff0c;推动充电桩产业升级成为行业亟…...

    2024/5/6 16:58:23
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/5/6 9:38:23
  3. ubuntu添加固定路由

    方法&#xff1a; 我的解决方法 添加路由 sudo ip route add 10.xxx.xxx.0/25 via 1.xxx.xxx.xxx&#xff08;我的是虚拟机&#xff09;dev ens65 proto static metric122 删除路由 sudo ip route delete 10.xxx.xxx.0/25 gpt答案 添加路由 要在Ubuntu上添加路由&#xff0c;您…...

    2024/5/6 8:43:07
  4. audio_video_img图片音视频异步可视化加载

    最近在做即时消息&#xff0c;消息类型除了文字还有音频、视频、图片展示&#xff0c;如果消息很多&#xff0c;在切换聊天框时&#xff0c;会有明显卡顿&#xff0c;后续做了懒加载&#xff0c;方案是只加载用户能看到的资源&#xff0c;看不到的先不加载&#xff1b; LazyAud…...

    2024/5/6 12:26:53
  5. k8s_入门_kubelet安装

    安装 在大致了解了一些k8s的基本概念之后&#xff0c;我们实际部署一个k8s集群&#xff0c;做进一步的了解 1. 裸机安装 采用三台机器&#xff0c;一台机器为Master&#xff08;控制面板组件&#xff09;两台机器为Node&#xff08;工作节点&#xff09; 机器的准备有两种方式…...

    2024/5/4 14:33:56
  6. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/5 18:19:03
  7. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/5 12:22:20
  8. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/5 19:59:54
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/6 7:24:07
  10. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/5 15:25:47
  11. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/6 6:01:13
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/6 7:24:06
  13. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/6 1:08:53
  14. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/5 18:50:00
  15. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/6 0:27:44
  16. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/6 7:24:04
  17. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/6 7:24:04
  18. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/5 13:14:22
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/6 7:24:03
  20. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/5 17:03:52
  21. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/5 21:10:50
  22. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/6 7:24:02
  23. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/6 7:24:01
  24. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/5 17:03:21
  25. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/6 16:50:57
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57