百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

干净、可读的 Python 代码的提示和技巧

ztj100 2024-12-17 17:46 34 浏览 0 评论

从装饰器到列表推导式,这些内置的 Python 功能可帮助开发人员将笨拙的代码转换为干净、可读的解决方案,而无需重新发明轮子。

学习编码是一个陡峭的攀登过程。学习的一面包括学习如何编码,另一面包括如何优雅地进行编码。对我来说,这是最困难的部分。我可以蛮力和笨拙地解决很多问题,但是当涉及到编写一个优雅的解决方案时,不,谢谢,我每次都会使用嵌套循环。但当然,这不起作用,原因有几个,因为代码应该是 DRY (Don't Repeat Yourself) 的,内存友好,并且其他人可以阅读。但 Google 是我的朋友,我慢慢发现了一些工具,这些工具可以帮助我以更简单的方式将更优雅的解决方案组合在一起,而无需重新发明轮子。以下是一些 Python 的内置帮助程序,它们有助于提高代码的可读性和易用性。

*args 和 **kwargs

*args 和 **kwargs 有助于使函数广泛使用。使用 *args 作为 functions 参数允许函数采用任意数量的参数。如果没有 *args,则必须考虑 integer 和 string 参数。

使用 *args:

没有它只会引发一个错误......

**kwargs 具有与 *args 类似的功能,但对键值对执行此操作。**kwargs 可用于没有所需数字或键值对数量未知的函数。

def dictionary_builder(**kwargs):
    for x,y in kwargs.items():
        print(f'key: {x}, value: {y}')

dictionary_builder(topic = 'Python')
dictionary_builder(city = 'Brooklyn', state = 'New York')
dictionary_builder(month = 'March', day = 1, year = 2024)

# key: topic, value: Python
# key: city, value: Brooklyn
# key: state, value: New York
# key: month, value: March
# key: day, value: 1
# key: year, value: 2024

表推导式

列表推导式允许开发人员仅使用一行创建列表。如果不使用列表推导式,您可以使用以下代码构建数字列表:

numbers = []

for i in range (1, 5):
    numbers.append(i)

列表推导式将该代码转换为单行代码。基本语法是:

[expression for item in iterable] 。在简单的代码中,它看起来像这样:

numbers= [i for i in range(5)]

列表推导式还可以包括筛选功能。

even_numbers = [i for i in range(1,5) if i % 2 == 0]
print(even_numbers) # [2, 4]

列表并不是您可以以这种方式创建的唯一数据结构。我们可以创建一个字典并使用相同的创建模式进行设置。字典的基本语法是:

{key_expression: value_expression for item in iterable}

我们可以将数字列表中的每个数字乘以 10 到 by_tens 字典中。

numbers = [1, 2, 3, 4, 5]
by_tens = {num: num*10 for num in numbers}
print(by_tens) #{1: 10, 2: 20, 3: 30, 4: 40, 5: 50}

我们也可以用 set 来做到这一点。基本语法是

{expression for item in iterable} 。代码如下所示:

numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
even_set = {num for num in numbers if num % 2 == 0}
print(even_set)# {2, 4, 6, 8, 10}

zip()

zip() 允许您同时迭代多个列表并创建相应元素的元组。zip() 将本来可能是多行迭代的内容缩短为一行代码。

zip() 迭代最小列表的长度。如果给定列表的长度不同,则 Tuples 的长度将仅与最小的列表一样长。 下面的代码清楚地说明了上述两点:

pets = ["dog", "cat", "horse", "fish", "turtle"]
names = ["Maxie", "Spot", "Dusty", "Swift", "Speedy"]
ages = [7, 4, 1, 12]
 
# Create a zipped object combining the pets, names, and ages lists
result = zip(pets, names, ages)
 
# Print the zipped object
print("Zipped result as a list:")
for i in list(result):
  print(i)
  
# Zipped result as a list:
# ('dog', 'Maxie', 7)
# ('cat', 'Spot', 4)
# ('horse', 'Dusty', 1)
# ('fish', 'Swift', 12)

合并词典

你可以使用 update() 功能或字典解包语法 (**) 合并字典。

land_pets = {'dog': 'Maxie', 'cat': 'Spot', 'horse': 'Dusty' }
water_pets = {'fish': 'Swift', 'turtle': 'Speedy'}
all_pets = {**land_pets, **water_pets}

print(all_pets)

#{'dog': 'Maxie', 'cat': 'Spot', 'horse': 'Dusty', 'fish': 'Swift', 'turtle': 'Speedy'}

或者你可以使用 update 函数将 water_pets 对象添加到 land_pets 对象:land_pets.update(water_pets)。

链接比较运算符

链接比较运算符允许您将多个比较合并到一个表达式中。链接消除了对显式 and' 运算符的需求。它有助于提高代码的可读性和性能,因为它减少了单独比较的数量。

以下示例比较变量 miles 以确定距离是否在范围内。代码如下所示,没有链接比较运算符:

def distance_checker(miles):
    if miles > 0 and miles <10:
        print("in range")
    else:
        print("out of range")

distance_checker(3)

# in range

当比较表示为复合条件时,它如下所示:

def distance_checker(miles):
    if  0 < miles <10:
        print("in range")
    else:
        print("out of range")

distance_checker(13)

# out of range

三元运算符

三元运算符允许开发人员在一行中编写 if 条件。基本语法是:

result = true_value if condition else false_value

如果条件的计算结果为 True,则表达式返回 true 值。如果条件的计算结果为 False,则表达式返回 false 值。下面是一个没有 turnery 运算符的示例:

x = 5

if x % 2 == 0:
    result = "even"   
else:
    result = "odd"

print(result)

#odd

与带有三元运算符的 if 条件相比:

x = 5

result = "even" if x % 2 == 0 else "odd"
print(result)

装饰

装饰器在不更改源代码的情况下修改函数。装饰器是一个新函数,它将原始函数作为参数,使用新函数对其进行修改,然后返回具有更新功能的函数。

让我们从一个基本的除法函数开始。

def division(x,y):
    print(x/y)

除法(10,5) 打印 2

除法(9,3) 打印 3

对于此示例,我们假设此函数始终需要将较大的数字除以较小的数字。编辑源代码不理想的原因有很多,在这些情况下,装饰器会派上用场。如果你熟悉 closures,这看起来很熟悉。对于那些不熟悉的人来说,装饰器是一个构建、修改和返回函数的函数。装饰器的 shell 将如下所示:


#decorator function definition, function passed in as an argument
def decorated_division(func):

    #inner function where the modifications will take place, has the same arguments as the function it's modifying
    def inner(a,b):

    #return the inner function   
    return inner


在内部函数中,我们将检查参数的顺序是否正确,如果不正确,则进行必要的交换(另一个 Python 技巧)。

def decorated_division(func):

    def inner(a,b):
        if a < b:
            a,b = b,a
            
        return func(a,b)

    return inner


内部函数的外观和行为与任何基本函数一样。

现在有几种不同的方法可以使用 decorator 函数来修改 division 函数。第一种方法是使用 @decorator,它看起来像这样:

@decorated_division
def division(x,y):
    print(x/y)
    
division(5, 10)

# 2

另一种方法是将函数分配为变量:

new_division = decorated_division(division)
new_division(5,10) 

# 2

祝您编码愉快!

这些技巧肯定会将代码从基本提升到优雅。您使用 Python 的次数越多,它就越容易。

相关推荐

sharding-jdbc实现`分库分表`与`读写分离`

一、前言本文将基于以下环境整合...

三分钟了解mysql中主键、外键、非空、唯一、默认约束是什么

在数据库中,数据表是数据库中最重要、最基本的操作对象,是数据存储的基本单位。数据表被定义为列的集合,数据在表中是按照行和列的格式来存储的。每一行代表一条唯一的记录,每一列代表记录中的一个域。...

MySQL8行级锁_mysql如何加行级锁

MySQL8行级锁版本:8.0.34基本概念...

mysql使用小技巧_mysql使用入门

1、MySQL中有许多很实用的函数,好好利用它们可以省去很多时间:group_concat()将取到的值用逗号连接,可以这么用:selectgroup_concat(distinctid)fr...

MySQL/MariaDB中如何支持全部的Unicode?

永远不要在MySQL中使用utf8,并且始终使用utf8mb4。utf8mb4介绍MySQL/MariaDB中,utf8字符集并不是对Unicode的真正实现,即不是真正的UTF-8编码,因...

聊聊 MySQL Server 可执行注释,你懂了吗?

前言MySQLServer当前支持如下3种注释风格:...

MySQL系列-源码编译安装(v5.7.34)

一、系统环境要求...

MySQL的锁就锁住我啦!与腾讯大佬的技术交谈,是我小看它了

对酒当歌,人生几何!朝朝暮暮,唯有己脱。苦苦寻觅找工作之间,殊不知今日之事乃我心之痛,难道是我不配拥有工作嘛。自面试后他所谓的等待都过去一段时日,可惜在下京东上的小金库都要见低啦。每每想到不由心中一...

MySQL字符问题_mysql中字符串的位置

中文写入乱码问题:我输入的中文编码是urf8的,建的库是urf8的,但是插入mysql总是乱码,一堆"???????????????????????"我用的是ibatis,终于找到原因了,我是这么解决...

深圳尚学堂:mysql基本sql语句大全(三)

数据开发-经典1.按姓氏笔画排序:Select*FromTableNameOrderByCustomerNameCollateChinese_PRC_Stroke_ci_as//从少...

MySQL进行行级锁的?一会next-key锁,一会间隙锁,一会记录锁?

大家好,是不是很多人都对MySQL加行级锁的规则搞的迷迷糊糊,一会是next-key锁,一会是间隙锁,一会又是记录锁。坦白说,确实还挺复杂的,但是好在我找点了点规律,也知道如何如何用命令分析加...

一文讲清怎么利用Python Django实现Excel数据表的导入导出功能

摘要:Python作为一门简单易学且功能强大的编程语言,广受程序员、数据分析师和AI工程师的青睐。本文系统讲解了如何使用Python的Django框架结合openpyxl库实现Excel...

用DataX实现两个MySQL实例间的数据同步

DataXDataX使用Java实现。如果可以实现数据库实例之间准实时的...

MySQL数据库知识_mysql数据库基础知识

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

如何为MySQL中的JSON字段设置索引

背景MySQL在2015年中发布的5.7.8版本中首次引入了JSON数据类型。自此,它成了一种逃离严格列定义的方式,可以存储各种形状和大小的JSON文档,例如审计日志、配置信息、第三方数据包、用户自定...

取消回复欢迎 发表评论: