通过python将图片生成字符画
基础知识:
1.python基础知识 快速学习链接:https://www.shiyanlou.com/courses/214
2.linux命令行操作 快速学习链接:https://www.shiyanlou.com/courses/1
3.pillow库的使用 快速学习链接:http://pillow.readthedocs.io/en/latest/index.html(英文) http://www.cnblogs.com/apexchu/p/4231041.html(中文)
4.argparse库的使用 快速学习链接:http://blog.ixxoo.me/argparse.html
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
pillow库:
导入Image类: from PIL import Image
在python解释器下
>>>from PIL import Image
>>>help(Image)
查看帮助文档
Image的文件位置 /usr/lib64/python2.7/site-packages/PIL/Image.py
使用Image类
To load an image from a file, use the open() function in the Image module:
从文件里加载图片,使用Image模块里的open()函数:
>>> from PIL import Image
>>> im = Image.open("lena.ppm")
If successful, this function returns an Image object. 如果成功,这个函数返回一个Image对象。
If the file cannot be opened, an IOError exception is raised. 如果失败,引发一个IOError.
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
PIL.Image.open(fp, mode='r')-
Opens and identifies the given image file.
This is a lazy operation; this function identifies the file, but the file remains open and the actual image data is not read from the file until you try to process the data (or call the
load()method). Seenew().Parameters: - fp – A filename (string), pathlib.Path object or a file object. The file object must implement
read(),seek(), andtell()methods, and be opened in binary mode. - mode – The mode. If given, this argument must be “r”.
Returns: An
Imageobject.Raises: IOError – If the file cannot be found, or the image cannot be opened and identified.
- fp – A filename (string), pathlib.Path object or a file object. The file object must implement
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Image.getpixel(xy)-
Returns the pixel value at a given position.
Parameters: xy – The coordinate, given as (x, y). Returns: The pixel value. If the image is a multi-layer image, this method returns a tuple.
通过给的位置值返回像素值。
>>> from PIL import Image
>>> im = Image.open('cat.jpg')
>>> im.getpixel((1,2))
(107, 81, 22) 返回了该坐标对应的rgb像素三元祖
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Image.resize(size, resample=0)-
Returns a resized copy of this image.
Parameters: - size – The requested size in pixels, as a 2-tuple: (width, height).
- resample – An optional resampling filter. This can be one of
PIL.Image.NEAREST,PIL.Image.BOX,PIL.Image.BILINEAR,PIL.Image.HAMMING,PIL.Image.BICUBICorPIL.Image.LANCZOS. If omitted, or if the image has mode “1” or “P”, it is setPIL.Image.NEAREST. See: Filters.
Returns: An
Imageobject.
重设图片的大小,返回一个Image对象。
5种resample: PIL.Image.NEAREST, PIL.Image.BOX, PIL.Image.BILINEAR, PIL.Image.HAMMING, PIL.Image.BICUBIC or PIL.Image.LANCZOS
>>> im = Image.open(IMG)
>>> im = im.resize((WIDTH,HEIGHT), Image.NEAREST)
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
NEAREST- Pick one nearest pixel from the input image. Ignore all other input pixels.
BOX-
Each pixel of source image contributes to one pixel of the destination image with identical weights. For upscaling is equivalent of
NEAREST. This filter can only be used with theresize()andthumbnail()methods.New in version 3.4.0.
BILINEAR- For resize calculate the output pixel value using linear interpolation on all pixels that may contribute to the output value. For other transformations linear interpolation over a 2x2 environment in the input image is used.
HAMMING-
Produces more sharp image than
BILINEAR, doesn’t have dislocations on local level like withBOX. This filter can only be used with theresize()andthumbnail()methods.New in version 3.4.0.
BICUBIC- For resize calculate the output pixel value using cubic interpolation on all pixels that may contribute to the output value. For other transformations cubic interpolation over a 4x4 environment in the input image is used.
LANCZOS-
Calculate the output pixel value using a high-quality Lanczos filter (a truncated sinc) on all pixels that may contribute to the output value. This filter can only be used with the
resize()andthumbnail()methods.New in version 1.1.3.
Filters comparison table
| Filter | Downscaling quality | Upscaling quality | Performance |
|---|---|---|---|
NEAREST |
⭐⭐⭐⭐⭐ | ||
BOX |
⭐ | ⭐⭐⭐⭐ | |
BILINEAR |
⭐ | ⭐ | ⭐⭐⭐ |
HAMMING |
⭐⭐ | ⭐⭐⭐ | |
BICUBIC |
⭐⭐⭐ | ⭐⭐⭐ | ⭐⭐ |
LANCZOS |
⭐⭐⭐⭐ | ⭐⭐⭐⭐ | ⭐ |
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Image.load()-
Allocates storage for the image and loads the pixel data. In normal cases, you don’t need to call this method, since the Image class automatically loads an opened image when it is accessed for the first time. This method will close the file associated with the image.
Returns: An image access object. Return type: PixelAccess Class or PIL.PyAccess
>>> im = im.load()
>>> im
<PixelAccess object at 0x7f20ebdeb990>
>>> print im[1,2]
(107, 81, 22)
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Image.convert(mode=None, matrix=None, dither=None, palette=0, colors=256)-
Returns a converted copy of this image. For the “P” mode, this method translates pixels through the palette. If mode is omitted, a mode is chosen so that all information in the image and the palette can be represented without a palette.
The current version supports all possible conversions between “L”, “RGB” and “CMYK.” The matrix argument only supports “L” and “RGB”.
When translating a color image to black and white (mode “L”), the library uses the ITU-R 601-2 luma transform:
L = R * 299/1000 + G * 587/1000 + B * 114/1000
The default method of converting a greyscale (“L”) or “RGB” image into a bilevel (mode “1”) image uses Floyd-Steinberg dither to approximate the original image luminosity levels. If dither is NONE, all non-zero values are set to 255 (white). To use other thresholds, use the
point()method.Parameters: - mode – The requested mode. See: Modes.
- matrix – An optional conversion matrix. If given, this should be 4- or 12-tuple containing floating point values.
- dither – Dithering method, used when converting from mode “RGB” to “P” or from “RGB” or “L” to “1”. Available methods are NONE or FLOYDSTEINBERG (default).
- palette – Palette to use when converting from mode “RGB” to “P”. Available palettes are WEB or ADAPTIVE.
- colors – Number of colors to use for the ADAPTIVE palette. Defaults to 256.
Return type: Returns: An
Imageobject.
The following example converts an RGB image (linearly calibrated according to ITU-R 709, using the D65 luminant) to the CIE XYZ color space:
rgb2xyz = (
0.412453, 0.357580, 0.180423, 0,
0.212671, 0.715160, 0.072169, 0,
0.019334, 0.119193, 0.950227, 0 )
out = im.convert("RGB", rgb2xyz)
-------------------------------------------------------------------------------------------------------------------------------------------
通过python将图片生成字符画的更多相关文章
- python识别图片生成字符模式
此python文件来自D7哥, 放在这里备份. 用法 python3 PIL\&argparse.py 1.jpg -o test.txt --width 300 --height 300 p ...
- 20个python项目--图片转字符画
转自实验楼:https://www.shiyanlou.com/courses/370/learning/?id=1191 代码: # -*- coding:utf-8 -*- from PIL im ...
- Python 【图片转字符画】
一.安装的第三方模块 $ sudo pip3 install --upgrade pip $ sudo pip3 install pillow //window pip3 install pillow ...
- Python实现图片转字符画
from PIL import Image def get_char(r, g, b, alpha=256): ascii_char = '''$@B%8&WM#*oahkbdpqwmZO0Q ...
- Python 图片转字符画
Python 图片转字符画 一.课程介绍 1. 课程来源 原创 2. 内容简介 本课程讲述怎样使用 Python 将图片转为字符画 3. 前置课程 Python编程语言 Linux 基础入门(新版) ...
- python生成字符画
python生成字符画 这个idea来自于实验楼,非常适合练习PIL的像素处理,更重要的是非常有意思. 环境配置 依赖的第三方库就是PIL(Python Image Library),可以直接使用pi ...
- [笔记] Python 图片转字符画
一.介绍 用Python 代码完成图片转字符画 二.python 环境 Python 3.6.6 pillow 5.1.0 Python 图像处理库, 需要另外安装 三.原理 gray = 0.21 ...
- python学习---50行代码实现图片转字符画2
from PIL import Image codeLib = '''@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~<> ...
- python小项目(-)图片转字符画
# -*- coding: utf-8 -*- from PIL import Image codeLib = '''@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrj ...
随机推荐
- 大叔也说Xamarin~Android篇~调用远程API接口,发POST请求
回到目录 Xamarin我们在上节已经教大家如何去部署它的环境了,今天来说一个实际的例子,使用android客户调用.net web api的一个接口,并发送POST请求,当服务端回到请求后做出响应, ...
- PHP变量作用域
PHP 的全局变量和 C 语言有一点点不同,在 C 语言中,全局变量在函数中自动生效,除非被局部变量覆盖,这可能引起一些问题,有些人可能不小心就改变了一个全局变量.PHP 中全局变量在函数中使用时必须 ...
- lua元表Metatable
Lua 中的每个值都可以用一个 metatable. 这个 metatable 就是一个原始的 Lua table , 它用来定义原始值在特定操作下的行为. 你可以通过在 metatable 中的特定 ...
- Atitit intellij idea的使用总结attilax
Atitit intellij idea的使用总结attilax 1. ideaIC-2016.2.4.exe1 1.1. Ij vs eclipse市场份额1 1.2. Ij的优点(方便的支持gro ...
- 支持自动切换的tab标签代码札记
html代码如下: <!-- tab标签代码begin --> <div class="tab1" id="tab1"> <div ...
- 使用模板技术处理ASP.NET中GridView额外序号列的问题
问题描述: 现在要在一张GridView表中添加一列来显示行号,要求是显示下一页的时候能够递增而不是从新编号.数据库中的没有相关序号列 如何在软件端实现呢? 通过测试,添加以下代码即可解决需求. &l ...
- 【技巧】只利用 Visual Stdio 自带的工具这么找父类?
很多人说只能 F12 看见子类 其实vs里面有一个叫“对象浏览器” 通过这个就可以直接定位父类,不需要利用reflector之类的工具来找父类 具体如下:
- SOLID原则
SOLID是面向对象设计和编程(OOD&OOP)中几个重要编码原则 即:SRP单一责任原则: OCP开放封闭原则: LSP里氏替换原则: ISP接口分离原则: DIP依赖倒置原则. 1. 单一 ...
- 深入理解CSS计数器
× 目录 [1]创建计数器 [2]使用计数器 [3]DEMO 前面的话 我们对计数器已经不陌生了,有序列表中的列表项标志就是计数器. 创建计数器 创建计数器的基础包括两个方面,一是能重置计数器的起点, ...
- Uvaoj 11624 - Fire!
/************************************************************************* > File Name: test.cpp ...