这个系列主要是用于记录本人在工作、学习python期间的一些学习心得,感兴趣的同学可以一起讨论交流*\^_^/*
1、在工作中前同事喜欢把视频用cv2库将视频逐帧读取逐写入成图片存到文件夹中,再对文件夹中的图像进行读取成list进行后续操作。
虽然将图片读出来很方便观察逐帧截取视频的状态,但是会严重减慢图像处理速度。可解决的方法时直接用list来接收,图像读取完毕后再抽一帧imshow出来即可。(缺点:短时间占用内存暴增)
2、作为初级程序员,我觉得实现程序功能是最基础的要求、更重要的是要清楚代码的逻辑并开发出条理清楚、不浪费内存的代码,毕竟内存寸土寸金。(最近实习旁边的大佬教会我很多,真的受益匪浅,果真能去华为的人确实有四把刷子!!)
video_path = './video_path/source_video.mp4'
output_path = './output_path/'
video_get = cv2.VideoCapture(video_path)
frame_in_list = []
while True:
ret, frame = video_get.read()
if not ret:
break
frame_in_list.append(frame)
print("finish append!")
frame_index = 1400
save_1400_frame = os.path.join(output_path, f'frame_{frame_index}.png' )
cv2.imwrite(save_1400_frame, frame_in_list[frame_index])
video_get.release()
print('have saved!')
2、os.path.basename()与os.path.splitext()
import os
eg_path = './fold/hello.png'
str_path = os.path.basename(eb_path) # 获取'hello.png'
#如果想要获取 hello,需要用os.path.splitext()
# 因为os.path.splitext()返回是元组('hello','png'),我们只需要得到第一个值就行
name_str_path,_ = os.path.splitext(str_path) # 方法1
name_str_path = os.path.splitext(str_path)[0]