QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2817|回复: 0
打印 上一主题 下一主题

opencv逐帧获取视频图片

[复制链接]
字体大小: 正常 放大

1186

主题

4

听众

2923

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 10:47 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
背景* ^; C  w9 _( P7 K/ p
由于我要做一个深度学习方向的计算机视觉项目,需要一些数据集来进行训练,我便想尝试捕获视频中的图片用来标注。: u" k( b, S7 @6 y

1 g6 }+ w2 B) ]& P7 n注意事项, e7 p; \/ L* \6 L% B9 X) c
如果视频中的场景单一,那么使用该视频获取的数据集训练出的模型面对其他场景的泛化能力就会受到限制。为了提高数据集的多样性,可以采用多种不同场景的视频,并且在获取数据时采用大间隔捕获的方式。采用大间隔捕获数据的方法可以捕获到的图片同质化降低,从而进一步增加数据集的多样性。
  1. import os+ g; O2 a- L6 J/ c5 m
  2. import sys
    - G% e, x- V; @$ p2 k* J  T
  3. from concurrent.futures import ThreadPoolExecutor
    # B3 _+ r, a7 L& g  `
  4. import cv2
    ) s1 T' P  O% J* N+ p0 i% G

  5. 0 _* I% D8 v5 J8 f8 h! K
  6. def output_img(video_path,img_dir):
    : z7 W6 j: H7 l$ e& k. P
  7. #     由视频逐帧输出图片7 O& y3 Z' D1 P5 y5 ^
  8. #     video_path: 视频文件路径/ g/ H$ I! R2 @! M7 W
  9. #     img_dir: 图片保存目录路径,路径不支持中文
    / ^# r/ U3 {6 j3 [0 Q3 ~
  10.     os.makedirs(img_dir,exist_ok=True)
    ) n6 o0 M  D* f; o2 W1 ?( q
  11. #     img_dir:表示要创建的目录路径。. s: Q7 F5 o3 c* _4 Q
  12. #     exist_ok=True:表示如果目录已经存在时不抛出异常。如果将 exist_ok 设置为 True,那么如果目录已经存在,os.makedirs() 函数也不会报错;如果设置为 False,则会抛出一个 FileExistsError 异常。- {9 ~7 f5 p( B6 Q6 ~5 O: R9 ?, `
  13.     cv = cv2.VideoCapture(video_path)
    3 u. R5 ~: z$ _! A7 h\" Q
  14.     frame_count = 0
    8 G* x0 [# D/ m8 L* D9 b
  15.     # 计数器# e3 L4 v, U) J& m7 x, V* V( I
  16.     n = 04 h, ~# l6 j* j
  17.     # 命名计数器
    + M5 I; ^8 e) O4 M* x& H* E' ^
  18.     while True:
    + g' U6 x5 g7 ^4 }\" ^
  19.         ret,frame = cv.read(); Y: N1 e/ {9 K( q) M9 m# ]
  20.         if not ret:
    7 A% v! r+ s0 a& M/ D; ^
  21.             break
    3 ]; _+ |  p7 J\" j\" p. t
  22.         frame_count += 1
    # {  V4 M/ U, C
  23.         if frame_count % 30 ==0:
    ) b; G5 B& r2 A8 v$ `4 @
  24.             # 每隔三十帧获取一次图片8 h, t\" a: Z) c% a( O+ S& f- b  @
  25.             n += 1; I) Y  M) O* U% w2 W* ^5 I
  26.             img_name = "0000000{0}.jpg".format(n)
    4 Z9 B$ c  c7 y& F- q& x. U
  27.             img_file_path = os.path.join(img_dir,img_name)9 l0 x# I3 T) F3 x  i! `2 K
  28.             if not os.path.exists(img_file_path):4 I% h5 ~0 y0 p) a# Z- x+ y
  29.                 sys.stdout.write("创建文件:"+ img_file_path + "\n")
    ) A, z% R1 K/ p9 t, x5 x  E2 }
  30.                 # 标准输出流,将指定文本输出到控制台或其他输出设备中
    * v+ a4 e% ]( S( d1 Q3 h: E7 s/ @- T
  31.                 cv2.imwrite(img_file_path,frame,[cv2.IMWRITE_JPEG_QUALITY,100])8 J- B2 Y7 w  }\" b
  32.                 # 将图像帧保存为jepg格式的图像,质量最高为100+ g. Y4 N- J4 p- }' j8 A+ e
  33.             else:
    \" c( w  v& M& ]$ b0 }1 R\" H& @
  34.                 sys.stderr.write("跳过:" + img_file_path + "\n")% |\" s3 Y# E; w; A( u$ }$ i
  35.                 ret,frame = cv.read(); z4 {' l7 Q1 _# B9 ~  h0 ?

  36. : \: J7 Z) Q, U9 T! ~
  37. def run(video_dir,img_dir):
    . `4 g7 R3 l) ^3 m
  38.     pool = ThreadPoolExecutor(). \' l- E8 i. m1 V. T% g$ X; a
  39.     # 创建一个线程池对象,实例化ThreadPoolExecutor类,将任务提交给线程池,线程池会自动调度线程来执行这些任务& [% I/ U# f/ S0 V9 e6 t$ u) z
  40.     for file in os.listdir(video_dir):) T. @4 E( j3 C! E' P
  41.         if file[-4:] == ".mp4":$ d3 [. f. S7 P# L  g
  42.             video_file_path = os.path.join(video_dir,file)
    - |- E. r' {, N$ c. h% s* z
  43.             img_dir_name = os.path.join(img_dir,file[:-4])
      k! ~% Z4 G; ]4 A# K/ e2 u
  44.             os.makedirs(img_dir_name,exist_ok=True)
    / j0 K  T, u+ d) W' c& z' b  |: K* L
  45.             pool.submit(output_img,*(video_file_path,img_dir_name))6 r) X5 z9 w) p7 ]$ _
  46. #* 和 ** 是用于解包参数的操作符。在这种情况下,*(video_file_path, img_dir_name): @- s, B% a, o' X
  47. # 的作用是将元组 (video_file_path, img_dir_name) 中的元素解包并作为单独的参数传递给函数。% n  C; h. W( u) e
  48. ( [1 m3 y5 o2 s1 m
  49. if __name__ == '__main__':
    ) l* H/ |* b' S
  50.     run(r"E:\video",r"E:\image"): L+ D' s* d% e  o
复制代码
5 t, q" N& B9 }
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-20 23:06 , Processed in 0.410659 second(s), 51 queries .

回顶部