1. 列表

  • 数据结构:以某种方式(如通过编号)组合起来的元素(如数,字符乃至其他数据结构)集合。
  • 在python中,最基本的数据结构为序列。序列中的每个元素都有编号,即其位置或索引,其中第一个元素的索引为0,第二个元素的索引为1,以此类推。
  • 偏移量:相对于序列开头的偏移量

1.1 序列

  • 容器(container):可包含其他对象的对象
  • 主要的容器:序列(列表和元组(索引)),映射(字典(键))和集合。

1.2 通用的序列操作

  • 索引
a = [1, 3, 5, 7]
print(a[1]) # 打印3
  • 切片
a = [1, 3, 5, 7, 9, 11, 13]
print(a[1:3]) # [3,5]
print(a[-3:-1]) # [9, 11]
print(a[:3]) # [1, 3 , 5]
print(a[4:]) # [9, 11, 13]
print(a[:]) # [1, 3, 5, 7, 9, 11, 13]
print(a[1:6:2]) # [3, 7, 11],指定步长
print(a[5:1:-1]) # [11, 9, 7],注意开始索引大于结束索引
  • 序列相加
print([1, 2, 3] + [4, 5, 6])  # [1, 2, 3, 4, 5, 6]
  • 乘法
print([1] * 5)  # [1, 1, 1, 1, 1]
print([none] * 5) # 创建指定长度空列表
  • 成员资格

要检查特定的值是否包含在序列内,可使用运算符in,返回布尔值。

name = 'zhaojun'
print('zh' in name) # True
hobby_list = ['sing', 'dancing', 'rap', 'basketball', 'music']
print('run' in hobby_list) # False
  • 长度、最大值、最小值
nums = [1, 3, 5, 2, 4]
print(len(nums)) # 5
print(max(nums)) # 5
print(min(nums)) # 1

1.3 列表的基本操作

  • 修改列表:给元素赋值
nums = [1, 2, 3]
x[1] = 5
print(x) # [1, 5, 3]
  • 删除元素
nums = [1, 2, 3]
del nums[2]
print(nums) # [1, 2]
  • 给切片赋值
nums = [1, 2, 3, 4, 5, 6, 7]
nums[:3] = [0, 0, 0]
print(nums) # [0, 0, 0, 4, 5, 6, 7] # 赋值是将整段插入切片位置,不考虑数量
nums = [1, 2, 3, 4, 5, 6, 7]
nums[1:3] = [0, 0, 0, 0]
print(nums) # [1, 0, 0, 0, 0, 4, 5, 6, 7]

1.4 列表方法

  • append(就地修改):将一个对象加到列表末尾。
nums = [1, 2, 3, 4]
nums.append(5)
print(nums) # [1, 2, 3, 4, 5]
  • clear:就地清空列表内容。
nums = [1, 2, 3, 4]
nums.clear()
print(nums) # [] 返回空列表 # 用切片赋值实现
nums1 = [1, 2, 3, 4]
nums1[:] = []
print[nums1] # []
  • copy:复制列表
nums = [1, 2, 3, 4]
nums1 = nums.copy()
print(nums1)
print(id(nums))
print(id(nums1))
nums.append(5)
print(nums)
print(nums1) """
执行结果为:
[1, 2, 3, 4]
2193656132360
2193656116168
[1, 2, 3, 4, 5]
[1, 2, 3, 4]
"""
  • count:计算指定的元素在列表中出现了多少次。
nums = [1, 2, 2, 3, 4, 4]
print(nums.count(2)) # 2
  • entend:将多个值附加到列表末尾(扩展列表)
a = [1, 2, 3]
b = [4, 5, 6]
a.entend(b)
print(a) # [1, 2, 3, 4, 5, 6]
  • index:在列表中查找指定值第一次出现的索引。如果搜不到,就会引发异常,ValueError。
a = ['a', 'b', 'c', 'd']
print(a.index('b')) # 1
  • insert:将一个对象插入列表。
nums = [1, 2, 3, 4, 5]
nums.insert(3, '6')
print(nums) # [1, 2, 3, '6', 4, 5]
  • pop:从列表中删除一个元素(末尾为最后一个元素),并返回这一元素。

    使用pop可实现一种常见的数据结构———栈(stack),后进先出(LIFO)。

    push和pop是大家普遍接受的两种栈操作(加入和取走)的名称。python没有提供,但可用append代替。

    要创建先进先出(FIFO)的队列,可使用insert(0, ...)代替append,也可继续使用append但弹出用pop(0)。

x = [1, 2, 3]
a = x.pop()
print(a) # 3
print(x) # [1, 2]
b = x.pop(0)
print(b) # 1
print(x) # [2]
  • remove:删除第一个为指定值的元素(就地修改不返回值)。
x = ['to', 'be', 'or', 'not', 'to', 'be']
x.remove('be')
print(x) # ['to', 'or', 'not', 'to', 'be']
  • reverse:按相反的顺序排列列表中的元素。

    如果要按相反的顺序迭代序列,可使用函数reversed,这个函数不返回列表,而是返回一个迭代器。

x = [1, 2, 3]
x.reverse()
print(x) # [3, 2, 1]
  • sort:对列表就地排序。

    sorted函数:对列表排序,返回排序后列表,原列表不变。

