超简洁YOLO8n快速上手人员检测

基于Python 的cv2和ultraytics库,直接调用yolov8n.ptyolov8n.ptUltralytics YOLOv8 目标检测系列中最小、最轻量的官方预训练模型)

1、安装依赖

复制代码
pip install ultralytics -i https://pypi.tuna.tsinghua.edu.cn/simple
pip install opencv-python

2、加载模型

复制代码
from ultralytics import YOLO

# 加载模型(自动下载,只需要这一行)
model = YOLO("yolov8n.pt")

3、开始识别(单张图和监控识别)

复制代码
from ultralytics import YOLO
import cv2

# 1. 加载模型
model = YOLO("yolov8n.pt")

# 2. 识别(只检测人,置信度 0.4)
results = model("你的图片.jpg", classes=[0], conf=0.4)

# 3. 读取图片画框
img = cv2.imread("你的图片.jpg")

for r in results:
    for box in r.boxes:
        x1, y1, x2, y2 = map(int, box.xyxy[0])
        cv2.rectangle(img, (x1, y1), (x2, y2), (0,255,0), 2)
        cv2.putText(img, "PERSON", (x1,y1-10), cv2.FONT_HERSHEY_SIMPLEX, 1, (0,255,0), 2)

# 保存
cv2.imwrite("result.jpg", img)
  • classes=[0]只检测人
  • conf=0.4置信度 40% 就识别
  • model()AI 推理核心
  • box = 一个人在图片里的 "位置方框"

监控头识别

复制代码
from ultralytics import YOLO

model = YOLO("yolov8n.pt")
model.predict(source=0, show=True)  # 0=摄像头

def local_inference(img_path):
    model = YOLO("yolov8n.pt")
    results = model(img_path, classes=[0], conf=0.4)
    
    persons = []
    for r in results:
        for box in r.boxes:
            x1, y1, x2, y2 = map(int, box.xyxy[0])
            persons.append({
                "Box": {
                    "X": x1,
                    "Y": y1,
                    "Width": x2-x1,
                    "Height": y2-y1
                },
                "label": "person",
                "Score": float(box.conf)
            })
    return {"result": persons}

下面是一段测试的照片识别项目

复制代码
import os
import cv2
from ultralytics import YOLO

# ===================== 你的路径(完全按你要求) =====================
BASE_DIR = r"C:\AI_project\person_detect"
PicPath = os.path.join(BASE_DIR, "pic")          # 原图在这里
DetectPicPath = os.path.join(BASE_DIR, "detect_pic")  # 打框图输出到这里
os.makedirs(DetectPicPath, exist_ok=True)

# ===================== 加载YOLO模型 =====================
model = YOLO("yolov8n.pt")

# ===================== 要检测的图片(你那张图) =====================
img_name = "safe.jpg"  # <--- 改成你图片真实名字!!!
img_path = os.path.join(PicPath, img_name)

# ===================== 开始检测(只检测人) =====================
results = model(img_path, conf=0.2, classes=[0])  # conf=0.2 超低门槛,必检出!

# ===================== 读取图片 + 画框 =====================
img = cv2.imread(img_path)

for r in results:
    for box in r.boxes:
        # 获取坐标
        x1, y1, x2, y2 = map(int, box.xyxy[0])
        # 画绿色框
        cv2.rectangle(img, (x1, y1), (x2, y2), (0, 255, 0), 3)
        # 写文字
        cv2.putText(img, "PERSON", (x1, y1-10), cv2.FONT_HERSHEY_SIMPLEX, 1, (0,255,0), 2)
        #cv2.putText(img, "illegal", (x1+10, y1 + 10), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 255, 0), 2)

# ===================== 保存到 detect_pic =====================
save_path = os.path.join(DetectPicPath, f"detected_{img_name}")
cv2.imwrite(save_path, img)

print(f"✅ 检测完成!已保存到:{save_path}")
print(f"✅ 一共检测到 {len(results[0].boxes)} 个人!")

在pic目录下保存safe.jpg运行后生成图如下

相关推荐
财经资讯数据_灵砚智能2 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(日间)2026年4月10日
人工智能·python·信息可视化·自然语言处理·ai编程
啦啦啦_99992 小时前
0. Python进阶概要
python
weixin_408099672 小时前
OCR 识别率提升实战:模糊 / 倾斜 / 反光图片全套优化方案(附 Python / Java / PHP 代码)
图像处理·人工智能·后端·python·ocr·api·抠图
翻斗包菜2 小时前
Python 网络编程从入门到精通:TCP/UDP/Socket 实战详解
网络·python·tcp/ip
七颗糖很甜3 小时前
雨滴谱数据深度解析——从原始变量到科学产品的Python实现【下篇】
python·算法·pandas
爱码小白3 小时前
MySQL 常用数据类型的系统总结
数据库·python·算法
xcbrand3 小时前
专精特新品牌全案公司有哪些
大数据·人工智能·python
橘子编程3 小时前
GoF 23 种设计模式完整知识总结与使用教程
java·c语言·开发语言·python·设计模式
枫叶林FYL3 小时前
【Python高级工程与架构实战】项目五:生产级LLM Agent框架:基于PydanticAI的类型安全企业级实现
python·安全·架构