运行前先下载yolov3的配置文件等,包括:coco.names,yolov3.cfg,yolov3.weights三个文件,可通过wget下载

wget https://github.com/pjreddie/darknet/blob/master/data/coco.names?raw=true -O ./coco.names
wget https://github.com/pjreddie/darknet/blob/master/cfg/yolov3.cfg?raw=true -O ./yolov3.cfg
wget https://pjreddie.com/media/files/yolov3.weights

新建测试类,引入如上三个配置文件。

package com.zk.tobacco.util.yolo;import com.zk.tobacco.util.yolo.modal.BBox;
import org.opencv.core.*;
import org.opencv.dnn.Dnn;
import org.opencv.dnn.Net;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.*;
import java.util.ArrayList;
import java.util.List;import static org.opencv.highgui.HighGui.namedWindow;
import static org.opencv.imgcodecs.Imgcodecs.imread;
import static org.opencv.imgproc.Imgproc.putText;/*** Copyright (C), 2020-2020* FileName: OpencvYolo3* Author: PJJ* Date: 2020/7/29 12:08* Description: openYolo3*/
public class OpencvYolo3 {static String pro_dir = "D:\\yanchongjiance\\yolo3\\";   // 根路径static float confThreshold = 0.3f;  // 置信度阈值static float nmsThreshold = 0.4f;   // iou阈值static int inpWidth = 416;          // 修改输入图片的宽高static int inpHeight = 416;static List<String> classes = new ArrayList<String>();  // 存放类别的列表static int FONT_HERSHEY_SIMPLEX =1;static int WINDOW_NORMAL=416;public static void main(String[] args) throws Exception{System.loadLibrary(Core.NATIVE_LIBRARY_NAME);//加载配置文件:配置 权重 图片路径 类别文件String modelConfiguration = pro_dir + "yolov3-voc.cfg"; // 模型配置文件String classesFile = pro_dir + "voc.names"; // 模型可识别类别的标签文件String modelWeights = pro_dir + "yolov3.weights"; // 模型权重文件String image_path = "D:\\yanchongjiance\\150\\1.jpg"; //要检测的图片// 进入识别图片的方法detect_image(image_path, modelWeights, modelConfiguration, classesFile);//waitKey(0);}//    检测图片public static void detect_image(String image_path, String modelWeights, String modelConfiguration, String classesFile) throws Exception {// 读取classesFile路径的文件InputStream in = new FileInputStream(classesFile);int iAvail = in.available(); // 适用于本地一次读取多个字节时,返回得到的字节数。byte[] bytes = new byte[iAvail];in.read(bytes);String allContent = new String(bytes); // 文件中的所有内容String[] tempContent = allContent.trim().split("\n"); // allContent去除首尾空格,再按换行符分割。System.out.println(tempContent.length);// 遍历tempContent,添加到保存类别名的列表classes里。for (int i = 0; i < tempContent.length; i++) {classes.add(tempContent[i]);}System.out.println(classes.size());//加载网络配置与训练权重的文件,构建网络Net net =  Dnn.readNetFromDarknet(modelConfiguration, modelWeights);net.setPreferableBackend(Dnn.DNN_BACKEND_OPENCV);net.setPreferableTarget(Dnn.DNN_TARGET_OPENCL);//读入图片,配置宽高Mat im = imread(image_path, Imgcodecs.IMREAD_COLOR); // 读入待检测的图片// 当前是以窗体的形式查看检测后的图片,给窗体命名final String kWinName = "my OpenCV";namedWindow(kWinName, WINDOW_NORMAL);// 将输入图片的宽高重新设置 (416, 416)Mat frame = new Mat();Size sz1 = new Size(im.cols(), im.rows());Imgproc.resize(im, frame, sz1);Mat resized = new Mat();Size sz = new Size(inpWidth, inpHeight);Imgproc.resize(im, resized, sz);float scale = 1.0F / 255.0F; // 像素归一化List<String> ln = net.getLayerNames(); // 获得YOLO各层的名字List<String> x = new ArrayList<String>();List<List<Integer>> out = new ArrayList<List<Integer>>(); // 存放的是列表List<Integer> temp = net.getUnconnectedOutLayers().toList(); // 获得未连接的输出层的索引列表out.add(temp);// out中存放的是一个List ,get(0)得到的就是list i 索引列表List<Integer> i = out.get(0);System.out.println(i.size()); // 3for(int a=0; a<i.size(); a++){String n = ln.get(i.get(a)-1); // 输出层的名字x.add(n); // 找到所有的输出层}ln = x; // 给ln重新赋值System.out.println(ln); // [yolo_82, yolo_94, yolo_106]// 矩阵列表 [Mat[...], Mat[...], Mat[...]]List<Mat> outs = new ArrayList<Mat>();net.forward(outs, ln); // ln此时为输出层的名字列表,向前传播,将得到的检测结果传入outsSystem.out.println(outs);// 进入检测识别方法postprocess_(im, outs);// 检测结束后显示图片//imshow(kWinName, im); // 显示图片// waitKey(300000);}/*** 图片检测识别方法* @param im* @param outs*/public static void postprocess_(Mat im, List<Mat> outs) {System.out.println("检测过程开始");List<Rect> boxes = new ArrayList<Rect>(); // 矩形框列表List<Integer> classIds = new ArrayList<Integer>(); // 类的序号列表List<Float> confidences = new ArrayList<Float>(); // 置信度列表
//        HashMap<String, Object> predicts_dict = new HashMap<String, Object>();// 循环List<Mat>for (int i = 0; i < outs.size(); i++) {Mat mat = outs.get(i);// 循环每一个mat对象// 按行循环for (int j = 0; j < mat.rows(); j++) {int probaility_index = 5; // [x,y,h,w,c,class1,class2] 所以是标号5int size = (int) (mat.cols() * mat.channels());float[] data = new float[size];mat.get(j, 0, data);float confidence = -1;int classId = -1;// 按列循环for (int k = 0; k < mat.cols(); k++) {// 相当于[5:] np.argmax(scores)if (k >= probaility_index && confidence < data[k]) {confidence = data[k]; // 最大值classId = k - probaility_index; // 得到检测得的类别索引}}// 过滤掉置信度较小的检测结果if (confidence > 0.5) {System.out.println("Result  Object:" + j);for (int k = 0; k < mat.cols(); k++) {System.out.println(" " + k + ":" + data[k]);}System.out.println("");float x = data[0]; // centerX 矩形中心点的X坐标float y = data[1]; // centerY 矩形中心点的Y坐标float width = data[2]; // 矩形框的宽float height = data[3]; //矩形框的高float xLeftBottom = (x - width / 2) * im.cols(); // 矩形左下角点的X坐标float yLeftBottom = (y - height / 2) * im.rows(); // 矩形左下角点的Y坐标float xRightTop = (x + width / 2) * im.cols(); // 矩形右上角点的X坐标float yRightTop = (y + height / 2) * im.rows(); // 矩形右上角点的Y坐标// boxes列表填值 Rect对象,参数是两个点boxes.add(new Rect(new Point(xLeftBottom, yLeftBottom), new Point(xRightTop, yRightTop)));confidences.add(confidence);classIds.add(classId);}}}System.out.println(classIds);System.out.println(confidences);System.out.println(boxes.size());System.out.println(boxes);// 非极大值抑制List<Integer> indices = new ArrayList<Integer>();// 此处的非极大值抑制为自己重写的方法。NMSBoxes(boxes, confidences, confThreshold, nmsThreshold, indices);List<Mat> cutImages = new ArrayList<Mat>();Mat cut;int a = 0;// indices : 最终剩下的按置信度由高到低的矩形框序号if (indices.size() > 0) {for (int b = 0; b < indices.size(); b++) {a = a + 1;Rect box = boxes.get(indices.get(b));Point p1 = box.tl(); // 获得左 上角点Point p2 = box.br(); // 获得右下角点int classId = classIds.get(a - 1); // 得到类别序号float confidence = confidences.get(a - 1); // 得到置信度值// 进入画框框方法drawPred_(classId, confidence, im, p1, p2);// 将每个矩形框裁剪cut = im.submat((int)p1.y, (int)p2.y, (int)p1.x, (int)p2.x);cutImages.add(cut);}}System.out.println(cutImages);// 将裁剪后的图片存入本地路径(可省略)String outputFilePath = "D:\\yanchongjiance\\out";for (int i=0; i<cutImages.size(); i++){Mat mat  = cutImages.get(i);MatOfByte mob = new MatOfByte();Imgcodecs.imencode(".jpg", mat, mob);byte[] byteArray = mob.toArray();ByteArrayInputStream in = new ByteArrayInputStream(byteArray);try {BufferedImage image = ImageIO.read(in);OutputStream bOut = new FileOutputStream(outputFilePath + "/" + i + ".jpg");ImageIO.write(image, "jpg", bOut);} catch (IOException e) {e.printStackTrace();}}}//重写的非极大值抑制方法public static void NMSBoxes(List<Rect> boxes, List<Float> confidences, float confThreshold, float nmsThreshold, List<Integer> indices){// 新建一个List 存放BBox的对象List<BBox> bboxes = new ArrayList<BBox>();// 循环向bboxes里添加值:Rect(Point,Point) float confidence, int indexfor(int i=0; i<boxes.size(); i++){BBox bbox = new BBox();bbox.box = boxes.get(i);bbox.confidence = confidences.get(i);bbox.index = i;bboxes.add(bbox);}// 排序算法 根据confidence的属性值,降序排列List bboxesfor (int i = 0; i < bboxes.size(); i++) {for (int j = 0; j < bboxes.size() - i - 1; j++) {if (bboxes.get(j).confidence < bboxes.get(j + 1).confidence) {BBox temp = bboxes.get(j);bboxes.set(j, bboxes.get(j + 1));bboxes.set(j+1, temp);}}}//        for(int i=0; i<bboxes.size(); i++){
//            System.out.println(bboxes.get(i).confidence);
//        }int updated_size = bboxes.size();System.out.println("bboxes.size(): " +bboxes.size());// 循环删除for (int i=0; i<updated_size; i++){// 如果list中的box置信度小于阈值,跳出循环if (bboxes.get(i).confidence < confThreshold){continue;}// indices存放最终剩下的按置信度由高到低的矩形框的序列号indices.add(bboxes.get(i).index);// 比较第一个值( 最大值)与后面每一个值的交并比// 如果iou>阈值,删除这个框,更改bboxes的长度for (int j=i+1; j<updated_size; j++){float iou = getIouValue(bboxes.get(i).box, bboxes.get(j).box);if(iou > nmsThreshold){bboxes.remove(j);updated_size = bboxes.size();}}}}//获得交并比的方法public static float getIouValue(Rect rect1, Rect rect2){int xx1, yy1, xx2, yy2;xx1 = Math.max(rect1.x, rect2.x);yy1 = Math.max(rect1.y, rect2.y);xx2 = Math.min(rect1.x + rect1.width - 1, rect2.x + rect2.width - 1);yy2 = Math.min(rect1.y + rect1.height -1, rect2.y + rect2.height -1);int insection_width, insection_height;insection_width = Math.max(0, xx2 - xx1 + 1);insection_height = Math.max(0, yy2 - yy1 + 1);float insection_area, union_area, iou;insection_area = insection_width * insection_height;union_area = rect1.width * rect1.height + rect2.width * rect2.height - insection_area;iou = insection_area / union_area;return iou;}//画矩形框,添加文字标签public static void drawPred_(int classId, float confidence, Mat im, Point p1, Point p2){String text;double x = p1.x; // p1 的 x 坐标double y = p1.y; // p1 的 y 坐标// 下面加if语句只是为了区分人和其他类别的不同颜色,改成随机获取颜色也可以if(classId == 0){System.out.println("1");rectangle(im, p1, p2, new Scalar(0, 0, 255), 3);text = classes.get(classId) + ":" + confidence;putText(im, text, new Point(x, y-5), FONT_HERSHEY_SIMPLEX, 0.3, new Scalar(0, 255, 0), 1);}else {System.out.println("2");rectangle(im, p1, p2, new Scalar(0, 255, 0), 3); // 画框text  = String.format("%s %f", classes.get(classId), confidence); // 标签内容System.out.println(text);// 把标签添加到矩形框左上putText(im, text, new Point(x, y-5), FONT_HERSHEY_SIMPLEX, 0.5, new Scalar(0, 0, 255), 1);}}private static void rectangle(Mat im, Point p1, Point p2, Scalar scalar, int i) {}}
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. elasticsearch 的基本查询

