python输出文本居中_#python PIL ImageDraw text 文本居中#

python pip pil有什么东西

你所问的问题实是属1.先参考【教程】Python中的内置的和方的模块搞懂PIL是属于第三方Python模块2.再参考:【待完善】【总结】Python安装第三方的库、package的方法去安装PIL模块。3.关于PIL的一些使用,可以参考:【已解决】Python中通过Image的open之后,去show结果打不开bmp图片,无法正常显示图片再针对PIL来说就是:1.这里不给贴地址,所以只能靠你自己用google搜:pythonpil第一个就是:PythonImagingLibrary(PIL)点击进去后,找到自己python版本的PIL,比如:PythonImagingLibrary1.1.7forPython2.7(Windowsonly)下载,双击,安装,即可。2.如果下载到的是PIL源码,则打开cmd,切换到其目录然后执行setup.pyinstall就可以通过源码方式安装了。这些方法,上面帖子其实都有总结的。(此处不给贴地址,请自己用google搜帖子标题,就可以找到帖子地址了)

如何python pil开发图像识别

1. 简介

处理是一门应用非常广术,而拥有非常丰富第三方扩的 Python 当然不会错过这一门盛宴。PIL (Python Imaging Library)是 Python 中最常用的图像处理库,目前版本为 1.1.7,我们可以 在这里 下载学习和查找资料。

Image 类是 PIL 库中一个非常重要的类,通过这个类来创建实例可以有直接载入图像文件,读取处理过的图像和通过抓取的方法得到的图像这三种方法。

2. 使用。

导入 Image 模块。然后通过 Image 类中的 open 方法即可载入一个图像文件。如果载入文件失败,则会引起一个 IOError ;若无返回错误,则 open 函数返回一个 Image 对象。现在,我们可以通过一些对象属性来检查文件内容,即:

1 >>> import Image

2  >>> im = Image.open("j.jpg")

3  >>> print im.format, im.size, im.mode

4 JPEG (440, 330) RGB

这里有三个属性,我们逐一了解。

format : 识别图像的源格式,如果该文件不是从文件中读取的,则被置为 None 值。

size : 返回的一个元组,有两个元素,其值为象素意义上的宽和高。

mode : RGB(true color image),此外还有,L(luminance),CMTK(pre-press image)。

现在,我们可以使用一些在 Image 类中定义的方法来操作已读取的图像实例。比如,显示最新载入的图像:

1 >>>im.show()

2  >>>

输出原图:

3. 函数概貌。

3.1    Reading and Writing Images : open( infilename ) , save( outfilename )

3.2    Cutting and Pasting and Merging Images :

crop() : 从图像中提取出某个矩形大小的图像。它接收一个四元素的元组作为参数,各元素为(left, upper, right, lower),坐标系统的原点(0, 0)是左上角。

paste() :

merge() :

1 >>> box = (100, 100, 200, 200)

2  >>> region = im.crop(box)

3  >>> region.show()

4  >>> region = region.transpose(Image.ROTATE_180)

5  >>> region.show()

6  >>> im.paste(region, box)

7  >>> im.show()

其效果图为:

旋转一幅图片:

1 def roll(image, delta):

2     "Roll an image sideways"

3

4     xsize, ysize = image.size

5

6     delta = delta % xsize

7     if delta == 0: return image

8

9     part1 = image.crop((0, 0, delta, ysize))

10     part2 = image.crop((delta, 0, xsize, ysize))

11     image.paste(part2, (0, 0, xsize-delta, ysize))

12     image.paste(part1, (xsize-delta, 0, xsize, ysize))

13

14     return image

3.3    几何变换。

3.3.1    简单的几何变换。

1 >>>out = im.resize((128, 128))                     #

2  >>>out = im.rotate(45)                             #逆时针旋转 45 度角。

3  >>>out = im.transpose(Image.FLIP_LEFT_RIGHT)       #左右对换。

4  >>>out = im.transpose(Image.FLIP_TOP_BOTTOM)       #上下对换。

5  >>>out = im.transpose(Image.ROTATE_90)             #旋转 90 度角。

6  >>>out = im.transpose(Image.ROTATE_180)            #旋转 180 度角。

7 >>>out = im.transpose(Image.ROTATE_270)            #旋转 270 度角。

各个调整之后的图像为:

图片1:

图片2:

图片3:

图片4:

3.3.2    色彩空间变换。

convert() : 该函数可以用来将图像转换为不同色彩模式。

3.3.3    图像增强。

Filters : 在 ImageFilter 模块中可以使用 filter 函数来使用模块中一系列预定义的增强滤镜。

1 >>> import ImageFilter

2 >>> imfilter = im.filter(ImageFilter.DETAIL)

3 >>> imfilter.show()

3.4    序列图像。

即我们常见到的动态图,最常见的后缀为 .gif ,另外还有 FLI / FLC 。PIL 库对这种动画格式图也提供了一些基本的支持。当我们打开这类图像文件时,PIL 自动载入图像的第一帧。我们可以使用 seek 和 tell 方法在各帧之间移动。

1 import Image

2 im.seek(1)        # skip to the second frame

3

4 try:

5     while 1:

6         im.seek( im.tell() 1)

7         # do something to im

8 except EOFError:

9     pass

3.5    更多关于图像文件的读取。

最基本的方式:im = Image.open("filename")

类文件读取:fp = open("filename", "rb"); im = Image.open(fp)

字符串数据读取:import StringIO; im = Image.open(StringIO.StringIO(buffer))

从归档文件读取:import TarIO; fp = TarIo.TarIO("Image.tar", "Image/test/lena.ppm"); im = Image.open(fp)

基本的 PIL 目前就练习到这里。其他函数的功能可点击 这里 进一步阅读。

python PIL的问题

我能的是,不用 Image.open("XXXX")读文件,会有之后的惰性操作,

ImageFile从另一个open的图片文件中读到内存里面,也可以删除原文件

import ImageFile

fp = open("1.png", "rb")

p = ImageFile.Parser()

while 1:

s = fp.read(1024)

if not s:

break

p.feed(s)

im = p.close()

im.save("copy.jpg")

python PIL ImageDraw text 文本居中

宽度本来难。这个是难题。因为字符宽度不一致。 通常我做法是这样子。

你先面的画板上画一个字符串,然后测量它的宽度。再根据测量得到的宽度正式在你想绘制的画板上绘。

这个测量也是用它的API实现的。不是自己用尺子量。

另外一个办法是手机上用的。 每个字体的每个字符的长宽都有精准的数据。做一个这样的数据库。然后绘制前计算一下,就可以居中了。

python怎么用PIL模块处理BMP图像 二值化

遍历对象?可是怎么遍历法呢?Pillow 提供了一个 .load() 方法,用理像素。图片嘛,当然是二维的,和高的。

pixels = image.load()

for x in ramge(image.width):

for y in range(image.height):

pixsels[x, y] = 255 if pixsels[x, y] > 125 else 0

当然了,只是最简单的二值化的话,直接 image.convert('1') 就可以了 :-)

python pil 怎么安装

命令行窗口(假设载的PIL文放在E盘下,文件名叫Pillow-3.3.1-cp27-cp27m-win_amd64.whlpip  install e:\Pillow-3.3.1-cp27-cp27m-win_amd64.whl

完毕,需要检下安装是否成功。

Python中用PIL库批量给图片加上序号的教程

这篇文章主要介绍了Python中用PIL批量给图片加上序号的教程,PIL库是Python中一个非常强大的处理图片的库,需要的朋友可以参考下

女友让我给她论文的图片上加上字母序号,本来觉得是个很简单的事情,但那个白底黑字的圆圈序号却难住了我,

试了几个常用的软件,都不行。

后来用

PS

动作,倒是能搞出来,不过也不容易,正好那天没搞完,于是拿回自己家做,但我的电脑上又没有

PS,

所以就用

python

实现了。

效果图

这里用的图片全是

240X240

的,按文件名的首字母作为序号,PIL

虽然可以计算文字的尺寸,但类似

D

这样的字符依然不能处于圆圈的正中,所以还对个别字符做了偏移设置,本来想用

aggdraw

画圆圈的,能平滑

一些,不过安装了好几次,都以失败告终,最终放弃。

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

#!/usr/bin/env

python

#-*-

coding:

utf-8

-*-

import

os,

sys,

fnmatch

import

Image,

ImageDraw,

ImageFont

def

process_picture(filename):

seq

=

os.path.split(filename)[-1][0].upper()

img

=

Image.open(os.path.join(input_dir,

filename))

draw

=

ImageDraw.Draw(img)

#

在右下角画白底黑框圆圈

draw.ellipse((215,

215,

235,

235),

outline='black',

fill='white')

#

将字母序号写入到圆圈内

font

=

ImageFont.truetype('fonts/Times

New

Roman.ttf',

20)

#

计算文字居中的位置

text_size

=

draw.textsize(seq,

font)

x

=

(20

/

2)

-

(text_size[0]

/

2)

y

=

(20

/

2)

-

(text_size[1]

/

2)

#

字母偏移量

offsets

=

{'A':

1,

'B':

1,

'E':

1,

'D':

2}

offset

=

offsets.get(seq,

0)

draw.text((215

x

offset,

215

y),

seq,

font=font,

fill='black')

#

save

image

img.save(os.path.join(output_dir,

filename),

'JPEG')

if

__name__

==

'__main__':

if

len(sys.argv)

<

3:

print

'Usage:

python

drawseq.py

'

sys.exit(1)

input_dir,

output_dir

=

sys.argv[1:3]

os.path.exists(output_dir)

or

os.makedirs(output_dir)

for

filename

in

os.listdir(input_dir):

if

fnmatch.fnmatch(filename.lower(),

'*.jpg'):

process_picture(filename)

注:更多精彩教程请关注三联图文教程

频道,

版权声明:本站所有文章皆为原创,欢迎转载或转发,请保留网站地址和作者信息。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值