新的一年,新气象。

不少人都会选择换一个微信头像,迎接新的一年。

这期小F就来教大家,如何使用Python生成emoji风格的头像。

效果大致如下图,由很多的emoji图片方块组成一张新的头像图片

细节图~

主要是通过matplotlib、pillow和numpy这三个库来实现的。

import matplotlib.pyplot as plt
from scipy import spatial
from PIL import Image
import numpy as np

对于numpy和matplotlib(以及几乎所有的图像处理库)而言,图像基本上只是一个矩阵(例如A),其中每个像素§都是A的元素。

很多人学习python,不知道从何学起。
很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手。
很多已经做案例的人,却不知道如何去学习更加高深的知识。
那么针对这三类人,我给大家提供一个好的学习平台,免费领取视频教程,电子书籍,以及课程的源代码!
QQ群:810735403

如果是灰度图像,则每个像素§只是一个数字(或标量)。如果为浮点数,则为[0, 1]。如果为整数,则为[0, 255]。

如果不是灰度级(例如在这次的情况下),则每个像素都是尺寸为3-红色®,绿色(G)和蓝色(B)或尺寸为4-RGBA的矢量(A代表Alpha,表示的是透明度)。

首先读取图像,并且将图像尺寸缩小。

# 读取图片,并且修改图片大小
G_sm = np.array(Image.open('fans.png').resize([50, 50]).getdata()).reshape([50, 50, 3])/256# 显示图片
plt.figure()
plt.imshow(G_sm)
plt.title('Original Image')
plt.show()

然后读取emoji图像数据,一共是有近1600个emoji图像数据。

# 读取emoji数据
emoji_array = np.load("emojis_16.npy")# 获取emoji的平均颜色值
emoji_mean_array = np.array([ar.mean(axis=(0,1)) for ar in emoji_array]) # 将得到的每个emoji平均颜色值存储在树中以加快搜索速度
tree = spatial.KDTree(emoji_mean_array)

整个图像的平均颜色计算公式如下。

np.load,读取磁盘数组数据的函数,通常数组是以未压缩的原始二进制格式保存在扩展名为.npy的文件中。

indices = []
# 平整数组,一维
flattened_img = G_sm.reshape(-1, G_sm.shape[-1])
print(flattened_img.shape)# 匹配最相似的表情符号的像素
for pixel in flattened_img:pixel_ = np.concatenate((pixel, [1]))# 查询最近的索引_, index = tree.query(pixel_)indices.append(index)

将原图上每个像素点的颜色均值和emoji的颜色均值配对上。

# 从索引中获取对应的表情符号
emoji_matches = emoji_array[indices]# 获取图片的高度
dim = G_sm.shape[0]
print(dim)# 设置最终生成图像的大小,每个表情符号的形状都是(16,16,4),R, G, B, alpha
resized_ar = emoji_matches.reshape((dim, dim, 16, 16,4))

设置生成图像的大小,每个emoji图片的大小设置成16*16。

# 转换单个表情符号补丁(5维)
# 使用numpy块生成完整的图像(三维)
final_img = np.block([[[x] for x in row] for row in resized_ar])

生成最终结果图像,并且保存。

# 设置画布
plt.figure()
# 去除坐标轴
plt.axis('off')
# 显示图片
plt.imshow(final_img)# 保存emoji马赛克风格图像,去除白边
plt.savefig('image_emoji.png', bbox_inches="tight", pad_inches=0.0)
plt.show()

通过设置plt.savefig的参数,去除图像白边,保存图片。

下面就使用小F的微信头像为例,来实验一波~

生成的emoji图看起来不是很细腻,可以设置一下图片参数为100。

G_sm = np.array(Image.open('weixin.png').resize([100, 100]).getdata()).reshape([100, 100, 3])/256

得到结果如下。

看起来还不错,大家伙也可以使用自己喜欢的头像去生成~,源代码1我

在这里还是要推荐下我自己建的Python开发交流学习(qq)群:810735403,群里都是学Python开发的,如果你正在学习Python ,欢迎你加入,大家都是软件开发党,不定期分享干货(只有Python软件开发相关的),包括我自己整理的一份2020最新的Python进阶资料和高级开发教程,欢迎进阶中和想深入Python的小伙伴!

新年新气象,2021来了,用Python换一张头像迎新年吧!相关推荐

  1. 2021来了,用Python换一张头像到新年!

    点击 机器学习算法与Python学习 ,选择加星标 精彩内容不迷路 新的一年,新气象. 不少人都会选择换一个微信头像,迎接新的一年. 这期小F就来教大家,如何使用Python生成emoji风格的头像. ...

  2. 2021年12月Python小屋编程比赛获奖名单

    首先祝所有朋友元旦快乐,在新的一年里天天开心,在技术上每天都有新突破! 中国大学MOOC"Python程序设计基础"免费学习地址 推荐图书: <Python程序设计基础(第2 ...

  3. 2021年11月Python小屋编程比赛获奖名单

    中国大学MOOC"Python程序设计基础"第5次开课 推荐图书: <Python程序设计基础(第2版)>,ISBN:9787302490562,董付国,清华大学出版社 ...

  4. 2021年10月Python小屋编程比赛获奖名单

    全国高校教师Python课程高级研修班(线上,11月20-21日) 中国大学MOOC"Python程序设计基础"第5次开课 推荐图书: <Python程序设计基础(第2版)& ...

  5. 2021年8月Python小屋编程比赛获奖名单

    推荐图书: <Python程序设计基础(第2版)>,ISBN:9787302490562,董付国,清华大学出版社,第19次印刷,清华大学出版社2019.2020年度畅销图书,山东省高等教育 ...

  6. 2021年6月Python小屋编程比赛获奖名单

    推荐图书: <Python程序设计基础(第2版)>,ISBN:9787302490562,董付国,清华大学出版社,第19次印刷,清华大学出版社2019.2020年度畅销图书,山东省高等教育 ...

  7. 2021年4月Python小屋编程比赛获奖名单

    推荐图书: <Python程序设计基础(第2版)>,ISBN:9787302490562,董付国,清华大学出版社,第18次印刷,清华大学出版社2019.2020年度畅销图书,山东省高等教育 ...

  8. 【2021最新版】Python 并发编程实战,用多线程、多进程、多协程加速程序运行

    [2021最新版]Python 并发编程实战,用多线程.多进程.多协程加速程序运行 视频地址:https://www.bilibili.com/video/BV1bK411A7tV/ P1 Pytho ...

  9. python在手机上如何模拟登录_用 Python 换个姿势「模拟登录」

    原标题:用 Python 换个姿势「模拟登录」 作者:librauee 今天给大家介绍Python一个非常有意思的库PyUserInput,它集成了PyMouse和PyKeyboard这俩模块,能够模 ...

最新文章

  1. qui ajax,Ajax Fils de T Lamon
  2. JspWriter与PrintWriter的关系
  3. Rebuild Instance 操作详解 - 每天5分钟玩转 OpenStack(37)
  4. 只用2000行代码实现google protocol buffer c++版的功能
  5. pytorch中gather函数的理解
  6. oracle ebs 期间 打开,ORACLE EBS重新打开关闭库存期间
  7. 金融评分卡项目—3.流失预警模型中的数据预处理与特征衍生
  8. 票据通的支票管理的账户管理的对应账号支票已使用该怎么重新修改票据打印模板;
  9. 集成电路那些事儿:CMOS模拟集成电路版图基础
  10. Unity设置天空盒子
  11. crt导出服务器文件,CRT中将服务器中生成的awr报告用会话日志提取到本地
  12. c/c++文本单词查询
  13. 红帽linux卸载软件命令,好记性不如烂笔头- linux 下rpm软件的安装和卸载 rpm --force -ivh ......
  14. 数字孪生技术在智慧城市建设中有哪些应用?
  15. 管道的故事(一)管道的故事
  16. 五线谱如何快速修改谱号,Overture这个小技巧必须要掌握!
  17. python获取所有盘符_自动扫描所有本地磁盘,获取所有图片信息
  18. iOS读懂崩溃日志,解析崩溃日志
  19. 单身程序员上班路上二三事(一)
  20. 三星4k3d电视测试软件,技术篇 | 央视4K超高清频道怎么看?三星电视让您大饱眼福!...

热门文章

  1. 掌握el-table的formatter方法,提升数据展示效果
  2. C++题解:CSP迎国庆热身公益赛T2——猜数游戏(70分)
  3. 「Python|音视频处理|场景案例」如何使用ffmpeg下载m3u8视频到本地并保存成mp4
  4. 第一节 函数与极限——映射与函数
  5. Web3还没实现,Web5乍然惊现!
  6. 微信小程序获取当前时间及获取当前日期
  7. 微信小程序时间戳转换为日期
  8. 创建新Docker容器时出现“The container name /xxx is already in use by container xxxxxxxxxxx...”问题的解决办法
  9. nn.Linear()函数详解及代码使用
  10. 2021最新Android开发者学习路线,已整理成文档