    转载:https://blog.csdn.net/qq_37129281/article/details/89293591?utm_medium=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.channel_param&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLear…...

    2024/5/10 5:14:33
  2. 谷歌浏览器chrome:0x80040154无法更新

    解决:https://www.minitool.com/news/google-chrome-update-error-fix.html本人用了方案三四,服务的话win+s搜索 服务 打开。注册表没有这个路径的话自己建...

    2024/5/10 11:30:42
  3. 在线教育巨头3P大战 猿辅导可能第一个倒下

    今年暑期虽然已过,但各大在线教育平台之间的竞争却不会停息。暑假期间,国内几大在线教育平台持续“短兵相接”,相关数据统计信息显示,为了在暑期招生之战中获得优势,国内几大在线教育平台开启了重金投入的广告大战,广告投放总额至少已经达到了40亿元人民币,潜力仍然巨大…...

    2024/5/9 13:15:59
  4. 为什么要先commit,然后pull,最后再push?而不是commit然后直接push?

    转载:https://www.cnblogs.com/leiblog/p/11138497.html 【Git版本控制】为什么要先commit,然后pull,最后再push?而不是commit然后直接push? 情况是这样的,现在远程有一个仓库,分支就一个,是master。然后我本地的仓库是从远程的master上clone下来的。大家都是clone下来…...

