用python實(shí)現(xiàn)一幅春聯(lián)實(shí)例代碼
前言
過年了,家家戶戶都得貼春聯(lián),紅紅火火過大年~
春聯(lián)是天朝傳統(tǒng)節(jié)日完美銜接了民族文化的產(chǎn)物,以美好的詩詞文字表達(dá)美好愿望,是天朝特有文學(xué)形式綻放。也是天朝人民自古以來的過年習(xí)俗,家家戶戶都必不可少。

咱們作為程序員,不知道你們會(huì)不會(huì)寫毛筆字,反正我小時(shí)候練過,但是現(xiàn)在不會(huì)寫了。不過對(duì)于美好生活的憧憬,可不比李白杜甫等大佬少,咱們用代碼也是可以寫出漂亮的春聯(lián),一樣的向親人朋友送上咱們美好的祝福。

哈哈 Python 生成不出來,字體原因,懶得改了,就用派森吧,大家可以自己去改改字體。
代碼展示
" 模塊導(dǎo)入"
import io
from PIL import Image
import numpy as np
import requests
" 字模下載 "
"""獲取單個(gè)漢字圖片
ch - 單個(gè)漢字或英文字母(僅支持大寫)
quality - 單字分辨率,H-640像素,M-480像素,L-320像素
"""
def get_word(ch, quality):
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)
" 生成春聯(lián) "
"""
text - 春聯(lián)內(nèi)容,以空格斷行
HorV - H-橫排,V-豎排
quality - 單字分辨率,H-640像素,M-480像素,L-320像素
out_file - 輸出文件名
"""
def write_couplets(text, HorV='V', quality='L', out_file=None):
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()
text = '地位清高日月每從肩上過 門庭開豁江山常在掌中看'
write_couplets(text, HorV='H', quality='M', out_file='這個(gè)對(duì)聯(lián) 牛逼.jpg')
效果展示

豎版
text = '丹鳳呈祥龍獻(xiàn)瑞 紅桃賀歲杏迎春' write_couplets(text, HorV='V', quality='M', out_file='福滿人間.jpg')

提前祝大家新年快樂!!
總結(jié)
到此這篇關(guān)于用python實(shí)現(xiàn)一幅春聯(lián)實(shí)例代碼的文章就介紹到這了,更多相關(guān)python春聯(lián)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
TensorFlow實(shí)現(xiàn)簡(jiǎn)單卷積神經(jīng)網(wǎng)絡(luò)
這篇文章主要為大家詳細(xì)介紹了TensorFlow實(shí)現(xiàn)簡(jiǎn)單卷積神經(jīng)網(wǎng)絡(luò),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05
python使用正則表達(dá)式替換匹配成功的組并輸出替換的次數(shù)
正則表達(dá)式是一個(gè)特殊的字符序列,它能幫助你方便的檢查一個(gè)字符串是否與某種模式匹配。這篇文章主要介紹了python使用正則表達(dá)式替換匹配成功的組并輸出替換的次數(shù),需要的朋友可以參考下2017-11-11
實(shí)例講解Python爬取網(wǎng)頁數(shù)據(jù)
這篇文章給大家通過實(shí)例講解了Python爬取網(wǎng)頁數(shù)據(jù)的步驟以及操作過程,有興趣的朋友跟著學(xué)習(xí)下吧。2018-07-07
python使用nibabel和sitk讀取保存nii.gz文件實(shí)例
這篇文章主要介紹了python使用nibabel和sitk讀取保存nii.gz文件實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07
20行Python代碼實(shí)現(xiàn)視頻字符化功能
這篇文章主要介紹了20行Python代碼實(shí)現(xiàn)視頻字符化功能,本文通過實(shí)例代碼截圖的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04

