Python切片

本文深入探讨了线性结构的基础概念及应用,包括如何通过索引和切片访问和操作线性结构中的数据。介绍了Python中常见的线性结构类型如list、tuple、str等,并提供了丰富的实例说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线性结构

    可迭代for … in
    len()可以获取长度
    通过下标可以访问
    可以切片
学过的线性结构

在内存中是一串连续的内存空间,list,tuple,str,bytes,bytearray
tuple小巧,只读
  • str和bytes和bytearray之间做操作
切片

通过索引区间访问线性结构的一段数据
    sequence[start:stop]表示返回[start,stop]区间的子序列
    支持负索引
    start为0,可以省略
    stop为末尾,可以省略
    超过上界(右边界),就取到末尾;超过下界(左边界),取到开头
    start一定要在stop的左边

[:]表示从头至尾,全部元素被取出,等效于copy()方法

切片举例:

'wwww.baidu.com'[4:10]
'.baidu'
'wwww.baidu.com'[4:]
'.baidu.com'
'wwww.baidu.com'[:]
'wwww.baidu.com'
'wwww.baidu.com'[:-1]
'wwww.baidu.co'
'wwww.baidu.com'[4:-4]
'.baidu'
'wwww.baidu.com'[4:50]
'.baidu.com'
b'wwww.baidu.com'[-40:10]
b'wwww.baidu'
bytearray(b'wwww.baidu.com')[-4:10]
bytearray(b'')
tuple('wwww.baidu.com')[-10:10]
('.', 'b', 'a', 'i', 'd', 'u')
list('wwww.baidu.com')[-10:-4]
['.', 'b', 'a', 'i', 'd', 'u']
步长切片:

    [start:stop:step]
    step为步长,可以正、负整数,默认是1
    step要和start:stop同向,否则返回空序列

步长举例:
'wwww.baidu.com'[4:10:2]
'.ad'
list('wwww.baidu.com')[4:10:-2]
[]
tuple('wwww.baidu.com')[-10:-4:2]
('.', 'a', 'd')
b'wwww.baidu.com'[-4:-10:2]
b''
bytearray(b'wwww.baidu.com')[-4:-10:-2]
bytearray(b'.da')
'wwww.baidu.com'[::-1] 从start到stop倒着走
'moc.udiab.wwww'
### Python 切片使用方法 #### 基础语法 Python切片功能允许通过指定起始索引、结束索引以及步长来获取序列中的子集。基本语法如下: ```python sequence[start:end:step] ``` - `start` 表示开始的位置,默认为 0。 - `end` 表示结束的位置(不包括该位置),默认为序列长度。 - `step` 是间隔数,默认为 1。 当只提供单个参数时,表示从该位置到序列末尾;两个参数则定义了一个范围[^1]。 #### 字符串切片实例 对于字符串而言,可以轻松提取特定部分的内容: ```python text = "hello world" substring = text[0:5] # 提取出 'hello' print(substring) ``` 此代码片段展示了如何利用正向索引来选取前五个字符组成的子串[^2]。 #### 插入元素至列表中某处 值得注意的是,除了用于读取数据外,还可以借助切片的方式修改现有结构内的项目。例如,在给定位置批量插入多个新项: ```python my_list = ["a", "b", "d"] my_list[2:2] = ["c"] # 在第三个位置之前加入 'c' ,即 my_list 变成 ['a', 'b', 'c', 'd'] print(my_list) ``` 这里采用 `[n:n]` 形式的切片作为目标区域,并赋值一个新的可迭代对象实现插入操作。 #### 步长的应用——逆序遍历与筛选奇偶数 设置负数作为 step 参数能够改变方向,从而支持倒叙访问元素。另外,配合 start 和 end 控制边界条件,可用于高效过滤出符合条件的数据点,比如仅保留数组里的奇数位成员: ```python numbers = [0, 1, 2, 3, 4, 5, 6] odd_numbers = numbers[1::2] # 获取所有奇数索引对应的值 [1, 3, 5] reversed_text = "abcdefg"[::-1] # 将整个字符串反转得到 'gfedcba' print(odd_numbers) print(reversed_text) ``` 上述例子分别演示了基于固定增量抽取子列和完全翻转原始顺序两种情况下的应用方式[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值