一些小细节代码笔记汇总

Python

cv2抓取摄像头图片保存到本地

python 复制代码
import cv2
import datetime, os

savePath = "E:/Image/"

if not os.path.exists(savePath):
    os.makedirs(savePath)

cap = cv2.VideoCapture(0)
capture = False

if not cap.isOpened():
    print("无法打开摄像头")
    exit()

while True:
    ret, frame = cap.read()
    
    if not ret:
        print("无法接收帧 (stream end?). Exiting ...")
        break

    cv2.imshow('Image', frame)
    current_time = datetime.datetime.now().strftime("%Y%m%d_%H%M%S_%f")
    if capture:
        cv2.imwrite(os.path.join(savePath, current_time + ".jpg"), frame)
    
    key = cv2.waitKey(1) & 0xFF
    # 按下'q'键退出循环
    if key == ord('q'):
        break
    elif key == ord('s'):
        print("开始抓取图片")
        capture = True

cap.release()
cv2.destroyAllWindows()

cv2.waitKey(1) & 0xFF的作用是:

  • cv2.waitKey(1):等待1毫秒,检查是否有键盘输入。如果有输入,则返回按键的ASCII码值;如果没有输入,则返回-1。
  • & 0xFF:通过按位与操作,将返回值的高位清零,只保留低8位。这是因为在某些系统上,cv2.waitKey可能返回一个大于8位的整数,而我们只关心低8位的ASCII码值。

这样做的目的是确保代码在不同平台上都能正确处理键盘输入。例如,在Windows和Linux系统上,cv2.waitKey的返回值可能有所不同,通过& 0xFF可以统一处理这些差异。

相关推荐
冬奇Lab5 分钟前
Agent 系列(22):Context Engineering 深度——三种上下文管理策略的量化对比
人工智能·agent
hboot7 分钟前
AI工程师第二课 - 数据处理
人工智能·python·数据分析
程序员cxuan26 分钟前
DeepSeek 杀入多模态,识图功能正式上线!
人工智能·后端·程序员
米小虾2 小时前
告别单打独斗:2026年多Agent协作架构实战指南
人工智能·agent
IT_陈寒3 小时前
SpringBoot这个自动配置坑我跳了三次
前端·人工智能·后端
Larcher4 小时前
AI Loop:让AI像人一样自主完成任务的核心机制
javascript·人工智能·设计模式
牧艺4 小时前
从零到协同:构建类飞书在线文档系统的五个技术重难点
前端·人工智能
CodePlayer竟然被占用了5 小时前
Codex 用电脑的三种姿势:选错模式,你就白烧 Token
人工智能
袋鼠云数栈UED团队5 小时前
一套 Spec-First 的 AI 编程工作流
前端·人工智能