python pil怎么调用_python – 使用PIL中的Image.point()方法来操作像素数据

这篇博客探讨了如何使用Python Imaging Library (PIL) 中的Image.point()方法来高效地操作像素数据,特别是在给黑白图像上色的场景下。文章提到了通过getpixel()和putpixel()方法的原始实现,然后改进为使用im.load()直接访问像素,再进一步介绍Image.point()的使用,旨在提高处理速度。作者寻求关于Image.point()的正确用法和参数格式的指导。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我正在使用

Python Imaging Library通过查找表来定义颜色关系来对黑白图像进行着色。查找表只是一个256元素的RGB元组列表:

>>> len(colors)

256

>>> colors[0]

(255, 237, 237)

>>> colors[127]

(50, 196, 33)

>>>

我的第一个版本使用了getpixel()和putpixel()方法:

for x in range(w):

for y in range(h):

pix = img.getpixel((x,y))

img.putpixel((x,y), colors[pix[0]])

这太可怕了一个配置文件报告指出了putpixel和getpixel方法作为罪魁祸首。有一点调查(即阅读文档),我发现“注意这种方法比较慢”。 re:putpixel。 (实际运行时间:putpixel为53s,1024×1024图像为50像素)

根据文档中的建议,我使用im.load()和直接像素访问:

pixels = img.load()

for x in range(w):

for y in range(h):

pix = pixels[x, y]

pixels[x, y] = colors[pix[0]]

处理速度提高了一个数量级,但仍然很慢:处理1024×1024图像的大约3.5秒。

对PIL文档的更全面的研究似乎表明Image.point()正是为了这个目的:

im.point(table) => image

im.point(function) => image

Returns a copy of the image where each pixel has been mapped through the given table. The table should contains 256 values per band in the image. If a function is used instead, it should take a single argument. The function is called once for each possible pixel value, and the resulting table is applied to all bands of the image.

我花了一些时间在界面上闯入,但是看起来不太合适。原谅我的无知,但PIL的文档是curt,我没有太多的图像处理经验。我已经google了一些,并提出了几个例子,但没有任何使用“点击”为我。所以,最后我的问题:

> Image.point()是这个工作的正确工具吗?

> Image.point()期望什么格式/结构表?

有人可以粗略地列举一个例子吗?到目前为止,我尝试过的每一次迭代都是直线黑色的形象。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值