    2024/5/5 5:20:10
  5. python PIL模块知识点

    简介:Pillow是Python Imaging Library的简称,是Python语言中最为常用的图像处理库。Pillow库提供了对Python3的支持,为Python3解释器提供了图像处理的功能。通过使用Pillow库,可以方便地使用Python程序对图片进行处理,例如常见的尺寸、格式、色彩、旋转等处理。 1.Image打…...

    2024/5/9 7:38:45
  6. jQuery操作iframe元素

    jQuery操作iframe元素 深度踩坑干货原理: 深度踩坑 今天做了一个后台管理的新手引导界面,就需要操作iframe里面的元素了,网上百度了好多,前篇一律最终在一个不知名的博客上找到了,还是乱码,中文符号什么的,整理了一下,希望能帮到大家,喜欢的小伙伴可以来个-三连-吆! …...

    2024/5/9 2:39:40
  7. IPV6功能

    如何判断终端是否实现IPV6功能?联网 终端实现以IPV6协议接入网络,包括DHCP、PPOE、IPOE、LAN 具体体现:有线方式成功接入网络之后,能够返回IPV6的信息,如IP地址,DNS地址,默认网关等信息。 DNS解析 终端向DNS服务器请求资源,DNS服务器下发IPV6地址,终端能解析IPV6地址,…...

    2024/5/10 4:20:23
  8. Queue.queue 退出与阻塞

    Queue.queue 退出与阻塞#-*-coding:utf-8-*- import threading import queue import time import random 1.创建一个 Queue.Queue() 的实例,然后使用数据对它进行填充。 2.将经过填充数据的实例传递给线程类,后者是通过继承 threading.Thread 的方式创建的。 3.每次从队列中取…...

    2024/5/5 5:48:30
  9. [转载] C++工程里一个文件怎么调用另外一个文件里的函数

    目录[转载] C++工程里一个文件怎么调用另外一个文件里的函数前提声明方法1. 直接在调用前,写函数声明2. 将声明写在头文件中举例参考 [转载] C++工程里一个文件怎么调用另外一个文件里的函数注:转载文章,侵删 来源:C++工程里一个文件怎么调用另外一个文件里的函数 作者:风…...

    2024/5/10 12:14:55
  10. vue表单validate验证手机号、座机号、邮箱、微信号

    目录手机号验证座机号验证邮箱验证微信号验证 手机号验证 /*自带的type属性:phone、email、date*/ <el-form-item prop="phone" label="手机号" :rules="[{ required: true, message: 请输入手机号, trigger: blur },{ type: phone, message: 请输…...

    2024/5/8 8:47:25
  11. DDOS都有哪些攻击方式?

    目前,DDOS攻击已经不在网络安全界的新客,但作为老客的它已经变的越来越复杂。黑客不断提出新的攻击方案以便于绕过安全部门所制定的防御计划,进而对企业造成利益的损害。但安全提供商在防御技术上的研究也并没有就此停止脚步,反而更加积极的推出新的解决方案来组织黑客攻击…...

    2024/5/9 0:41:01
  12. Why and How zk-SNARK Works 1: Introduction & the Medium of a Proof

    Why and How zk-SNARK Works 1: Introduction & the Medium of a Proof Author:Maksym Address:原文地址 Despite the existence of multiple great resources on zk-SNARK construction, from original papers [Bit+11; Par+13] to explainers [Rei16; But16; But17; Gab1…...

    2024/5/5 7:59:00
  13. CSS实现单行、多行文本溢出显示省略号(…)

    CSS实现单行、多行文本溢出显示省略号(…) 如果实现单行文本的溢出显示省略号同学们应该都知道用text-overflow:ellipsis属性来,当然还需要加宽度width属来兼容部分浏览。 实现方法: overflow: hidden; text-overflow:ellipsis; white-space: nowrap;效果如图:但是这个属性…...

    2024/5/5 10:17:42
  14. tesseract安装及环境配置

    tesseract安装及环境配置下载 链接:https://digi.bib.uni-mannheim.de/tesseract/安装 没有多余要求,默认安装就可以,有需要可以更改安装位置的! 记住安装路径!!!!!! 配置环境变量名:TESSDATA_PREFIX 变量值:安装路径\tessdata 验证pytesseract安装及环境配置安装p…...

    2024/5/5 5:11:20
  15. 离线安装MinGW (gcc)

    文章目录在线安装离线安装 linux 系统一般自带gcc编译器, 方便开发c/c++。gcc 不能直接在Windows上使用,但是我们可以用gcc 的Windows移植版MinGW,Cygwin等。 Cygwin用过一次,感觉还是MinGW好用。 下面介绍MinGW的安装。 在线安装 在线安装请参考这个链接https://blog.csdn.n…...

    2024/5/5 4:29:30
  16. 刷脸支付解决了用户忘带手机的尴尬

    当我们还在感慨二维码支付如何便捷时,“刷脸”支付已经悄然兴起,相对于二维码支付,“刷脸”支付真正让我们脱离了手机的操作步骤,只靠一张脸就可以解决“衣”、“食”、“住”、“行”,同时“刷脸”支付大大提高了收银效率,节省了商家的人力成本,可以说消费者和商家对于…...

    2024/5/6 1:28:59
  17. 配置nginx

    1,准备工作 1>三台虚拟机 2>一个spring—boot项目jar包 2,安装nginx 1,在一台虚拟机上安装nginx 1.上传nginx安装包 2.解压nginx tar -zxvf nginx-1.12.2.tar.gz -C /usr/local/src/ 3.进入到nginx的源码目录 cd /usr/local/src/nginx-1.12.2/ 4.预编译 ./configure 5…...

    2024/5/5 14:11:50
  18. 【MATLAB】没错,MATLAB也可以玩“超级玛丽”!

    写作时间:2020-07-29 目录: 1.先玩玩 2.下载链接 3.代码讲解 正文 1.先玩玩2.下载链接这是一个大神写的,下面是链接。 超级玛丽MATLAB版本–下载链接 点击appinstall安装。 3.代码理解 后续写。今天先玩儿~THE END~...

    2024/5/6 19:50:28
  19. 12个免费开源后台管理系统模板

    当你写项目的时候,如何快速的完成一个项目的搭建,这个时候就需要借助到一些模板了,前端开发的一个好处就是,各类UI模板都是相当的齐全的,直接拿来用就可以了,脱离了一行又一行垒代码的繁琐的工作,以下的开源后台管理系统模板是我在逛GitHub的时候看到的,排名先后是按照…...

    2024/5/7 6:22:02
  20. magento2 addCount和getCount相关计数方法

    计数的方法逻辑(自我理解)(material可换) 1、model下的MaterialRepository.php写计数的方法 public function addCount($materialId=null,$offset=1){if($materialId){$material = $this->materialFactory->create();$material->load($materialId);$count=$materi…...

    2024/5/7 8:25:25

最新文章

  1. Go-Zero自定义goctl实战:定制化模板,加速你的微服务开发效率(四)

    前言 上一篇文章带你实现了Go-Zero和goctl&#xff1a;解锁微服务开发的神器&#xff0c;快速上手指南&#xff0c;本文将继续深入探讨Go-Zero的强大之处&#xff0c;并介绍如何使用goctl工具实现模板定制化&#xff0c;并根据实际项目业务需求进行模板定制化实现。 通过本文…...

    2024/5/10 13:50:36
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/5/9 21:23:04
  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/10 8:40:06
  4. K8S容器空间不足问题分析和解决

    如上图&#xff0c;今天测试环境的K8S平台出现了一个问题&#xff0c;其中的一个容器报错&#xff1a;Free disk space below threshold. Available: 3223552 bytes (threshold: 10485760B)&#xff0c;意思服务器硬盘空间不够了。这个问题怎么产生的&#xff0c;又怎么解决的呢…...

    2024/5/9 13:07:02
  5. 贪心算法|376.摆动序列

    力扣题目链接 class Solution { public:int wiggleMaxLength(vector<int>& nums) {if (nums.size() < 1) return nums.size();int curDiff 0;int preDiff 0;int result 1;for (int i 0; i < nums.size() - 1; i) {curDiff nums[i 1] - nums[i];if ((pre…...

    2024/5/10 0:17:07
  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/10 1:36:26
  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/9 7:40:42
  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/9 2:44:26
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

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

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

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

    2024/5/10 8:07:24
  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/9 5:40:03
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

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

    2024/5/10 8:16:30
  13. 【ES6.0】- 扩展运算符(...)

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

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

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

    2024/5/10 2:07:43
  15. Go语言常用命令详解(二)

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

    2024/5/9 4:12:16
  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/9 7:40:35
  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/9 19:47:07
  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/10 10:17:11
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

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

    2024/5/10 2:07:41
  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/9 5:02:59
  21. 基于深度学习的恶意软件检测

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

    2024/5/9 4:31:45
  22. JS原型对象prototype

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

    2024/5/9 16:54:42
  23. C++中只能有一个实例的单例类

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

    2024/5/10 1:31:37
  24. python django 小程序图书借阅源码

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

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

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

    2024/5/10 10:40:03
  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