虎年将至,老板把今年公司写500副春联任务交给了我,我...
【摘要】
目录
1.安装Pillow库
2.安装numpy和requests
3.补课:写春联将要用到的几个库
3.1 关于BytesIO用法
3.2 from PIL import Image
3.3 import numpy as np
3.4 requests库
4.测试代码
4.1&n...
目录
虎年将至,老板准备送公司每个人一副春联,要求不重样,把这个任务交给了我。我微微一笑,马上开干。博主准备用python代替人工来写春联。
1.安装Pillow库
输入安装指令
pip install Pillow
2.安装numpy和requests
输入安装指令
-
pip install numpy
-
pip install requests
3.补课:写春联将要用到的几个库
3.1 关于BytesIO用法
内存读写bytes 用BytesIO,
BytesIO写入时,写入的不是str,是UTF-8编码的bytes。
通过缓存,存入文件。
通过缓存,读取文件。
文件句柄赋值BytesIO。
3.2 from PIL import Image
在PIL模块中导入Image类。
3.3 import numpy as np
关于numpy
NumPy(Numerical Python)是Python的一种开源的数值计算扩展。这种工具可用来存储和处理大型矩阵,比Python自身的嵌套列表(nested list structure)结构要高效的多(该结构也可以用来表示矩阵(matrix)),支持大量的维度数组与矩阵运算,此外也针对数组运算提供大量的数学函数库mpy。
用import导入numpy时,np是导入numpy的别名,可以使用缩写的别名进行调用。
3.4 requests库
requests是python实现的最简单易用的HTTP库。
-
# 发送一个 HTTP POST 请求:
-
r = requests.post("http://httpbin.org/post",data = {'key':'value'})
4.测试代码
这里用的天元大佬的代码
-
import io
-
from PIL import Image
-
import numpy as np
-
import requests
-
def get_word(ch, quality):
-
"""获取单个汉字(字符)的图片
-
ch - 单个汉字或英文字母(仅支持大写)
-
quality - 单字分辨率,H-640像素,M-480像素,L-320像素
-
"""
-
-
fp = io.BytesIO(requests.post(url='http://xufive.sdysit.com/tk', data={'ch':ch}).content)
-
im = Image.open(fp)
-
w, h = im.size
-
if quality == 'M':
-
w, h = int(w*0.75), int(0.75*h)
-
elif quality == 'L':
-
w, h = int(w*0.5), int(0.5*h)
-
-
return im.resize((w,h))
-
def get_bg(quality):
-
"""获取春联背景的图片"""
-
-
return get_word('bg', quality)
-
def write_couplets(text, HorV='V', quality='L', out_file=None):
-
"""生成春联
-
text - 春联内容,以空格断行
-
HorV - H-横排,V-竖排
-
quality - 单字分辨率,H-640像素,M-480像素,L-320像素
-
out_file - 输出文件名
-
"""
-
-
usize = {'H':(640,23), 'M':(480,18), 'L':(320,12)}
-
bg_im = get_bg(quality)
-
text_list = [list(item) for item in text.split()]
-
rows = len(text_list)
-
cols = max([len(item) for item in text_list])
-
-
if HorV == 'V':
-
ow, oh = 40+rows*usize[quality][0]+(rows-1)*10, 40+cols*usize[quality][0]
-
else:
-
ow, oh = 40+cols*usize[quality][0], 40+rows*usize[quality][0]+(rows-1)*10
-
out_im = Image.new('RGBA', (ow, oh), '#f0f0f0')
-
-
for row in range(rows):
-
if HorV == 'V':
-
row_im = Image.new('RGBA', (usize[quality][0], cols*usize[quality][0]), 'white')
-
offset = (ow-(usize[quality][0]+10)*(row+1)-10, 20)
-
else:
-
row_im = Image.new('RGBA', (cols*usize[quality][0], usize[quality][0]), 'white')
-
offset = (20, 20+(usize[quality][0]+10)*row)
-
-
for col, ch in enumerate(text_list[row]):
-
if HorV == 'V':
-
pos = (0, col*usize[quality][0])
-
else:
-
pos = (col*usize[quality][0],0)
-
-
ch_im = get_word(ch, quality)
-
row_im.paste(bg_im, pos)
-
row_im.paste(ch_im, (pos[0]+usize[quality][1], pos[1]+usize[quality][1]), mask=ch_im)
-
-
out_im.paste(row_im, offset)
-
-
if out_file:
-
out_im.convert('RGB').save(out_file)
-
out_im.show()
-
text1 = '金牛辞岁千仓满 玉虎迎春百业兴'
-
text2 = '玉虎迎春'
-
write_couplets(text1, HorV='V', quality='M', out_file='上下批.jpg')
-
write_couplets(text2, HorV='H', quality='M', out_file='横批.jpg')
4.1 虎虎跃龙腾生紫气 风调雨顺兆丰年 虎跃龙腾
-
text1 = '虎跃龙腾生紫气 风调雨顺兆丰年'
-
text2 = '虎跃龙腾'
-
write_couplets(text1, HorV='H', quality='M', out_file='上下批.jpg')
-
write_couplets(text2, HorV='H', quality='M', out_file='横批.jpg')
4.2 花事才逢花好日,虎年更有虎威风 花境迎虎
-
text1 = '花事才逢花好日 虎年更有虎威风 '
-
text2 = '花境迎虎'
-
write_couplets(text1, HorV='H', quality='M', out_file='上下批.jpg')
-
write_couplets(text2, HorV='H', quality='M', out_file='横批.jpg')
4.3 金牛辞岁千仓满,玉虎迎春百业兴 玉虎迎春
结尾
文章来源: xintiaobao.blog.csdn.net,作者:心跳包,版权归原作者所有,如需转载,请联系作者。
原文链接:xintiaobao.blog.csdn.net/article/details/122444138
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)