Python 探究“一行代码画爱心”的秘密,去向心爱的人表白吧

简介: Python 探究“一行代码画爱心”的秘密,去向心爱的人表白吧

今天7月8号,恰逢儿子生日,我来画个爱心向他表达一下爱意吧:

>>> print('\n'.join([''.join([('ILoveYangCheng'[(x-y)%len('ILoveYangCheng')] if((x*0.05)**2+(y*0.1)**2-1)**3-(x*0.05)**2*(y*0.1)**3<=0 else' ') for x in range(-30,30)]) for y in range(13,-12,-1)]))
                oveYangCh           gChengILo               
            gILoveYangChengIL   YangChengILoveYan           
          ngILoveYangChengILoveYangChengILoveYangCh         
         ngILoveYangChengILoveYangChengILoveYangChen        
        ngILoveYangChengILoveYangChengILoveYangChengI       
        gILoveYangChengILoveYangChengILoveYangChengIL       
        ILoveYangChengILoveYangChengILoveYangChengILo       
        LoveYangChengILoveYangChengILoveYangChengILov       
        oveYangChengILoveYangChengILoveYangChengILove       
        veYangChengILoveYangChengILoveYangChengILoveY       
         YangChengILoveYangChengILoveYangChengILoveY        
          ngChengILoveYangChengILoveYangChengILoveY         
          gChengILoveYangChengILoveYangChengILoveYa         
            engILoveYangChengILoveYangChengILoveY           
             gILoveYangChengILoveYangChengILoveY            
              LoveYangChengILoveYangChengILoveY             
                eYangChengILoveYangChengILove               
                  ngChengILoveYangChengILov                 
                    hengILoveYangChengILo                   
                       ILoveYangChengI                      
                          eYangChen                         
                             gCh                            
                              h                             
>>> 


网上流传了很多类似这种“一行代码画爱心”的文章,但大多数都没作深入研究,有的甚至是收费栏目中还有改错代码的,比如 %‘字串实际长度’ 都直接‘%8’。下面,我来对此代码作点解析,告诉小白们爱心到底是怎么画出来的?



探究一:去掉字符串,全部用'.'代替


>>> print('\n'.join([''.join([('.' if((x*0.05)**2+(y*0.1)**2-1)**3-(x*0.05)**2*(y*0.1)**3<=0 else' ') for x in range(-30,30)]) for y in range(13,-12,-1)]))
                .........           .........               
            .................   .................           
          .........................................         
         ...........................................        
        .............................................       
        .............................................       
        .............................................       
        .............................................       
        .............................................       
        .............................................       
         ...........................................        
          .........................................         
          .........................................         
            .....................................           
             ...................................            
              .................................             
                .............................               
                  .........................                 
                    .....................                   
                       ...............                      
                          .........                         
                             ...                            
                              .                             
>>> 


探究二:其实就是心形线的函数式在起作用,换成直线看效果

>>> print('\n'.join([''.join([('.' if y==x+1 else' ') for x in range(-30,30)]) for y in range(15,-15,-1)]))
                                            .               
                                           .                
                                          .                 
                                         .                  
                                        .                   
                                       .                    
                                      .                     
                                     .                      
                                    .                       
                                   .                        
                                  .                         
                                 .                          
                                .                           
                               .                            
                              .                             
                             .                              
                            .                               
                           .                                
                          .                                 
                         .                                  
                        .                                   
                       .                                    
                      .                                     
                     .                                      
                    .                                       
                   .                                        
                  .                                         
                 .                                          
                .                                           
               .                                            
>>> # 直线方程 y = x + 1


直线方程 y = x+1 斜率1的倾角看上去不是45度,是因为x,y的长度比不是1:1。

方程式换成不等式 y > = x + 1 图像就成为一个区域,换个抛物线试试效果:

>>> print('\n'.join([''.join([('.' if y>=0.035*x**2-12 else' ') for x in range(-30,30)]) for y in range(15,-15,-1)]))
   .......................................................  
   .......................................................  
    .....................................................   
    .....................................................   
     ...................................................    
     ...................................................    
      .................................................     
       ...............................................      
       ...............................................      
        .............................................       
        .............................................       
         ...........................................        
          .........................................         
           .......................................          
           .......................................          
            .....................................           
             ...................................            
              .................................             
              .................................             
               ...............................              
                .............................               
                 ...........................                
                   .......................                  
                    .....................                   
                     ...................                    
                       ...............                      
                         ...........                        
                              .                             
>>> 抛物线内部区域: y >= 0.035 x² - 12


探究三:换个心形方程式

网上随便搜索了一张心形方程式的图片:


20210708171045196.png



方程x,y的取值范围有点小,可以先放大10倍: 0.01*x*x+(0.1*y-pow(0.01*x*x,1/3))**2-1=0

由于纵横比不为1,再适当调整各个系数的大小;还有我们的坐标系是整数点,想和直线方程一样显示边界点不太现实,所以只能以 f(x,y)<=0的形式显示图形区域。若<=换成>=,则相当于图章的阳刻和阴刻的区别。


>>> print('\n'.join([''.join([('HannYang'[(x+y+78)%8] if 0.003*x*x+(0.075*y-pow(0.0015*x*x,1/3))**2-0.6<=0 else' ') for x in range(-30,30)]) for y in range(15,-12,-1)]))
                   annYang         annYang                  
                  gHannYangH     ngHannYang                 
                 angHannYangH   YangHannYang                
                 YangHannYangH nnYangHannYan                
                nnYangHannYangHannYangHannYan               
                annYangHannYangHannYangHannYa               
                HannYangHannYangHannYangHannY               
                 HannYangHannYangHannYangHan                
                 gHannYangHannYangHannYangHa                
                 ngHannYangHannYangHannYangH                
                  ngHannYangHannYangHannYan                 
                  angHannYangHannYangHannYa                 
                   angHannYangHannYangHann                  
                    angHannYangHannYangHa                   
                    YangHannYangHannYangH                   
                     YangHannYangHannYan                    
                      YangHannYangHannY                     
                       YangHannYangHan                      
                        YangHannYangH                       
                         YangHannYan                        
                          YangHannY                         
                            angHa                           
                             ang                            
                              a                             
                              Y                             
>>> #字符串的索引号表达式也可以修改:str[(表达式)&len(str)]
print('\n'.join([''.join([('HannYang'[x%8-2] if 0.003*x*x+(0.075*y-pow(0.0015*x*x,1/3))**2-0.6>=0 else' ') for x in range(-30,30)]) for y in range(16,-12,-1)]))
HannYangHannYangHannYangHannYangHannYangHannYangHannYangHann
HannYangHannYangHannYangHannYangHannYangHannYangHannYangHann
HannYangHannYangHan       nnYangHan       nnYangHannYangHann
HannYangHannYangHa          YangH          nYangHannYangHann
HannYangHannYangH            ang            YangHannYangHann
HannYangHannYangH             n             YangHannYangHann
HannYangHannYang                             angHannYangHann
HannYangHannYang                             angHannYangHann
HannYangHannYang                             angHannYangHann
HannYangHannYangH                           YangHannYangHann
HannYangHannYangH                           YangHannYangHann
HannYangHannYangH                           YangHannYangHann
HannYangHannYangHa                         nYangHannYangHann
HannYangHannYangHa                         nYangHannYangHann
HannYangHannYangHan                       nnYangHannYangHann
HannYangHannYangHann                     annYangHannYangHann
HannYangHannYangHann                     annYangHannYangHann
HannYangHannYangHannY                   HannYangHannYangHann
HannYangHannYangHannYa                 gHannYangHannYangHann
HannYangHannYangHannYan               ngHannYangHannYangHann
HannYangHannYangHannYang             angHannYangHannYangHann
HannYangHannYangHannYangH           YangHannYangHannYangHann
HannYangHannYangHannYangHa         nYangHannYangHannYangHann
HannYangHannYangHannYangHann     annYangHannYangHannYangHann
HannYangHannYangHannYangHannY   HannYangHannYangHannYangHann
HannYangHannYangHannYangHannYa gHannYangHannYangHannYangHann
HannYangHannYangHannYangHannYa gHannYangHannYangHannYangHann
HannYangHannYangHannYangHannYangHannYangHannYangHannYangHann
>>> 


探究四:字符串换成中文汉字

需要把 else 后的填充空格换成2个半角空格或1个全角空格

>>> print('\n'.join([''.join([('我爱杨程'[(x-y)%4-3] if((x*0.08)**2+(y*0.1)**2-1)**3-(x*0.08)**2*(y*0.1)**3<=0 else ' ') for x in range(-20,20)]) for y in range(13,-12,-1)]))
                                        
           我爱杨程我爱       爱杨程我爱杨          
         程我爱杨程我爱杨程我   我爱杨程我爱杨程我爱        
        程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程       
       程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱      
       我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨      
      我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我     
      爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱     
      杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨     
      程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程     
       爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程      
       杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我      
       程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱      
        爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱       
         程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱        
         我爱杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨        
          杨程我爱杨程我爱杨程我爱杨程我爱杨程我爱杨         
           我爱杨程我爱杨程我爱杨程我爱杨程我爱杨          
             程我爱杨程我爱杨程我爱杨程我爱            
              爱杨程我爱杨程我爱杨程我爱             
                我爱杨程我爱杨程我               
                  程我爱杨程                 
                   爱杨程                  
                    程                   
                                        
>>> 

如此,掌握了原理,就去网上找各种方程式来创作你自己的图形吧!大胆去向心爱的人表白吧!!

目录
打赏
0
0
0
0
74
分享
相关文章
Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器是那些静悄悄的幕后英雄。它们不张扬,却能默默地为函数或类增添强大的功能。本文将带你了解装饰器的魅力所在,从基础概念到实际应用,我们一步步揭开装饰器的神秘面纱。准备好了吗?让我们开始这段简洁而富有启发性的旅程吧!
58 6
实战指南:通过1688开放平台API获取商品详情数据(附Python代码及避坑指南)
1688作为国内最大的B2B供应链平台,其API为企业提供合法合规的JSON数据源,直接获取批发价、SKU库存等核心数据。相比爬虫方案,官方API避免了反爬严格、数据缺失和法律风险等问题。企业接入1688商品API需完成资质认证、创建应用、签名机制解析及调用接口四步。应用场景包括智能采购系统、供应商评估模型和跨境选品分析。提供高频问题解决方案及安全合规实践,确保数据安全与合法使用。立即访问1688开放平台,解锁B2B数据宝藏!
【Azure Developer】编写Python SDK代码实现从China Azure中VM Disk中创建磁盘快照Snapshot
本文介绍如何使用Python SDK为中国区微软云(China Azure)中的虚拟机磁盘创建快照。通过Azure Python SDK的Snapshot Class,指定`location`和`creation_data`参数,使用`Copy`选项从现有磁盘创建快照。代码示例展示了如何配置Default Azure Credential,并设置特定于中国区Azure的`base_url`和`credential_scopes`。参考资料包括官方文档和相关API说明。
|
1月前
|
Python高性能编程:五种核心优化技术的原理与Python代码
Python在高性能应用场景中常因执行速度不及C、C++等编译型语言而受质疑,但通过合理利用标准库的优化特性,如`__slots__`机制、列表推导式、`@lru_cache`装饰器和生成器等,可以显著提升代码效率。本文详细介绍了这些实用的性能优化技术,帮助开发者在不牺牲代码质量的前提下提高程序性能。实验数据表明,这些优化方法能在内存使用和计算效率方面带来显著改进,适用于大规模数据处理、递归计算等场景。
71 5
Python高性能编程:五种核心优化技术的原理与Python代码
|
2月前
|
课程设计项目之基于Python实现围棋游戏代码
游戏进去默认为九路玩法,当然也可以选择十三路或是十九路玩法 使用pycharam打开项目,pip安装模块并引用,然后运行即可, 代码每行都有详细的注释,可以做课程设计或者毕业设计项目参考
83 33
【Azure Developer】Python代码调用Graph API将外部用户添加到组,结果无效,也无错误信息
根据Graph API文档,在单个请求中将多个成员添加到组时,Python代码示例中的`members@odata.bind`被错误写为`members@odata_bind`,导致用户未成功添加。
56 10
以下是一些常用的图表类型及其Python代码示例,使用Matplotlib和Seaborn库。
通过这些思维导图和分析说明表,您可以更直观地理解和选择适合的数据可视化图表类型,帮助更有效地展示和分析数据。
112 8
|
2月前
|
【Azure Developer】分享一段Python代码调用Graph API创建用户的示例
分享一段Python代码调用Graph API创建用户的示例
73 11
探索Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器就像是给函数穿上了一件神奇的外套,让它们拥有了超能力。本文将通过浅显易懂的语言和生动的比喻,带你了解装饰器的基本概念、使用方法以及它们如何让你的代码变得更加简洁高效。让我们一起揭开装饰器的神秘面纱,看看它是如何在不改变函数核心逻辑的情况下,为函数增添新功能的吧!
深入理解Python装饰器:提升代码重用与可读性
本文旨在为中高级Python开发者提供一份关于装饰器的深度解析。通过探讨装饰器的基本原理、类型以及在实际项目中的应用案例,帮助读者更好地理解并运用这一强大的语言特性。不同于常规摘要,本文将以一个实际的软件开发场景引入,逐步揭示装饰器如何优化代码结构,提高开发效率和代码质量。
79 6

热门文章

最新文章