Python生成数字图片代码分享
作者:往来白丁 发布时间:2023-03-02 04:27:18
标签:python,生成图片
本文向大家分享了几段Python生成数字图片的代码,喜欢的朋友可以参考。具体如下:
最终版本
# -*- coding:utf-8 -*-
from PIL import Image,ImageFont,ImageDraw,ImageFilter
import random
import os
import time
class Code(object):
def __init__(self, imgSize=(35,35),\
fontSize=25, bgColor=(255,)*4, fontColor=(0,0,0)):
self.imgSize = imgSize
self.fontSize = fontSize
self.bgColor = bgColor
self.fontColor = fontColor
def setFontSize(self, size):
self.fontSize = size;
def getDigit(self, digit):
return str(digit)
def getPannel(self):
pannel = Image.new('RGBA',self.imgSize,self.bgColor)
return pannel
def getFont(self, fontFile='./Arial.ttf'):
return ImageFont.truetype(fontFile, self.fontSize)
def getTextPos(self, digit, font):
text = self.getDigit(digit)
textWidth,textHeight = font.getsize(text);
imgWidth,imgHeight = self.imgSize
textPos = ((imgWidth-textWidth)/2, (imgHeight-textHeight)/2)
return textPos
def rotateImg(self,image,angle=0, expand=0):
rot = image.rotate(angle, expand)
fff = Image.new('RGBA',rot.size,self.bgColor)
image = Image.composite(rot, fff, rot)
return image
def createImg(self, digit, font, angle):
codeImg = Image.new('RGBA',self.imgSize,self.bgColor)
draw = ImageDraw.Draw(codeImg);
text = self.getDigit(digit)
textPos = self.getTextPos(digit, font)
draw.text(xy=textPos,text=text,fill=self.fontColor,font=font)
codeImg = self.rotateImg(codeImg,angle)
return codeImg
def saveImg(self, img, savePath, imgName):
img.save(savePath+'/'+imgName)
def createPath(path):
if not os.path.exists(path):
os.makedirs(path)
def createImages(code,rootPath='./images',digitList=range(10), fontSizeList=range(18,30),\
angleList=[(45,90),(-45,45),(-45,-90)]):
for index,angles in enumerate(angleList):
if index==0:
angleRange = '-90_-45'
elif index == 1:
angleRange = '-45_45'
else:
angleRange = '45_90'
anglepath = os.path.join(rootPath, angleRange)
createPath(anglepath)
for digit in digitList:
digitpath = os.path.join(anglepath, 'x'+str(digit))
createPath(digitpath)
for size in fontSizeList:
angle = round(random.uniform(angles[0], angles[1]),5)
code.setFontSize(size)
imgName = str(digit)+'_'+str(size)+'_'+str(angle)+'.jpg'
img = code.createImg(digit, code.getFont(),angle)
code.saveImg(img, digitpath, imgName)
if __name__ == '__main__':
imagesPath = './images'
if os.path.exists(imagesPath):
os.system('rm -rf '+imagesPath)
os.mkdir(imagesPath)
code = Code()
for i in range(1000):
createImages(code)
# test ...
# code = Code()
# img = code.createImg(5,code.getFont(),0)
# code.saveImg(img, savePath, 'test.jpg')
# img.show()
print 'hello'
# -*- coding:utf-8 -*-
from PIL import Image,ImageFont,ImageDraw,ImageFilter
import random
import os
class Captcha(object):
def __init__(self,size=(20,24),fontSize=20):
self.font = ImageFont.truetype('./fonts/Arial.ttf',fontSize)
self.size = size
self.image = Image.new('RGBA',self.size,(255,)*4)
# self.texts = self.randNum(1)
self.text = ''
def rotate(self, angle):
# rot = self.image.rotate(random.randint(-10,10),expand=0)
rot = self.image.rotate(angle,expand=0)
fff = Image.new('RGBA',rot.size,(255,)*4)
self.image = Image.composite(rot,fff,rot)
def randColor(self):
self.fontColor = (random.randint(0,250),random.randint(0,250),random.randint(0,250))
# def randNum(self,bits):
# return ''.join(str(random.randint(0,9)) for i in range(bits))
def setNum(self, num):
return num;
def write(self,text,x,y):
draw = ImageDraw.Draw(self.image)
draw.text((x,y),text,fill=self.fontColor,font=self.font)
def writeNum(self, num, angle):
x = 2
y = -2
self.text = num
self.fontColor = (0, 0, 0)
self.write(num, x, y)
self.rotate(angle)
return self.text
# character
# xplus = 15
# for text in self.texts:
# self.randColor()
# self.fontColor = (0, 0, 0)
# self.write(text, x, y)
# self.rotate(angle)
# self.rotate(random.randint(-10,10))
# x += xplus
# return self.texts
def save(self, save_path):
# self.image.save('captcha.jpg')
self.image.save(save_path)
pic_root_path = './pic'
if not os.path.exists(pic_root_path):
os.mkdir(pic_root_path)
angles = [(45,90),(-45,45),(-90,-45)]
for i in range(10):
pic_num_path = os.path.join(pic_root_path, 'pic'+str(i))
if not os.path.exists(pic_num_path):
os.mkdir(pic_num_path)
for angle_i in angles:
angle_name = str(angle_i[0])+'_'+str(angle_i[1])
pic_angle_path = os.path.join(pic_num_path, angle_name)
if not os.path.exists(pic_angle_path):
os.mkdir(pic_angle_path)
for angle in range(angle_i[0], angle_i[1]):
for fontsize in range(25,28):
img = Captcha(size=(20, 24), fontSize=fontsize)
num = img.writeNum(str(i), angle)
img_name = str(i)+'_'+str(fontsize)+'_'+str(angle)+'.bmp'
save_path = os.path.join(pic_angle_path, img_name)
img.save(save_path)
# img = Captcha()
# num = img.writeNum(str(i), random.randint(-90,-45))
# img_name = str(i)+'.jpg'
# pic_path = './pic'+str(i)
# if not os.path.exists(pic_path):
# os.mkdir(pic_path)
# save_path = os.path.join(pic_path, img_name)
# save_path = os.path.join(pic_root_path, save_path)
# img.save(save_path)
# img.image.show()
# img.save()
随机生成各种size和旋转角度的单个数字图片
# -*- coding:utf-8 -*-
from PIL import Image,ImageFont,ImageDraw,ImageFilter
import random
import os
import time
class Captcha(object):
def __init__(self,size=(20,24),fontSize=20):
self.font = ImageFont.truetype('./fonts/Arial.ttf',fontSize)
self.size = size
self.image = Image.new('RGBA',self.size,(255,)*4)
self.text = ''
def rotate(self, angle):
rot = self.image.rotate(angle,expand=0)
fff = Image.new('RGBA',rot.size,(255,)*4)
self.image = Image.composite(rot,fff,rot)
def randColor(self):
self.fontColor = (random.randint(0,250),random.randint(0,250),random.randint(0,250))
def setNum(self, num):
return num;
def write(self,text,x,y):
draw = ImageDraw.Draw(self.image)
draw.text((x,y),text,fill=self.fontColor,font=self.font)
def writeNum(self, num, angle):
x = 2
y = -2
self.text = num
self.fontColor = (0, 0, 0)
self.write(num, x, y)
self.rotate(angle)
return self.text
def save(self, save_path):
# self.image = self.image.filter(ImageFilter.EDGE_ENHANCE_MORE) #滤镜,边界加强
self.image.save(save_path)
pic_root_path = './pic'
if not os.path.exists(pic_root_path):
os.mkdir(pic_root_path)
angles = [(45,90),(-45,45),(-90,-45)]
for i in range(10):
pic_num_path = os.path.join(pic_root_path, 'x'+str(i))
if not os.path.exists(pic_num_path):
os.mkdir(pic_num_path)
for angle_i in angles:
angle_name = str(angle_i[0])+'_'+str(angle_i[1])
pic_angle_path = os.path.join(pic_num_path, angle_name)
if not os.path.exists(pic_angle_path):
os.mkdir(pic_angle_path)
for fontsize in range(25,29):
for j in range(2500):
# Keep 5 decimal places
angle = round(random.uniform(angle_i[0], angle_i[1]),5)
img = Captcha(size=(20, 24), fontSize=fontsize)
num = img.writeNum(str(i), angle)
img_name = 'x'+str(j)+'_'+str(fontsize)+'_'+str(angle)+'_'+str(num)+'.jpg'
save_path = os.path.join(pic_angle_path, img_name)
img.save(save_path)
文字居中
# -*- coding:utf-8 -*-
from PIL import Image,ImageFont,ImageDraw,ImageFilter
import random
import os
import time
imgWidth = 20
imgHeight = 24
fontSize = 28
backGroundColor = (255,)*4
fontColor = (0,)*3
text = '0'
font = ImageFont.truetype('./Arial.ttf', fontSize)
codeimg = Image.new('RGBA',(imgWidth,imgHeight), backGroundColor)
imagePath = './codes'
if not os.path.exists(imagePath):
os.mkdir(imagePath)
textWidth, textHeight = font.getsize(text)
textLeft = (imgWidth-textWidth)/2
textTop = (imgHeight-textHeight)/2
draw = ImageDraw.Draw(codeimg)
draw.text(xy=(textLeft,textTop),text=text,fill=fontColor,font=font)
rot = codeimg.rotate(90,expand=0)
codeimg.rotate
fff = Image.new('RGBA', rot.size,backGroundColor)
codeimg = Image.composite(rot, fff, rot)
codeimg.show()
# codeimg.save('./codes/test.jpg')
以上就是本文关于Python生成数字图片代码分享的全部内容,希望对大家有所帮助。欢迎参阅:Python列表删除的三种方法代码分享、Python文件的读写和异常代码示例等,有问题可以随时留言,欢迎大家交流讨论。
来源:http://blog.csdn.net/zwx2445205419/article/details/73481409


