中秋节之Python绘制许愿树和月饼(打开程序员世界的大门)

本文涉及的产品
函数计算FC,每月免费额度15元,12个月
简介: 中秋节之Python绘制许愿树和月饼(打开程序员世界的大门)

一、利用Python编写的中秋许愿树

https://blog.csdn.net/lzhcoder/article/details/126629828?spm=1001.2014.3001.5502

中秋许愿树

import turtle
import random
def love(x, y):  # 在(x,y)处画爱⼼
    lv = turtle.Turtle()
    lv.hideturtle()
    lv.up()
    lv.goto(x, y)  # 定位到(x,y)
    def curvemove():
        for i in range(20):
            lv.right(10)
            lv.forward(2)
    lv.color('red', 'pink')
    lv.speed(10000000)
    lv.pensize(1)
    lv.down()
    lv.begin_fill()
    lv.left(160)
    lv.forward(22)
    curvemove()
    lv.left(120)
    curvemove()
    lv.forward(22)
    lv.write("中秋节快乐", font=("Arial", 12, "normal"), align="center")  # 写上表⽩的⼈的名字
    lv.left(140)  # 画完复位
    lv.end_fill()
def tree(branchLen, t):
    if branchLen > 5:
        if branchLen < 20:
            t.color("green")
            t.pensize(random.uniform((branchLen + 5) / 4 - 2, (branchLen + 6) / 4 + 5))
            t.down()
            t.down()
            t.forward(branchLen)
            love(t.xcor(), t.ycor())  # 传输现在turtle的坐标
            t.up()
            t.backward(branchLen)
            t.color("brown")
            return
        t.pensize(random.uniform((branchLen + 5) / 4 - 2, (branchLen + 6) / 4 + 5))
        t.down()
        t.forward(branchLen)
        # 以下递归
        ang = random.uniform(15, 45)
        t.right(ang)
        tree(branchLen - random.uniform(12, 16), t)  # 随机决定减⼩长度
        t.left(2 * ang)
        tree(branchLen - random.uniform(12, 16), t)  # 随机决定减⼩长度
        t.right(ang)
        t.up()
        t.backward(branchLen)
myWin = turtle.Screen()
t = turtle.Turtle()
t.hideturtle()
t.speed(1000)
t.left(90)
t.up()
t.backward(200)
t.down()
t.color("brown")
t.pensize(32)
t.forward(60)
tree(100, t)
myWin.exitonclick()

二、自定义中秋月饼绘制

from numpy import sin, cos, pi
import matplotlib.pyplot as plt
from matplotlib.patches import Arc, Circle, Wedge
from matplotlib.font_manager import FontProperties
num=5
list={'红色':'red','黄色':'yellow','淡蓝':'lightcyan','粉红':'pink','绿色':'greenyellow','橘子色':'orange','天空蓝':'aqua',
      '土黄色':'wheat','紫色':'deeppink','灰色':'lightgrey','深黄色':'orangered','深紫色':'orchid'}                    #颜色的样式
class MoonCake():                           #定义一个类
    def __init__(self,pattern,center,roundt,edge,sector,largefan,largefan_0,blessing,blessing_0,number):      #对数据进行封装
        self.pattern = pattern             #月饼边缘花纹的颜色
        self.center = center               #月饼主体圆,边的颜色
        self.roundt = roundt               #月饼主体圆实部的颜色
        self.edge =edge                    #请输入4个大的扇形花纹的颜色
        self.sector = sector               #请输入4个大的扇形花纹实部的颜色
        self.largefan = largefan           #请输入4个小的扇形花纹的颜色
        self.largefan_0 = largefan_0       #请输入4个小的扇形花纹实部的颜色
        self.blessing = blessing           #请输入祝福语
        self.blessing_0 = blessing_0       #请输入祝福语的颜色
        self.number = number               #请输入保存图片的序号
    def lucky(self):
        length = 20
        R = 3**0.5*length/(3**0.5*cos(pi/12)-sin(pi/12))
        r = 2*sin(pi/12)*R/3**0.5
        arc1 = Arc([0, length], width=2*r, height=2*r,
                   angle=0, theta1=30, theta2=150, ec=str(self.pattern),linewidth=4)                #ec为线条颜色,fc为填充颜色,可以自由替换
        arc2 = Arc([-length/2, length/2*3**0.5], width=2*r, height=2*r,
                   angle=0, theta1=60, theta2=180, ec=str(self.pattern), linewidth=4)
        arc3 = Arc([-length/2*3**0.5, length/2], width=2*r, height=2*r,
                   angle=0, theta1=90, theta2=210, ec=str(pattern), linewidth=4)
        arc4 = Arc([-length, 0], width=2*r, height=2*r, angle=0, theta1=120, theta2=240, ec=str(self.pattern),linewidth=4)     #ec为线条颜色,fc为填充颜色,可以自由替换
        arc5 = Arc([-length/2*3**0.5, -length/2], width=2*r, height=2*r,
                   angle=0, theta1=150, theta2=270, ec=str(self.pattern), linewidth=4)
        arc6 = Arc([-length/2, -length/2*3**0.5], width=2*r, height=2*r,
                   angle=0, theta1=180, theta2=300, ec=str(self.pattern), linewidth=4)
        arc7 = Arc([0, -length], width=2*r, height=2*r, angle=0, theta1=210, theta2=330, ec=str(self.pattern),linewidth=4)
        arc8 = Arc([length/2, -length/2*3**0.5], width=2*r, height=2*r,
                   angle=0, theta1=240, theta2=360, ec=str(self.pattern), linewidth=4)
        arc9 = Arc([length/2*3**0.5, -length/2], width=2*r, height=2*r,
                   angle=0, theta1=270, theta2=390, ec=str(self.pattern), linewidth=4)
        arc10 = Arc([length, 0], width=2*r, height=2*r, angle=0, theta1=300, theta2=420, ec=str(self.pattern), linewidth=4)
        arc11 = Arc([length/2*3**0.5, length/2], width=2*r, height=2*r,
                    angle=0, theta1=330, theta2=450, ec=str(self.pattern), linewidth=4)
        arc12 = Arc([length/2, length/2*3**0.5], width=2*r, height=2*r,
                    angle=0, theta1=0, theta2=120, ec=str(self.pattern), linewidth=4)
        circle = Circle((0,0), R, ec=str(self.center), fc=str(self.roundt), linewidth=4)
        wedge1 = Wedge([-2, 2], R-5, 90, 180,
                       ec=str(self.edge), fc=str(self.sector), linewidth=4)
        wedge2 = Wedge([-5, 5], R-12, 90, 180, ec=str(self.largefan),
                       fc=str(self.largefan_0), linewidth=4)                             #ec为线条颜色,fc为填充颜色,可以自由替换
        wedge3 = Wedge([-2, -2], R-5, 180, 270, ec=str(self.edge),
                       fc=str(self.sector), linewidth=4)
        wedge4 = Wedge([-5, -5], R-12, 180, 270, ec=str(self.largefan),
                       fc=str(self.largefan_0), linewidth=4)
        wedge5 = Wedge([2, -2], R-5, 270, 360, ec=str(self.edge),
                       fc=str(self.sector), linewidth=4)
        wedge6 = Wedge([5, -5], R-12, 270, 360, ec=str(self.largefan),
                       fc=str(self.largefan_0), linewidth=4)
        wedge7 = Wedge([2, 2], R-5, 0, 90, ec=str(self.edge),                            #ec为线条颜色,fc为填充颜色,可以自由替换
                       fc=str(self.sector), linewidth=4)
        wedge8 = Wedge([5, 5], R-12, 0, 90, ec=str(self.largefan),
                       fc=str(self.largefan_0), linewidth=4)
        art_list = [arc1, arc2, arc3, arc4, arc5, arc6, arc7, arc8, arc9, arc10, arc11, arc12]
        art_list.extend([circle, wedge1, wedge2, wedge3, wedge4, wedge5, wedge6, wedge7, wedge8])
        fig, ax = plt.subplots(figsize=(8,8))
        ax.set_aspect('equal')
        for a in art_list:
            ax.add_patch(a)
        plt.axis('off')
        font_set = FontProperties(fname=r"Alibaba-PuHuiTi-Medium.ttf", size=15)
        plt.text(-8.4, -7,'中秋\n快乐', bbox=dict(boxstyle='circle', fc="skyblue", ec='red', linewidth=4), fontproperties=font_set,   fontsize=50, color='yellow') ##ec为线条颜色,color为字体颜色,可以自由替换
        plt.text(-43, -33, str(self.blessing),fontproperties=font_set, fontsize=30, color=str(self.blessing_0))
        plt.ylim([-35, 35])
        plt.xlim([-35, 35])
        name='tset'+str(number)+'.png'      #生成图片序号
        plt.savefig(name)                   #保存图片
        plt.show()
while num:                                                     #根据需要自己可以决定制作几个月饼
    print('选择颜色,选择颜色输入一定要正确{}'.format(list))
    print('不选择我给出的颜色也可以,你自定义选择的颜色输入一定要准确\n')              #输入的格式一定要正确,不然会错
    print('')
    pattern = input('请输入月饼边缘花纹的颜色:')                  #制作月饼,并输入参数
    center = input('请输入月饼主体圆,边的颜色:')
    roundt = input('请输入月饼主体圆实部的颜色:')
    edge = input('请输入4个大的扇形花纹的颜色:')
    sector = input('请输入4个大的扇形花纹实部的颜色:')
    largefan = input('请输入4个小的扇形花纹的颜色:')
    largefan_0 = input('请输入4个小的扇形花纹实部的颜色:')
    blessing = input('请输入祝福语:')
    blessing_0 = input('请输入祝福语的颜色:')
    number = int(input('请输入保存图片的序号:'))
    num = int(input('输入数字0结束月饼制作:'))
    good=MoonCake(pattern,center,roundt,edge,sector,largefan,largefan_0,blessing,blessing_0,number)
    good.lucky()

字体下载地址:

http://tianchi-media.oss-cn-beijing.aliyuncs.com/DSW/Python/miniproject/01_draw_moon_cake/Alibaba-PuHuiTi-Medium.ttf

静下心来写代码需要”精神力量“。精神的探究有丰富的理论支撑,这里不再累述有兴趣的同学们可以去翻阅相关书籍下面是摘抄的一段:

人们已经把世界的有形实体细化到了极致,已经看透它的内部构造。从分子到原子,再从原子到量子。接下来我们要做的事情就是把精神细分,找到精神的量子。安布罗斯·佛莱明爵士说:“能量,就其终极本质而言,只有当它表现为我们所说的‘精神’或‘意志’而运转时,方可被我们所理解。


相关实践学习
基于函数计算一键部署掌上游戏机
本场景介绍如何使用阿里云计算服务命令快速搭建一个掌上游戏机。
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
相关文章
|
6天前
|
算法 数据处理 索引
告别低效搜索!Python中Trie树与Suffix Tree的实战应用秘籍!
【7月更文挑战第21天】探索Python中的字符串搜索效率提升:使用Trie树与Suffix Tree。Trie树优化单词查询,插入和删除,示例展示其插入与搜索功能。Suffix Tree,复杂但强大,适用于快速查找、LCP查询。安装[pysuffixtree](https://pypi.org/project/pysuffixtree/)库后,演示查找子串及最长公共后缀。两者在字符串处理中发挥关键作用,提升数据处理效率。**
|
8天前
|
存储 大数据 索引
解锁Python隐藏技能:构建高效后缀树Suffix Tree,处理大数据游刃有余!
【7月更文挑战第19天】Suffix Tree 概述:** 为高效处理字符串搜索、匹配和大数据分析,后缀树是一种优化数据结构,可快速检索后缀、执行最长公共后缀查询及字符串排序。Python中虽无内置实现,但可通过第三方库或自建代码构造。应用于字符串搜索、生物信息学等领域,提升大数据处理效率。
19 3
|
8天前
|
存储 开发者 Python
从理论到实践:Python中Trie树与Suffix Tree的完美结合,开启编程新篇章!
【7月更文挑战第19天】在编程实践中,Trie树和Suffix Tree优化了字符串处理。Trie树用于快速拼写检查,如在构建词库后,能高效判断单词是否存在。Suffix Tree则助力文本相似度检测,找寻共同子串。通过Python示例展示了Trie树插入和搜索方法,并指出Suffix Tree虽复杂但能提升性能。结合两者,实现复杂功能,展现数据结构的强大。
25 3
|
7天前
|
人工智能 算法 数据挖掘
高效文本处理新纪元:Python后缀树Suffix Tree,让数据分析更智能!
【7月更文挑战第20天】后缀树是文本处理的关键工具,它在Python中虽需第三方库支持(如pysuffixtree),但能高效执行搜索、重复内容检测等任务。应用于文本搜索、重复内容检测、生物信息学、文本压缩及智能推荐系统。随着AI和大数据发展,后缀树将在更多领域展现潜力,助力数据分析智能化和高效化。学习和利用后缀树,对于驾驭海量文本数据至关重要。**
17 1
|
7天前
|
存储 算法 Python
Python数据结构新视角:Trie树与Suffix Tree的相爱相杀,你站哪边?
【7月更文挑战第20天】在编程领域,Trie树(前缀树)与Suffix Tree(后缀树)犹如双星,各有专长。Trie树高效检索字符串集合,擅长前缀匹配,适用于自动补全和拼写检查;Suffix Tree则管理字符串所有后缀,加速子串查询,解最长公共前缀和重复子串难题。两者在不同场景发光发热,Trie树于快速响应的自动完成胜出,Suffix Tree则在基因序列分析和文本模式识别中独领风骚。抉择之间,应用场景与需求成关键,恰如剑客选剑,唯理解本质方能制胜。
|
8天前
|
大数据 UED 开发者
实战演练:利用Python的Trie树优化搜索算法,性能飙升不是梦!
【7月更文挑战第19天】Trie树,又称前缀树,是优化字符串搜索的高效数据结构。通过利用公共前缀,Trie树能快速插入、删除和查找字符串。
27 2
|
6天前
|
存储 算法 索引
从菜鸟到大神:一文带你彻底搞懂Python中的后缀树Suffix Tree奥秘!
【7月更文挑战第21天】后缀树是高效处理字符串问题的数据结构,用于存储字符串后缀并排序。它能优化字符串搜索、最长公共前缀查询等,时间复杂度近乎线性。Python中可通过自定义类实现,应用包括字符串搜索、生物信息学分析等。学习后缀树需理解算法和数据结构,实践编写代码或使用库如`suffix_trees`。掌握后缀树能提升算法思维。**
12 0
|
6天前
|
存储 算法 搜索推荐
Python进阶必备:字典树Trie与后缀树Suffix Array,效率提升的神器!
【7月更文挑战第21天】Python进阶:Trie树实现自动补全,后缀数组解决最长重复子串。Trie树优化前缀搜索,适用于自动补全系统,如文本编辑器中的`autocomplete`功能。后缀数组,非树但高效处理字符串后缀,与LCP数组配合找到最长重复子串。两者提升字符串处理效率,是编程利器。学习并运用这些数据结构可增强程序性能。**
13 0