python语言中tup的意思_Python:更改tup中的值

好吧,正如Trufa已经展示的,在给定的索引处替换元组元素的方法基本上有两种。要么将元组转换为列表,替换元素并转换回,要么通过连接构造一个新元组。In [1]: def replace_at_index1(tup, ix, val):

...: lst = list(tup)

...: lst[ix] = val

...: return tuple(lst)

...:

In [2]: def replace_at_index2(tup, ix, val):

...: return tup[:ix] + (val,) + tup[ix+1:]

...:

那么,哪种方法更好,也就是说,更快?

事实证明,对于短元组(在Python3.3上),连接实际上更快!In [3]: d = tuple(range(10))

In [4]: %timeit replace_at_index1(d, 5, 99)

1000000 loops, best of 3: 872 ns per loop

In [5]: %timeit replace_at_index2(d, 5, 99)

1000000 loops, best of 3: 642 ns per loop

然而,如果我们看较长的元组,列表转换是一种方法:In [6]: k = tuple(range(1000))

In [7]: %timeit replace_at_index1(k, 500, 99)

100000 loops, best of 3: 9.08 µs per loop

In [8]: %timeit replace_at_index2(k, 500, 99)

100000 loops, best of 3: 10.1 µs per loop

对于非常长的元组,列表转换实际上更好!In [9]: m = tuple(range(1000000))

In [10]: %timeit replace_at_index1(m, 500000, 99)

10 loops, best of 3: 26.6 ms per loop

In [11]: %timeit replace_at_index2(m, 500000, 99)

10 loops, best of 3: 35.9 ms per loop

此外,连接方法的性能取决于替换元素的索引。对于list方法,索引是不相关的。In [12]: %timeit replace_at_index1(m, 900000, 99)

10 loops, best of 3: 26.6 ms per loop

In [13]: %timeit replace_at_index2(m, 900000, 99)

10 loops, best of 3: 49.2 ms per loop

所以:如果元组很短,则切片并连接。

如果是长的,做列表转换!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值