python的索引和切片

一、索引和切片介绍


字符串可以定义为字符的有序集合,我们可以通过其位置获得他们的元素。在python中,字符串中的字符是通过索引提取的。

  • python偏移量是从0开始的,这样就会比字符串的长度len()小1。
  • 大家比较熟悉字符串的正偏移,python中还可以使用负偏移,可以看着是从结束处反向计数。
  • 关于偏移和分片的网格四意图如图,便于理解:

个人觉得这个图解比较好,大部分人的图解都是直接把偏移量0直接指向了第一个元素。



二、代码举例讲解

举例1:索引(S[i])获取特定偏移的元素

S = 'abcdefg'
print(S[0],S[-1])
#('a', 'g')

 

  • 第一个元素的偏移量是0
  • 负偏移索引意味着从最后或者右边反向进行计数
  • S[0]获取了第一个元素
  • S[-1]获取了倒数第一个元素,效果等同于S[len(S)-1]

举例2:分片(S[i:j])提取对应的步伐作为一个序列

S = 'abcdefg'
print(S[1:3])
#'bc'
print(S[1:])
#'bcdefg'
print(S[:-1])
#'abcdef'

 

  • 上边界并不包含在内
  • 分片的边界默认为0和序列的长度,如果没有特别给出的话
  • S[1:3]获取了从偏移为1的元素,到但是不包含偏移为3的元素
  • S[1:]或者了从偏移1直到末尾直接的元素
  • S[:3]获取了从偏移0直到但是不包括3之间的元素=S[0:3]
  • S[:-1]获取了从偏移量0直到但是不包含最后一个元素之间的
  • S[:]获取了所有的元素,可以实现顶层S的拷贝



三、扩展分片:第三个限制值S[I:J:K]


直接代码举例进行说明

print(S[1:5:2])
# 'bd'
print(S[::2])
# 'aceg'
print(S[::-1])
# 'gfedcba'
print(S[5:1:-1])
# 'fedc'

 

  • S[I:J:K]代表“偏移从X到J-1,每隔K元素索引一次”
  • 第三个限制K,默认为1
  • S[1:5:2]取偏移1到4之间的元素,间隔1个元素的元素,也就是偏移1、3之处的元素
  • S[::2]从序列头取到尾,每隔一个元素的元素,也可以用负数作为步进,步进-1代表从右向左进行。
  • S[::-1]实际效果就是将序列进行反转(这是一个有用的技巧)
  • S[5:1:-1]反转的顺序获取2到5的元素(偏移5、4、3、2的元素)
     

from我的简书:https://www.jianshu.com/p/d3839175eaf4

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值