图画的字符处理,就是将相应位置的像素转换相应的字符,这个字符可以是任意的字符,我们也可以将字符按照的简单程度排列。
from PIL import Image
ascii_char = " .,-'`:^!|1<>+*=()?%#@MBGKHZXRFGW"
def get_char(r, b, g, alpha=256):
if alpha == 0:
return ' '
gray = int(0.2126 * r + 0.7152 * g + 0.0722 * b)
unit = 256 / len(ascii_char)
i =int(gray // unit)
return ascii_char[i]
def main():
im = Image.open("C:\\Users\\j00431635\\Desktop\MM\\11.jpg")
WIDTH, HEIGHT = 166, 125
im = im.resize((WIDTH, HEIGHT))
txt = ""
for i in range(HEIGHT):
for j in range(WIDTH):
txt += get_char(*im.getpixel((j, i)))
txt += '\n'
fo = open("C:\\Users\\j00431635\\Desktop\MM\\11.txt", "w")
fo.write(txt)
fo.close()
main()
原图是:
字符画后的是:
或者我们使用 opencv 来实现
# -*- coding: utf-8 -*-
# feimengjuan
# 实现将图片转为字符画
import cv2
ascii_char = list("$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~<>i!lI;:,\"^`'. ")
# 将灰度值转为字符
def get_char(gray_number):
length = len(ascii_char)
unit = (256.0 + 1) / length
return ascii_char[int(gray_number / unit)]
if __name__ == '__main__':
image1 = cv2.imread('C:\\Users\\j00431635\\Desktop\MM\\naruto.jpg')
WIDTH, HEIGHT = 166, 125
image = cv2.resize(image1, (WIDTH, HEIGHT))
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
txt = ""
for i in range(image.shape[0]):
for j in range(image.shape[1]):
# 对打开的图片的每个坐标的灰度值做判断,
# 用get_char()获取该颜色灰度值对应的字符,然后拼接成字符串txt
txt += get_char(gray[i, j])
txt += '\n'
# 字符画输出到文件中
f = open("C:\\Users\\j00431635\\Desktop\MM\\naruto.txt", "w")
f.write(txt)
基本思路都是一致的,对应的像素替换罢了,只是对图像的读取和操作过程还是一样的。
效果如下: