1、序列的概念

序列sequence是Python中最基本的数据结构。指的是一块可存放多个值的连续内存空间,这些值按一定顺序排列,可通过每个值所在位置的编号(称为索引)访问它们。

为了更形象的认识序列,可以将它看做是一家旅店,那么店中的每个房间就如同序列存储数据的一个个内存空间,每个房间所特有的房间号就相当于索引值。也就是说,通过房间号(索引)我们可以找到这家旅店(序列)中的每个房间(内存空间)。

在Python中,常用的序列类型包括字符串列表元组集合字典

提示:

之前我们说Python中不可变数据类型的时候,已经介绍过字符串的一些基础用法,忘记的可以查看前面的文章。

下面我们说说字符串的更高级一些的用法。

2、字符串的下标说明

(1)下标的概念

“下标”又叫“索引”,就是编号。比如火车的座位号,座位号的作用:按照编号快速找到对应的座位。同理,下标的作用即是通过下标快速找到数据中对应位置的字符。

所以字符串实际上就是字符的数组,如果想使用字符串中某个特定的数据,那么可以通过下标的方法取得。换句话说字符串数据的下标从0开始顺序分配一个编号,使用这个编号精确找到某个字符数据。

注意:下标从0开始,向后递增。

(2)快速体验

需求:字符串name = "abcdef",取到不同下标对应的数据。

  1. name = "abcdef"
  2. # 下标得到的是下标为某个数字所对应的数据
  3. print(name[1])
  4. print(name[0])
  5. print(name[2])
  6. """
  7. 输出结果
  8. b
  9. a
  10. c
  11. """

(3)字符串取值的两种方式

在Python的字符串取值中,有两种取值方式,即正负取值。

  • 正向下标从0开始,下标值依次递增。
  • 负向下标从-1开始,下标值依次递减。

如下图所示:

练习:

  1. name = "abcdef"
  2. print(name[-1])
  3. print(name[-4])
  4. print(name[-2])
  5. """
  6. 输出结果
  7. f
  8. c
  9. e
  10. """

3、字符串的切片说明

切片是指对操作的对象截取其中一部分的操作。字符串、列表、元组都支持切片操作。

(1)切片的语法

  1. 序列[开始位置下标:结束位置下标:步长]

注意:

  • 不包含结束位置下标对应的数据(截取的规则为“前闭后开”), 正负整数均可。
  • 步长表示,每次获取元素的间隔,默认步长为1。(可省略不写)

    步长正负整数均可,不能是0,设置0会直接异常。
  • 做切片操作时,总会返回一个新的列表(字符串,元祖),不会影响原来的列表(字符串,元祖)。
  • 一般创建列表时,变量的名字会使用复数。(我们直接输出,就不定义变量名了)

(2)示例

  1. # 序列名[开始位置的下标:结束位置的下标:步长]
  2. # 我定义的一个字符串就是从0开始的数字
  3. # 对应着字符串的脚标,方便我们直观的查看结果。
  4. str1 = '012345678'
  5. # 1.规范截取,可观察前闭后开
  6. print(str1[2:5:1]) # 234
  7. # 2.验证步长,为隔几个字符曲一次值
  8. print(str1[2:5:2]) # 24
  9. # 3.可以不写步长,默认为1
  10. print(str1[2:5]) # 234
  11. # 4.如果不写开始,默认从0开始选取
  12. print(str1[:5]) # 01234
  13. # 5.如果不写结束,表示从某位置开始,选取到最后。
  14. print(str1[2:]) # 2345678
  15. # 6.如果不写开始和结束,表示选取所有。
  16. # 其实相当于创建了一个字符串的副本
  17. print(str1[:]) # 012345678
  18. # 负数测试
  19. # 1.如果步长为负数,表示倒叙选取
  20. print(str1[::-1]) # 876543210
  21. # 2.下标-1表示最后一个数据,下标数值向前依次递减。
  22. # 如下:从倒数第4位到倒数第1位,正向截取,前闭后开。
  23. print(str1[-4:-1]) # 567
  24. """
  25. 3.终极测试
  26. 从倒数第4位到倒数第1位,从左向右,
  27. 正向截取,前闭后开。
  28. 但是-1步长:是从右向左选取。
  29. 两个选取方向相反,所以不能选取出数据
  30. """
  31. print(str1[-4:-1:-1]) # 没有结果
  32. # 如下修改,从最后1位截取到倒数第4位
  33. # 方向是从后向前,也就是从右到左,
  34. # 步长-1的方向,也是从从右到左。
  35. # 所以可以取到值。
  36. print(str1[-1:-4:-1]) # 876
  37. """
  38. 重点:****
  39. 如果选取方向(下标开始到结束的方向) 和
  40. 步长的方向冲突,
  41. 则无法选取数据。
  42. """

总结:

这种语法很有用,因为你经常需要在不知道列表长度的情况下访问最后的元素。这种约定也适用于其他负数索引,例如,索引-2返回倒数第二个列表元素,索引-3返回倒数第三个列表元素,以此类推 。

(3)补充示例

  1. # 1.做切片操作时,总会返回一个新的列表,不会影响原来的列表。
  2. stus = ['孙悟空','猪八戒','沙和尚','唐僧','蜘蛛精','白骨精']
  3. new_stus = stus[0 :3]
  4. print(stus)
  5. print(new_stus)
  6. """
  7. 输出结果:
  8. ['孙悟空', '猪八戒', '沙和尚', '唐僧', '蜘蛛精', '白骨精']
  9. ['孙悟空', '猪八戒', '沙和尚']
  10. """
  11. # 步长不能设置为0
  12. # 结果:ValueError: slice step cannot be zero
  13. print(stus[0 :3 : 0]) # 异常

『无为则无心』Python基础 — 16、Python序列之字符串的下标和切片的更多相关文章

  1. 『无为则无心』Python基础 — 4、Python代码常用调试工具

    目录 1.Python的交互模式 2.IDLE工具使用说明 3.Sublime3工具的安装与配置 (1)Sublime3的安装 (2)Sublime3的配置 4.使用Sublime编写并调试Pytho ...

  2. 『无为则无心』Python基础 — 8、Python中的数据类型(数值、布尔、字符串)

    目录 1.数据类型介绍 2.数值型(Number) 3.布尔型(bool) 4.None(空值) 5.常量 6.字符串(String) 1.数据类型介绍 (1)什么是数据类型 在生活中,我们日常使用的 ...

  3. 『无为则无心』Python基础 — 12、Python运算符详细介绍

    目录 1.表达式介绍 2.运算符 (1)运算符的分类 (2)算数运算符 (3)赋值运算符 (4)复合赋值运算符 (5)比较运算符 3.逻辑运算符 拓展1:数字之间的逻辑运算 拓展2:Python中逻辑 ...

  4. 『无为则无心』Python基础 — 6、Python的注释

    目录 1.注释的作用 2.注释的分类 单行注释 多行注释 3.注释的注意事项 4.什么时候需要使用注释 5.总结 提示:完成了前面的准备工作,之后的文章开始介绍Python的基本语法了. Python ...

  5. 『无为则无心』Python基础 — 7、Python的变量

    目录 1.变量的定义 2.Python变量说明 3.Python中定义变量 (1)定义语法 (2)标识符定义规则 (3)内置关键字 (4)标识符命名习惯 4.使用变量 1.变量的定义 程序中,数据都是 ...

  6. 『无为则无心』Python基础 — 10、Python字符串的格式化输出

    目录 1.什么是格式化输出 2.Python格式化输出的五种方式 方式一:字符串之间用+号拼接 方式二:print()函数可同时输出多个字符串 方式三:占位符方式 方式四:f格式化方式(推荐) 方式五 ...

  7. 『无为则无心』Python基础 — 61、Python中的迭代器

    目录 1.迭代的概念 2.迭代器的概念 3.可迭代的对象(Iterable) 4.迭代器对象(Iterator) 5.迭代器的使用体验 (1)基本用法 (2)实际应用 1.迭代的概念 (1)什么是迭代 ...

  8. 『无为则无心』Python序列 — 24、Python序列的推导式

    目录 1.列表推导式 (1)快速体验 (2)带if的列表推导式 (3)多个for循环实现列表推导式 2.字典推导式 (1)创建一个字典 (2)将两个列表合并为一个字典 (3)提取字典中目标数据 3.集 ...

  9. 『无为则无心』Python序列 — 17、Python字符串操作常用API

    目录 1.字符串的查找 @1.find()方法 @2.index()方法 @3.rfind()和rindex()方法 @4.count()方法 2.字符串的修改 @1.replace()方法 @2.s ...

随机推荐

  1. ES6对象的新增方法的使用

    Object.assign Object Object.assign(target, ...sources) 将所有可枚举属性的值从一个或多个源对象复制到目标对象 参数: target 目标对象 so ...

  2. 【转载】geany linux python编译器 开源

    http://www.dekiru.cn/?p=1491 Geany 不好用,建议用一些好用的编辑器或ide Subliem Text 或 VS code Pycharm等. 设置运行环境 菜单栏–生 ...

  3. Spec2006使用说明

    Spec2006使用说明 五 10 十月 2014 By penglee 工具介绍 SPEC CPU 2006 benchmark是SPEC新一代的行业标准化的CPU测试基准套件.重点测试系统的处理器 ...

  4. win10家庭版升级 到win10企业版

    成功升级3小时  20200124 拿到电脑 win10家庭版 不会用 找admin都找不到只能用企业版 升级win10家庭版 到win10企业版 在msdn下载win10企业版iso iso 文件管 ...

  5. 学完了这篇JVM,面试官真拿我没办法了!

    在我们面试中经常会遇到面试官问一些有关JVM的问题,下面我大概从运行时数据域.类加载机制.类加载器.垃圾收集器.垃圾收集算法.JVM堆内存模型.JVM内存结构.JVM调优等几个方面来讲一下JVM. 一 ...

  6. 企业微信三种token

    http://www.upwqy.com/doc/28.html 基本配置介绍 区分三种类型access_token 服务商的token 说明:以corpid(服务商CorpID).provider_ ...

  7. Hashing散列注意事项

    Hashing散列注意事项 Numba支持内置功能hash(),只需__hash__()在提供的参数上调用成员函数即可 .这使得添加对新类型的哈希支持变得微不足道,这是因为扩展APIoverload_ ...

  8. 基于Linux的TCP网络聊天室

    1.实验项目名称:基于Linux的TCP网络聊天室 2.实验目的:通过TCP完成多用户群聊和私聊功能. 3.实验过程: 通过socket建立用户连接并传送用户输入的信息,分别来写客户端和服务器端,利用 ...

  9. pytest基础简介及实践举例

    一.pytest简介 pytest 是 python 的第三方单元测试框架,比自带的 unittest 更简洁和高效,同时兼容 unittest 框架.它还有如下优点: 1.简单灵活,容易上手,文档丰 ...

  10. 如果攻击者操控了 redirect_uri,会怎样?

    读者在看这篇文章之前,请先了解 Oauth2.0 的 Authorization Code 授权流程,可以看 Authorization Code 授权原理和实现方法 在 Token Enpoint ...