猜你喜欢
- Taglib指令介绍Taglib指令,其实就是定义一个标签库以及自定义标签的前缀。比如struts中支持的标签库,html标签库、bean标
- 1.重命名表方法使用 RENAME TABLE 语句或 ALTER TABLE 语句都可以对表进行重命名,基本语法如下:# RE
- 最长公共子序列python实现,最长公共子序列是动态规划基本题目,下面按照动态规划基本步骤解出来。1.找出最优解的性质,并刻划其结构特征序列
- Xxencode编码,也是一个二进制字符转换为普通打印字符方法。跟UUencode编码原理方法很相似,唯独不同的是可打印字符不同。通个UUe
- 本文是对《Python Qt GUI快速编程》的第10章的例子剪贴板用Python3+PyQt5进行改写,分别对文本,图片和html文本的复
- 个人使用样例及部分翻译自官方文档,并详细介绍chart的使用一:基础应用1.创建pptx文档类并插入一页幻灯片from pptx impor
- sympy有个vector 模块,里面提供了求解标量场、向量场的梯度、散度、旋度等计算,官方参考连接:http://docs.sympy.o
- Django 中的时区在现实环境中,存在有多个时区。用户之间很有可能存在于不同的时区,并且许多国家都拥有自己的一套夏令时系统。所以如果网站面
- 前言Django提供了多种装饰器, 其中login_required可能是经常会使用到的。 这里介绍下四种使用此装饰器的办法。当然, 在使用
- 前言在字典中查找某一个值的时候,若key不存在就会返回一个keyerror错误而不是一个默认值,如果想要返回一个默认值可以使用default
- import os os.os.listdir(path) 然后再一个一个的分析文件和目录 通过和dos命令dir的巧妙结合,可以很轻松的做
- 背景实现需求:批量下载联想某型号的全部驱动程序。一般在做网络爬虫的时候,都是保存网页信息为主,或者下载单个文件。当涉及到多文件批量下载的时候
- 使用distinct在mysql中查询多条不重复记录值的解决办法如何使用distinct在mysql中查询多条不重复记录值?有时候想用dis
- 简介:在Windows下的网易邮箱大师客户端中,阅读邮件时,可以使用快捷键Delete删除邮件,然后自动跳到下一封,如果再按一次Delete
- 游标概念数据库操作中我们常常会遇到这样情况,即从某一结果集中逐一地读取一条记录。那么如何解决这种问题呢?游标为我们提供了一种极为优秀的解决方
- SQL Server:Select TOP N * From TABLE Order By NewID() view
- 启用Ad Hoc Distributed Queries:exec sp_configure 'show advanced opti
- 堆 heap 值类型 原始类型(primitive type) Undefined: undefined (注意大小写:类型/ 值,下同)
- 本文实例讲述了JS实现利用两个队列表示一个栈的方法。分享给大家供大家参考,具体如下:先看原理图:理清楚思路,再动笔写:<!DOCTYP
- 什么是python的装饰器?网络上的定义:装饰器就是一函数,用来包装函数的函数,用来修饰原函数,将其重新赋值给原来的标识符,并永久的丧失原函