-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathvideo_to_txt_rus.py
87 lines (70 loc) · 2.6 KB
/
video_to_txt_rus.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
"""
Python 3.10 программа преобразования видео в текст
видео можно загрузить как из файла так и из интернета
Название файла video_to_txt_rus.py
Version: 0.1
Author: Andrej Marinchenko
Date: 2023-02-11
"""
import cv2
from PIL import Image
import numpy as np
import time
import sys
abc = '@MWNHB8$06XFVYZ27>1jli!;:,. '
l = 256 / len(abc)
def remove_transparency(im, bg_colour=(255, 255, 255)):
if im.mode in ('RGBA', 'LA') or (im.mode == 'P' and 'transparency' in im.info):
alpha = im.convert('RGBA').split()[-1]
bg = Image.new("RGBA", im.size, bg_colour + (255,))
bg.paste(im, mask=alpha)
return bg
else:
return im
def img2pixel(img, charwidth=100):
img = img.convert("L")
w, h = img.size
img = img.resize((charwidth, int(charwidth * (h / w) / 2.4)))
data = np.array(img)
return data
def pixel2char(data):
chars = '\n\n'
for row in data:
for pixel in row:
a = abc[int(pixel / l)]
chars += a
chars += '\n'
return chars + '\n'
def main(args):
start = time.time()
if len(args) != 3:
print("Использование: video_to_txt ширина символа видеопути")
return
# Получите информацию о ширине, высоте и частоте кадров видео
vcap = cv2.VideoCapture(args[1])
width = vcap.get(cv2.CAP_PROP_FRAME_WIDTH) # вещественное число
height = vcap.get(cv2.CAP_PROP_FRAME_HEIGHT) # вещественное число
fps = vcap.get(cv2.CAP_PROP_FPS)
print(width, height, fps)
# начать цикл по кадрам
currentframe = 0
while (True):
t1 = time.time()
ret, frame = vcap.read()
if ret:
pilimg = Image.fromarray(frame)
data = img2pixel(pilimg, charwidth=int(args[2]))
s = pixel2char(data=data)
print(s)
currentframe += 1
else:
break
# Время сна составляет одну долю секунды от кадров в секунду минус время, в течение которого этот кадр уже использовался.
time2sleep = (1 / fps) - (time.time() - t1)
if time2sleep > 0: time.sleep(time2sleep)
# Освободите пространство и окна
vcap.release()
cv2.destroyAllWindows()
print("Прошедшее время:", time.time() - start)
if __name__ == '__main__':
main(sys.argv)