1. 引言 在编程界,每个人都希望自己可以写出世界上最好的代码,其实最好的代码往往需要具备最好的代码质量。勤能补拙,善于总结往往可以快速提升大家的编程技巧。
本文重点对日常中不常使用的四个Python技巧进行简明阐述,希望可以提升大家编码时的工作效率。
闲话少说,我们直接开始吧!
2. 获取 n 个最大数字 我们知道,要获得列表中的最大数字,我们往往使用max
函数,如下:
max([15, 21, 30, 20])
# ouput: 30
但是如果我们将其进行扩展,获取n个最大数字的列表呢?学过数据结构的同学,也许能想到来构建大顶堆数据结构,嗯嗯,在Python中有一个名为
heapq
的模块,可以非常方便的来实现上述功能。如下所示:import heapqheap = [10, 5, 18, 1, 100]# heapq.nlargest(n, iterable)
n_largest_numbers = heapq.nlargest(3, heap)# show result
print(n_largest_numbers)
结果输出如下:
[100, 18, 10]
3. 获取 n 个最小数字 正如我们对
max
函数了解的一样,我们可以知道min
函数的作用:min([15, 21, 30, 20])
# ouput: 15
大家知道数据结构中通过构建大顶堆可以方便的求出n个最大数字,所以我们也可以通过小顶堆来获取n个最小数字,举例如下:
import heapqheap = [10, 5, 18, 1, 100, 8, 7]# heapq.nsmallest(n, iterable)
n_smallest_numbers = heapq.nsmallest(4, heap)# show result
print(n_smallest_numbers)
输出如下:
[1, 5, 7, 8]
4. 删除字符串的特定部分 假设我们有字符串
+-+-+Python
,如果此时我们只需要获取上述字符串中的部分即Python
,此时我们可以使用python字符串模块中的removeprefix
函数,示例如下:
myString = "+-+-+Python"new_string = myString.removeprefix("+-+-+")# show result
print(new_string)
输出如下:
Python
5. 从列表中删除重复元素 为了实现从列表中删除重复元素,也许我们知道可以通过集合进行转换,如下:
li = [10, 15, 10, 10, 5, 5]without_duplicates = list(set(li))print(without_duplicates)
输出如下:
[10, 5, 15]
但是上述实现并不是非常专业的实现,因为输出结果没有按原先次序输出,所以让我向大家展示第二种方式:
li = [10, 15, 10, 10, 5, 5]without_duplicates = dict.fromkeys(li)print(list(without_duplicates))
输出如下:
[10, 15, 5]
6. 总结 【Python|Python中四个不常见的小技巧】python中的一些技巧可以帮助我们编写更高效的代码。本文中我们介绍了四个小技巧可以帮助我们做一些了不起的事情。最后希望大家可以喜欢我写的简单的小文章,并确保可以学到新的东西。
嗯捏,您学废了嘛?
文章图片
推荐阅读
- Python|在Python中寻找数据异常值的三种方法
- #|pandas的简单使用(数据统计)
- Python|【Python】使用一行代码实现均值,中位数和众数
- 深度学习|Jupyter Notebook(Anaconda)——两个环境分别修改默认打开目录(深度学习第一周番外篇)
- #|深度学习之 11 空洞卷积的实现
- 神经网络与深度学习|【神经网络与深度学习】CIFAR10数据集介绍,并使用卷积神经网络训练图像分类模型——[附完整训练代码]
- 人工智能|21个项目玩转深度学习(基于TensorFlow的实践详解02—CIFAR10图像识别)
- python|CIFAR-10 图像识别
- tensorflow2.0|Tensorflow 2 实战(kears)- CIFAR10自定义网络、模型加载与保存实战