a = [1, 3, 5, 2, 4]
a.sort()
print(a) # [1, 2, 3, 4, 5] b = [1, 3, 5, 2, 4]
c = sorted(b)
print(b) # [1, 3, 5, 2, 4]
print(c) # [1, 2, 3, 4, 5]

Python基础之列表内置方法的更多相关文章

  1. python基础之反射内置方法元类

    补充内置函数 isinstance(obj,Foo)   # 判断obj是不是foo的实例 issubclass()      # 判断一个类是不是另一个类的子类 反射 什么是反射? 通过字符串来操作 ...

  2. Python基础之字典内置方法

    目录 1. 字典 1.1 字典的作用 1.2 创建和使用字典 1.2.1 dict类 1.2.2 基本的字典操作 1.2.3 字典方法 1. 字典 映射:可以通过名称来访问其各个值的数据结构. 字典是 ...

  3. 06 python初学 (列表内置方法)

    目录: type(a) is list :判断 a 是不是列表.返回 True False count:计算列表内某一元素出现的次数 extend:在列表末尾一次性添加另一列表中的全部值 index: ...

  4. python中的列表内置方法小结

    #!/usr/local/bin/python3 # -*- coding:utf-8 -*- ''' names=['zhangyu','mahongyan','zhangguobin','shac ...

  5. for循环,数字、字符串和列表内置方法

    目录 控制流程之for循环 基本语法 for+break for+continue for+else for循环打印lodaing 数字类型内置方法 整型 int 浮点型 float 字符串内置方法 ...

  6. Python 数据类型常用的内置方法(三)

    目录 Python 数据类型常用的内置方法(三) 1.列表内置方法 1.sort():升序 2.reverse():颠倒顺序 3.列表比较运算 2.字典内置方法 1.对Key的操作 2.len( )- ...

  7. Python 数据类型常用的内置方法(二)

    目录 Python 数据类型常用的内置方法(二) 1.字符串类型常用内置方法 1.upper.lower.isupper.islower 2.startswith.endswith 3.format ...

  8. Python 数据类型常用的内置方法(一)

    目录 Python 数据类型常用的内置方法 1.整型 int 2.浮点型 float 字符串转浮点型: 3.字符串 str 多种类型转字符型: 索引 切片 len( )方法:统计字符串长度/个数 移除 ...

  9. python今日分享(内置方法)

    目录 一.习题详解 二.数据类型的内置方法理论 三.整型相关操作 四.浮点型相关操作 五.字符串相关操作 六.列表相关操作 今日详解 一.习题详解 1.计算1-100所有数据之和 all_num = ...

随机推荐

  1. 【二食堂】Alpha- 发布声明

    MarkTexting Alpha版本发布声明 今日我们的MarkTexting正式上线了! 功能介绍 我们实现了一个简单的文本标注生成知识图谱的网站,在Alpha阶段,我们实现的功能有: 登陆注册 ...

  2. 单片机stm32的5个时钟源的详细分析

    众所周知STM32有5个时钟源HSI.HSE.LSI.LSE.PLL,其实他只有四个,因为从上图中可以看到PLL都是由HSI或HSE提供的. 其中,高速时钟(HSE和HSI)提供给芯片主体的主时钟.低 ...

  3. 文件上传漏洞Bypass总结

    文件上传漏洞Bypass总结 前端JS验证文件类型: 上传后缀jpg,抓包改为php后缀 ======================================================= ...

  4. Luogu P1654 OSU! | 期望

    题目链接 很妙的一道题. 题目要求$X^3$的期望值. 直接求不好求. 考虑先求出$X$和$X^2$的期望值,然后再求$X^3$的期望值. 迎.刃.而.解. #include<iostream& ...

  5. 地表最强IDE ——Visual Studio 2022正式发布

    地表最强IDE--Visual Studio 2022昨天正式发布啦! 堪称宇宙第一IDE工具集的Visual Studio,在经过不断更新优化之后,新版本就要与大家见面了.本次新版本发布,有许多令人 ...

  6. K8S发布策略,无损发布

    大家好,相信大部分公司都已经使用K8S进行容器管理和编排了,但是关于K8S的发布策略,还有很多同学不太清楚,通过这篇文章的介绍,相信大家对目前K8S的发布情况有一个概括的认识.总结下来,共有如下几种: ...

  7. Part 35 AngularJS caseInsensitiveMatch and Inline Templates

    In this video we will discuss 2 simple but useful features in Angular caseInsensitiveMatch Inline Te ...

  8. NOIP模拟99(多校31)

    T1 法阵 解题思路 原题3100,张口放 T1(出题人原话) 思维题,合法的情况其实就是上下两个梯形拼起来的样子. 他们的边界都是在 \(i\) 轴上面,但是不能相交. 于是我们可以尝试两者相交的纵 ...

  9. 如何设计一个高内聚低耦合的模块——MegEngine 中自定义 Op 系统的实践经验

    作者:褚超群 | 旷视科技 MegEngine 架构师 背景介绍 在算法研究的过程中,算法同学们可能经常会尝试定义各种新的神经网络层(neural network layer),比如 Layer No ...

  10. .NET GC 实时监控 dotnet-gcmon 介绍

    今天介绍一个新的诊断工具 dotnet-gcmon, 也是全局 .NET CLI 工具, 它可以监控到 .NET 程序的 GC, 能获取到的信息也很详细, 另外 maoni 大佬也是其中的开发者之一. ...