本文目录一览:
怎么用python将图片转换为文本形式?
ocr有开源的模块。也有国产的。总体来讲,国产的更准确。不过最好事先做一次图像处理。
几年前试过python调用开源模块识别。现在是什么情形不太清楚了。
python的图片转字符
from PILimport Image
ascii_char =list("!~#$%^**()_+`=][\{}|;':?/")
#字符与RGB的对应的映射关系
def get_char(r,g,b,alpha=256):
if alpha ==0 :
return ' '
lenght =len(ascii_char)
gray =int(0.2126 * r +0.7152 * g +0.0722 * b)
unit = (256.0 +1)/lenght
return ascii_char[int(gray/unit)]
if __name__ =='__main__':
im = Image.open(r"C:\Users\鹏COMPUTER\Desktop\timg.jpg")
#这里是转换图片的大小,然后第二个参数表示图片的质量,一共有4种,低质量Image.NEARSET,双线性Image.BILINEAR,三次样条插值Image.BICUBIC,高质量Image.ANTIALIAS
im = im.resize((60,30),Image.NEAREST)
txt =""
for iin range(30):
for jin range(60):
#im.getpixel:根据坐标取得RGB对应的r,g,b三个值,这里的getpixel((i,j))的两个括号非常重要
txt += get_char(*im.getpixel((j,i)))
txt +='\n'
print(txt)
with open(r"C:\Users\鹏COMPUTER\Desktop\m.txt",'w')as f:
f.write(txt)
这是输出的字符串:
如何用python将图片转为字符画
# 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%8WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~i!lI;:,\"^`'. ")
# 将256灰度映射到70个字符上
def get_char(r, b, g, 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 = ""
for i in range(HEIGHT):
for j in range(WIDTH):
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)