Python 将 QQ 好友头像生成祝福语的实现代码
作者:野客 发布时间:2022-01-11 20:29:33
标签:python,头像,祝福语
本文我们来看一下如何使用 Python 将 QQ 好友头像拼成“五一快乐”四个字。我们可以将整个实现过程分为两步:爬取 QQ 好友头像、利用好友头像生成文字。
爬取头像
爬取 QQ 好友头像我们需要借助于 QQ 邮箱,首先我们从浏览器上登录 QQ 邮箱,之后按 F12
键打开开发者工具并用鼠标选中 Network
选项,如下图所示:
再接着我们按 F5
键刷新一下网页,然后在 Filter
中输入 laddr_lastlist
,如下图所示:
我们再点 Name
下的链接,点击之后右侧会出现一个窗口,我们用鼠标选中 Response
项,如下图所示:
我们最后将 Response
下面出现的内容复制到 txt 文件。
获取了爬取需要用到的东西后我们就可以开始实现爬取了,我们使用 requests
库将头像图片爬取来下存到本地,代码实现如下所示:
# 获取头像
def get_head():
file = codecs.open('qqfriends.txt', 'rb', 'utf-8')
s = file.read()
pattern = re.compile(r'\d+@qq.com')
# 正则表达式匹配所有的 qq 号
all_mail = pattern.findall(s)
# 用于存储需要访问的链接
all_link = []
url = 'http://qlogo.store.qq.com/qzone/'
for mail in all_mail:
qq = mail.replace('@qq.com', '')
l = url + qq + '/' + qq + '/100'
all_link.append(l)
# 初始化下载图片数量
i = 0
# 获取朋友头像数量
friends_count = len(all_link)
print('共{}个头像'.format(friends_count))
# 遍历链接,下载头像
for link in all_link:
i += 1
saveurl = 'head/' + str(i) + '.png'
print('第 %d 个' % i, end=' ')
sava2img(link, saveurl)
return True
# 存储图片函数,picurl 是图片的 URL,saveurl 是本地存储位置
def sava2img(picurl, saveurl):
try:
start = time.time()
response = requests.get(picurl, stream=True)
# 下载图片到本地
with open(saveurl, 'wb') as file:
file.write(response.content)
print('下载完成...', end=' ')
end = time.time()
time_ = end - start
print('用时: %.2f秒' % (time_))
return True
except:
print('出错了...')
生成文字
现在 QQ 头像图片已经有了,我们再看一下如何用这些图片生成文字,这里需要用到一下第三方库 PIL
,安装使用 pip install Pillow
,我们需要先将 “五一快乐” 四个字转化为汉字库的点阵数据再使用,现在看一下具体实现:
# 将字转化为汉字库的点阵数据
def char2bit(textStr):
KEYS = [0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01]
target = []
global count
count = 0
for x in range(len(textStr)):
text = textStr[x]
rect_list = [] * 16
for i in range(16):
rect_list.append([] * 16)
gb2312 = text.encode('gb2312')
hex_str = binascii.b2a_hex(gb2312)
result = str(hex_str, encoding='utf-8')
area = eval('0x' + result[:2]) - 0xA0
index = eval('0x' + result[2:]) - 0xA0
offset = (94 * (area-1) + (index-1)) * 32
font_rect = None
with open("HZK16", "rb") as f:
f.seek(offset)
font_rect = f.read(32)
for k in range(len(font_rect) // 2):
row_list = rect_list[k]
for j in range(2):
for i in range(8):
asc = font_rect[k * 2 + j]
flag = asc & KEYS[i]
row_list.append(flag)
output = []
for row in rect_list:
for i in row:
if i:
output.append('1')
count+=1
else:
output.append('0')
target.append(''.join(output))
return target
# 生成图片文字
def head2char(workspace,folder,self,outlist):
# 将工作路径转移至头像文件夹
os.chdir(folder)
# 获取文件夹内头像列表
imgList = os.listdir(folder)
# 获取头像图片个数
numImages = len(imgList)
# 设置头像裁剪后尺寸
eachSize = 100
# 变量 n 用于循环遍历头像图片
n=0
# 变量 count 用于为最终生成的单字图片编号
count = 0
# 初始化颜色列表,用于背景着色
colorlist = ['#FFFACD','#F0FFFF','#BFEFFF','#b7facd','#ffe7cc','#fbccff','#d1ffb8','#febec0','#E0EEE0']
# index 用来改变不同字的背景颜色
index = 0
# 每个 item 对应不同字的点阵信息
for item in outlist:
# 将工作路径转到头像所在文件夹
os.chdir(folder)
# 新建一个带有背景色的画布,16 * 16点阵,每个点处填充 2 * 2 张头像图片,故长为 16 * 2 * 100
canvas = Image.new('RGB', (3200, 3200), colorlist[index]) # 新建一块画布
# index 变换,用于变换背景颜色
index = (index+1)%9
count += 1
# 每个 16 * 16 点阵中的点,用四张 100 * 100 的头像来填充
for i in range(16*16):
# 点阵信息为 1,即代表此处要显示头像来组字
if item[i] == "1":
# 循环读取连续的四张头像图片
x1 = n % len(imgList)
x2 = (n+1) % len(imgList)
x3 = (n+2) % len(imgList)
x4 = (n+3) % len(imgList)
# 以下四组 try,将读取到的四张头像填充到画板上对应的一个点位置
# 点阵处左上角图片 1/4
try:
# 打开图片
img = Image.open(imgList[x1])
except IOError:
print("有1张图片读取失败,已使用备用图像替代")
img = Image.open(self)
finally:
# 缩小图片
img = img.resize((eachSize, eachSize), Image.ANTIALIAS)
# 拼接图片
canvas.paste(img, ((i % 16) * 2 * eachSize, (i // 16) * 2 * eachSize))
# 点阵处右上角图片 2/4
try:
img = Image.open(imgList[x2])
except IOError:
print("有1张图片读取失败,已使用备用图像替代")
img = Image.open(self)
finally:
img = img.resize((eachSize, eachSize), Image.ANTIALIAS)
canvas.paste(img, (((i % 16) * 2 + 1) * eachSize, (i // 16) * 2 * eachSize))
# 点阵处左下角图片 3/4
try:
img = Image.open(imgList[x3])
except IOError:
print("有1张图片读取失败,已使用备用图像替代")
img = Image.open(self)
finally:
img = img.resize((eachSize, eachSize), Image.ANTIALIAS)
canvas.paste(img, ((i % 16) * 2 * eachSize, ((i // 16) * 2 + 1 ) * eachSize))
# 点阵处右下角图片 4/4
try:
img = Image.open(imgList[x4])
except IOError:
print("有1张图片读取失败,已使用备用图像替代")
img = Image.open(self)
finally:
img = img.resize((eachSize, eachSize), Image.ANTIALIAS)
canvas.paste(img, (((i % 16) * 2 + 1) * eachSize, ((i // 16) * 2 + 1) * eachSize))
#调整 n 以读取后续图片
n= (n+4) % len(imgList)
os.chdir(workspace)
# 创建文件夹用于存储输出结果
if not os.path.exists('output'):
os.mkdir('output')
os.chdir('output')
# 存储将拼接后的图片,quality 为图片质量,1 - 100,100 最高
canvas.save('result%d.jpg'% count, quality=100)
看一下实现效果:
来源:https://segmentfault.com/a/1190000022530497
0
投稿
猜你喜欢
- 为何选Nuxt.js?在前后端分离出现之前,传统的web页面都是服务端渲染的,如JSP、PHP、Python Django,还有各种模板技术
- 承上启下上一篇文章我们介绍了 RNN 相关的基础知识,现在我们介绍文本生成的基本原理,主要是为了能够灵活运用 RNN 的相关知识,真实的文本
- 起源就在今年9月份,我负责的部门平台项目发布了一个新版本,该版本同时上线了一个新功能,简单说有点类似定时任务。头一天一切正常,但第二天出现了
- 利用ResNet18进行手写数字识别先写resnet18.py代码如下:import torchfrom torch import nnfr
- asp使用WScript.Shell获取电脑的网络配置信息Option Explicit Dim WSHShe
- Flask 本身相当于一个内核,比如可以用 Flask 扩展加入ORM、窗体验证工具,文件上传、身份验证等。Flask 没有默认使用的数据库
- delete 删除一张大表时空间不释放,非常慢是因为占用大量的系统资源,支持回退操作,空间还被这张表占用着。truncate table 表
- 1.静态加载 CSS,图片资源文件在页面渲染过程中可以并行下载,不会阻塞。在IE8,FF下,也可以支持JS的并行下载。尽管页面的JS下载加速
- Expire 命令用于设置 key 的过期时间。key 过期后将不再可用。r.set('2', '4028b2883
- 我们先来实现一个简单的例子,hello world。似乎每种语言教程的第一节都会讲这个,我们也不例外。首先我们先创建一个项目目录,目录可自己
- Cookie简介首先,我们对Cookie做一个简单的介绍,说明如何利用ASP来维护cookie。Cookie是存储在客户端计算机中的一个小文
- python3 最常用的三种装饰器语法总结1.简述语法装饰器也叫函数装饰器,主要作用是在不修改原来函数的代码情况下(函数本身不会被修改,执行
- 线程是进程中可以调度执行的实体。而且,它是操作系统中可以执行的最小处理单元。简单地说,一个线程就是一个程序中可以独立于其他代码执行的指令序列
- 在使用PyTorch做实验时经常会用到生成随机数Tensor的方法,比如:torch.rand()torch.randn()torch.no
- 思路一、想要实现登录豆瓣关键点分析真实post地址 ----寻找它的formdata,如下图,按浏览器的F12可以找到。实战操作实现:模拟登
- 本文实例讲述了Python实现的逻辑回归算法。分享给大家供大家参考,具体如下:使用python实现逻辑回归Using Python to I
- 概述在使用Typora写比较长的文章时,需要给章节编号,方便区分层次。如果手动编号,一旦章节顺序改变,很多章节的编号都需要一一手动修改,极其
- 一、什么是sql注入呢? 所谓SQL注入,就是
- 如何在寸土寸金的首页上使页面的价值最大化,是每个网站设计者最关心的话题。用户关注的页面长度、宽度都是有限的。宽度自不必说,一般网站都会根据自
- 字节串bytes字节串也叫字节序列,是不可变的序列,存储以字节为单位的数据字节串表示方法:b"ABCD"b"\