用python實(shí)現(xiàn)一幅春聯(lián)實(shí)例代碼
前言
過年了,家家戶戶都得貼春聯(lián),紅紅火火過大年~
春聯(lián)是天朝傳統(tǒng)節(jié)日完美銜接了民族文化的產(chǎn)物,以美好的詩詞文字表達(dá)美好愿望,是天朝特有文學(xué)形式綻放。也是天朝人民自古以來的過年習(xí)俗,家家戶戶都必不可少。
咱們作為程序員,不知道你們會不會寫毛筆字,反正我小時(shí)候練過,但是現(xiàn)在不會寫了。不過對于美好生活的憧憬,可不比李白杜甫等大佬少,咱們用代碼也是可以寫出漂亮的春聯(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è)對聯(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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
TensorFlow實(shí)現(xiàn)簡單卷積神經(jīng)網(wǎng)絡(luò)
這篇文章主要為大家詳細(xì)介紹了TensorFlow實(shí)現(xiàn)簡單卷積神經(jīng)網(wǎng)絡(luò),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05python使用正則表達(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-07python使用nibabel和sitk讀取保存nii.gz文件實(shí)例
這篇文章主要介紹了python使用nibabel和sitk讀取保存nii.gz文件實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-0720行Python代碼實(shí)現(xiàn)視頻字符化功能
這篇文章主要介紹了20行Python代碼實(shí)現(xiàn)視頻字符化功能,本文通過實(shí)例代碼截圖的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04