python真的好难过_Python:有你们在的样子真好

2018走到了年尾,这一年经历如何、收获几多?

很感激这一年来遇到的各路贵人、朋友,以及一直默默支持我的家人。

今天,我想用Python来表达:有你们在的样子真好~

以上是效果图,通过获取微信好友头像图片组成背景,与个人头像融合,生成新的头像图片

思路

利用开源的微信接口itchat,扫码登录个人微信,读取好友信息中的头像存到本地,对头像图片进行裁剪、拼接和融合,最后将生成的图片再发送至微信到文件传输助手~

其实获取头像图片的步骤并不复杂,按照itchat官方文档的指引代码量很小。自己要做的集中在对图片文件的处理,需要些耐心。

itchat

“itchat是一个开源的微信个人号接口,使用python调用微信从未如此简单。”

“使用不到三十行的代码,你就可以完成一个能够处理所有信息的微信机器人。”

首先是安装 pip install itchat,在代码中import itchat,之后直接调用方法即可。

#扫码登录

itchat.auto_login()

#获取好友列表

friendlist = itchat.get_friends(update=True)

# 发给文件助手

itchat.send_image('result.jpg', 'filehelper')

#退出登录

itchat.logout()

获取头像图片

通过好友列表中的信息,读取头像图片内容,存储到本地,这样就完成了头像素材的获取。

好友如果很多,这个阶段耗时会较长。此外这个过程中发现有的好友可能没有设置头像、或者头像格式比较特殊,会导致读取失败,这里要利用try except语法进行控制

def get_wx_profiles():

#扫码登录

itchat.auto_login()

#获取好友列表

friendlist = itchat.get_friends(update=True)

#列表首位是你自己

if friendlist[0]["PYQuanPin"]:

user = friendlist[0]["PYQuanPin"]

else:

user = friendlist[0]["NickName"]

#创建用你微信名字命名的文件夹,存储好友头像

if not os.path.exists(user):

os.mkdir(user)

#先读取你的微信头像,存储为 你的名字.jpg

self_head = "{}/{}.jpg".format(os.getcwd(),user)

with open(self_head,'wb') as f:

head = itchat.get_head_img(friendlist[0]['UserName'])

f.write(head)

print("读取本人头像完毕")

#进入文件夹

os.chdir(user)

print("开始读取好友头像...")

for i in friendlist[1:]:

try:

i['head_img'] = itchat.get_head_img(userName=i['UserName'])

i['head_img_name'] = "%s.jpg" % i['UserName']

except ConnectionError:

print('Fail to get %s' % i['UserName'])

try:

with open(i['head_img_name'],'wb') as f:

f.write(i['head_img'])

except:

print(i['head_img_name'],"图片下载失败")

print("读取好友头像完毕")

return os.getcwd(),self_head

裁剪拼接

由于每个头像图片大小不一,需要统一标准裁剪。根据头像数量,计算略大些的平方数来设置拼接后的方图尺寸。

例如,你的好友数600,略大些的平方数是25的平方625,最终拼接图大小会定为25*25头像尺寸。剩余空白位置会填充用过的头像。此外好友头像如果获取失败,在这里我会读取到的本人头像来替换,数目小先忽略。

def combine(folder,self_head):

os.chdir(folder)

imgList = os.listdir(folder)

numImages = len(imgList)

eachLine = int(math.sqrt(numImages)) + 1

eachSize = 100

print("好友头像设定为", eachSize, "像素,每行", eachLine, "个好友,合成图为", eachSize * eachLine,"像素的方形图")

toImage = Image.new('RGB', (eachSize * eachLine, eachSize * eachLine), "#FFFFFF") # 新建一块画布

x = 0

y = 0

for i in range(eachLine*eachLine):

try:

img = Image.open(imgList[i%numImages]) # 打开图片

except IOError:

print("第%d位朋友头像可能没有设置头像,稍后用本人头像替代" % i) # 有些人没设置头像,就会有异常

img = Image.open(self_head)

finally:

img = img.resize((eachSize, eachSize), Image.ANTIALIAS) # 缩小图片

toImage.paste(img, (x * eachSize, y * eachSize)) # 拼接图片

x += 1

if x == eachLine:

x = 0

y += 1

print("图像拼接完成")

os.chdir(os.path.pardir)

os.getcwd()

print('保存拼接的图片到目录:', os.getcwd())

toImage.save('all.jpg', quality=100)

return eachSize * eachLine

图像融合

图像融合是在图像加法的基础上增加了系数和亮度调节量。主要调用的函数是addWeighted,链接,方法:

dst = cv2.addWeighter(scr1, alpha, src2, beta, gamma)

其中,alpha 为 src1 透明度,beta 为 src2 透明度.

目标图像 = 图像1 * 系数1 + 图像2 * 系数2 + 亮度调节量

这里我采用了原个人头像0.7系数、背景头像集合图0.3系数:

src1 = cv2.imread("resize.jpg")

src2 = cv2.imread("all.jpg")

result = cv2.addWeighted(src1,0.7,src2,0.3,0)

cv2.imwrite("result.jpg",result)

最终生成融合图,通过itchat发送到文件传输助手方便使用~

效果图

最后再附一张生成的测试图

回顾

最初的想法是用好友头像图片来实现“千图成像”的效果,实践过程中发现要么使用头像不全、要么复杂不够美观,所以暂时采用了融合图这种简单直接的模式来做个样本。

当然,相关的千图成像算法会继续研究。

此外关于itchat的应用真的很值得一看,之后我也要多挖掘些相关的应用。

代码下载

GitHub下载链接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值