从实验楼学习的图片转换字符
**
安装pip后,pip install pillow
开始
代码ascii.py
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)#打开图片
#使用resize()方法重新设置图片大小,其中第一个参数应是一个尺寸元组
#而第二个参数resample有四个选项,分别是Image.NEAREST、Image.BILINEAR、
#Image.BICUBIC、Image.LANCZOS,默认是第一个,第四个质量最高
im = im.resize((WIDTH,HEIGHT), Image.NEAREST)
txt = ""
for i in range(HEIGHT):
for j in range(WIDTH):
txt += get_char(*im.getpixel((j,i)))
txt += '\n'
#这段代码是使用getpixel()方法获取某坐标像素点的RGBA值,再通过设 置好的对应关系使图片被转换成字符画
#PNG是一种使用RGBA的图像格式,其中A是指alpha即色彩空间
#然后使用get_char函数将这个值转换成字符,换行时加上换行符
#其中getpixel()方法会返回四个元素的元组,
#而get_char(im.getpixel((j, i )))使用了*则会把返回的元组元素依次赋给get_char()函数的四个参数
print txt
#字符画输出到文件
if OUTPUT:
with open(OUTPUT,'w') as f:
f.write(txt)
else:
with open("output.txt",'w') as f:
f.write(txt)
问题
- cmd下运行出现/x*c之类的问题,在ascii文件开头添加‘#coding:utf-8’
- 出现is int not iterable解决: rgb_im = im.convert(‘RGB’)
- 出现unexpected indent 解决:出现了tab和空格混用,IDLE用的是空格,我直接取了tab让他们看起来差不多。。
- Traceback (most recent call last):
File “C:\Users\ReZero\Desktop\ascii.py”, line 46, in
txt += get_char(*im.getpixel((j,i)))
TypeError: get_char() argument after * must be an iterable, not int
吗隔壁还是安个linux吧。。。
解决方法:刚才的rgb_im = im.convert(‘RGB’)是从别的地方看的,一时没明白怎么用,其实就是把im为rgb格式
最后完整代码如下:
#coding:utf-8
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__':
rgb_im = Image.open(IMG)#打开图片
im = rgb_im.convert('RGB')
#使用resize()方法重新设置图片大小,其中第一个参数应是一个尺寸元组
#而第二个参数resample有四个选项,分别是Image.NEAREST、Image.BILINEAR、
#Image.BICUBIC、Image.LANCZOS,默认是第一个,第四个质量最高
im = im.resize((WIDTH,HEIGHT), Image.NEAREST)
txt = ""
for i in range(HEIGHT):
for j in range(WIDTH):
txt += get_char(*im.getpixel((j,i)))
txt += '\n'
#这段代码是使用getpixel()方法获取某坐标像素点的RGBA值,再通过设置好的对应关系使图片被转换成字符画
#PNG是一种使用RGBA的图像格式,其中A是指alpha即色彩空间
#然后使用get_char函数将这个值转换成字符,换行时加上换行符
#其中getpixel()方法会返回四个元素的元组,
#而get_char(im.getpixel((j, i )))使用了*则会把返回的元组元素依次赋给get_char()函数的四个参数
print txt
#字符画输出到文件
if OUTPUT:
with open(OUTPUT,'w') as f:
f.write(txt)
else:
with open("output.txt",'w') as f:
f.write(txt)
哦哈哈哈哈哈哈哈哈哈哈