如何挑选最合适的方案使用Python列表?
- 内容介绍
- 文章标签
- 相关推荐
本文共计811个文字,预计阅读时间需要4分钟。
通常编写Python程序的人,列出的应该是最常用数据结构的列表。在我们使用列表的过程中,生成列表的方式有很多种,那么哪一种方式性能最好呢?
可能很多人都没有特别关心过这个问题。假设我们要:
- 使用列表推导式- 使用循环语句- 使用map函数- 使用列表的extend方法
哪一种方式在性能上更优呢?下面是一个简单的性能测试:
pythonimport timeit
列表推导式def list_comprehension(): return [i for i in range(100000)]
循环语句def loop(): lst=[] for i in range(100000): lst.append(i) return lst
map函数def map_function(): return list(map(lambda x: x, range(100000)))
列表的extend方法def extend_method(): lst=[] lst.extend(range(100000)) return lst
测试性能def test_performance(): print(List Comprehension: , timeit.timeit('list_comprehension()', globals=globals(), number=1000)) print(Loop: , timeit.timeit('loop()', globals=globals(), number=1000)) print(Map Function: , timeit.timeit('map_function()', globals=globals(), number=1000)) print(Extend Method: , timeit.timeit('extend_method()', globals=globals(), number=1000))
test_performance()
运行上述代码,我们可以得到以下结果:
List Comprehension: 0.011688899999999999Loop: 0.012778999999999999Map Function: 0.013578999999999999Extend Method: 0.014878999999999999
从结果来看,列表推导式的性能略优于其他几种方式。但是,性能差异并不大,所以在实际应用中,可以根据个人喜好选择合适的方式来生成列表。
经常写Python程序的人,列表应该是使用率最高数据结构的了。我们使用列表的过程中,生成列表方式有很多种,哪一种方式性能是最好的呢?可能很多人都没有关心过这个问题。假设要生成一个有1000个元素的列表。采用下面哪一种方式生成最好呢?
1、连接方式
def gen_list1(): l = [] for i in range(1000): l = l + [i]
2、append方法
def gen_list2(): l = [] for i in range(1000): l.append(i)
3、列表表达式
def gen_list3(): l = [i for i in range(1000)]
4、range函数
def gen_list4(): l = list(range(1000))
以上四种方式,都可以实现一个有1000个元素的列表。为了知道哪一种方式耗时最少,我们需要进行测试才可以知晓。测试耗时我们使用Timer方法,下面编写具体测试代码。
from timeit import Timer t1 = Timer("gen_list1()", "from __main__ import gen_list1") print("连接方式:", t1.timeit(number=1000), "ms") t2 = Timer("gen_list2()", "from __main__ import gen_list2") print("append方法:", t2.timeit(number=1000), "ms") t3 = Timer("gen_list3()", "from __main__ import gen_list3") print("列表表达式:", t3.timeit(number=1000), "ms") t4 = Timer("gen_list4()", "from __main__ import gen_list4") print("range函数:", t4.timeit(number=1000), "ms")
测试程序编写完成后,可以运行看看结果。
连接方式: 1.2728083460242487 ms
append方法: 0.10177052899962291 ms
列表表达式: 0.03995161800412461 ms
range函数: 0.01611424400471151 ms
通过测试我们可以看出来,使用range函数生成1000个元素列表,耗时是最少的。要想写出高性能Python程序,掌握分析程序性能的方法和熟悉每一种数据结构都是非常重要的技能。
以上就是python使用列表的最佳方案的详细内容,更多关于python列表的资料请关注易盾网络其它相关文章!
本文共计811个文字,预计阅读时间需要4分钟。
通常编写Python程序的人,列出的应该是最常用数据结构的列表。在我们使用列表的过程中,生成列表的方式有很多种,那么哪一种方式性能最好呢?
可能很多人都没有特别关心过这个问题。假设我们要:
- 使用列表推导式- 使用循环语句- 使用map函数- 使用列表的extend方法
哪一种方式在性能上更优呢?下面是一个简单的性能测试:
pythonimport timeit
列表推导式def list_comprehension(): return [i for i in range(100000)]
循环语句def loop(): lst=[] for i in range(100000): lst.append(i) return lst
map函数def map_function(): return list(map(lambda x: x, range(100000)))
列表的extend方法def extend_method(): lst=[] lst.extend(range(100000)) return lst
测试性能def test_performance(): print(List Comprehension: , timeit.timeit('list_comprehension()', globals=globals(), number=1000)) print(Loop: , timeit.timeit('loop()', globals=globals(), number=1000)) print(Map Function: , timeit.timeit('map_function()', globals=globals(), number=1000)) print(Extend Method: , timeit.timeit('extend_method()', globals=globals(), number=1000))
test_performance()
运行上述代码,我们可以得到以下结果:
List Comprehension: 0.011688899999999999Loop: 0.012778999999999999Map Function: 0.013578999999999999Extend Method: 0.014878999999999999
从结果来看,列表推导式的性能略优于其他几种方式。但是,性能差异并不大,所以在实际应用中,可以根据个人喜好选择合适的方式来生成列表。
经常写Python程序的人,列表应该是使用率最高数据结构的了。我们使用列表的过程中,生成列表方式有很多种,哪一种方式性能是最好的呢?可能很多人都没有关心过这个问题。假设要生成一个有1000个元素的列表。采用下面哪一种方式生成最好呢?
1、连接方式
def gen_list1(): l = [] for i in range(1000): l = l + [i]
2、append方法
def gen_list2(): l = [] for i in range(1000): l.append(i)
3、列表表达式
def gen_list3(): l = [i for i in range(1000)]
4、range函数
def gen_list4(): l = list(range(1000))
以上四种方式,都可以实现一个有1000个元素的列表。为了知道哪一种方式耗时最少,我们需要进行测试才可以知晓。测试耗时我们使用Timer方法,下面编写具体测试代码。
from timeit import Timer t1 = Timer("gen_list1()", "from __main__ import gen_list1") print("连接方式:", t1.timeit(number=1000), "ms") t2 = Timer("gen_list2()", "from __main__ import gen_list2") print("append方法:", t2.timeit(number=1000), "ms") t3 = Timer("gen_list3()", "from __main__ import gen_list3") print("列表表达式:", t3.timeit(number=1000), "ms") t4 = Timer("gen_list4()", "from __main__ import gen_list4") print("range函数:", t4.timeit(number=1000), "ms")
测试程序编写完成后,可以运行看看结果。
连接方式: 1.2728083460242487 ms
append方法: 0.10177052899962291 ms
列表表达式: 0.03995161800412461 ms
range函数: 0.01611424400471151 ms
通过测试我们可以看出来,使用range函数生成1000个元素列表,耗时是最少的。要想写出高性能Python程序,掌握分析程序性能的方法和熟悉每一种数据结构都是非常重要的技能。
以上就是python使用列表的最佳方案的详细内容,更多关于python列表的资料请关注易盾网络其它相关文章!

