Python 圖片轉字符圖


pip install Image argparse pillow

from PIL import Image
import argparse

#命令行輸入參數處理
parser = argparse.ArgumentParser()
parser.add_argument('file')                                 #輸入文件
parser.add_argument('-o', '--output')                       #輸出文件
parser.add_argument('--width', type = int, default = 80)    #輸出字符畫寬
parser.add_argument('--height', type = int, default = 80)   #輸出字符畫高
args = parser.parse_args()                                  # 獲取參數

IMG = args.file
WIDTH = args.width
HEIGHT = args.height
OUTPUT = args.output

# 我們定義的不重復的字符列表,灰度值小(暗)的用列表開頭的符號,灰度值大(亮)的用列表末尾的符號
ascii_char = list("$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~<>i!lI;:,\"^`'. ")

# 將256灰度映射到70個字符上
def get_char(r,g,b,alpha = 256):
    if alpha == 0:
        return ' '
    length = len(ascii_char)
    gray = int(0.2126 * r + 0.7152 * g + 0.0722 * b)

    unit = (256.0 + 1)/length
    return ascii_char[int(gray/unit)]

if __name__ == '__main__':

    im = Image.open(IMG)
    im = im.resize((WIDTH,HEIGHT), Image.NEAREST)

    txt = ""

    #將圖片看成由像素點組成的二維數組,i代表每一行,j代表每一列
    for i in range(HEIGHT):
        for j in range(WIDTH):
            #getpixel()函數的參數是由每個像素點在圖片中的相對位置(w,h)組成的元組
            #返回值是一個代表圖片像素值的(r,g,b,alpha)元組
            txt += get_char(*im.getpixel((j,i)))
        txt += '\n'

    print(txt)
    #字符畫輸出到文件
    if OUTPUT:
        with open(OUTPUT,'w') as f:
            f.write(txt)
    else:
        with open("output.txt",'w') as f:
            f.write(txt)

python .\a.py .\time.jpg -o teaGod.txt --width 80 --height 40

 

 

 

 

轉成視頻圖

import cv2
import os
show_heigth = 30              
show_width = 80

ascii_char = list("$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~<>i!lI;:,\"^`'. ")
#生成一個ascii字符列表
char_len = len(ascii_char)

vc = cv2.VideoCapture("v.mkv")          #加載一個視頻

if vc.isOpened():                       #判斷是否正常打開
    rval , frame = vc.read()
else:
    rval = False
    
frame_count = 0
outputList = []                         #初始化輸出列表
while rval:   #循環讀取視頻幀  
    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)  #使用opencv轉化成灰度圖
    gray = cv2.resize(gray,(show_width,show_heigth))#resize灰度圖
    text = ""
    for pixel_line in gray:
        for pixel in pixel_line:                    #字符串拼接
            text += ascii_char[int(pixel / 256 * char_len )]
        text += "\n"                                
    outputList.append(text)
    frame_count = frame_count + 1                           
    if frame_count % 100 == 0:
        print("已處理" + str(frame_count) + "")
    rval, frame = vc.read()  
print("處理完畢")

for frame in outputList:            
    os.system("cls")                    #清屏
    print(frame)
    print()
    print()

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM