列表

概念:Python内置的一种数据类型是列表:list。list是一种有序的集合,可以随时添加和删除其中的元素。

列表的使用

names = ['zhangsan','lisi','wangwu','zhaoliu'] //定义一个了列表

print(names) //输出列表的所有内容
print(names[0]) //输出列表的第0个内容
//用索引来访问list中每一个位置的元素,记得索引是从0开始的。

输出结果:

如果要取最后一个元素,除了计算索引位置外,还可以用-1做索引,直接获取最后一个元素:

names = ['zhangsan','lisi','wangwu','zhaoliu','vector']
print(names[-1])

输出结果:

len()函数可以获得list元素的个数。

names = ['zhangsan','lisi','wangwu','zhaoliu','yangzirui']
print(len(names))

输出结果:

当索引超出了范围时,Python会报一个IndexError错误,所以,要确保索引不要越界,记得最后一个元素的索引还可以是len(classmates) - 1

切片

如果想取出中间一段连续的元素,则用name[1:3]的方式,这个参数是左闭右开的。也就是说从第1位取到第2位。

names = ['zhangsan','lisi','wangwu','zhaoliu']
print(names[1:3])# 切片

输出结果:

跳着切片

names = ['zhangsan','lisi','wangwu','zhaoliu']
print(names[0:-1:2]) # 从第0个到倒数第2个, 每两个元素取一个

输出结果:

倒着切片

names = ['zhangsan','lisi','wangwu','zhaoliu','vector','zhaoliu']
print(names[-3,-1]) # 这也是左闭右开的,表示从倒数第三个切到倒数第二个
# 如果想切到倒数第一个, 就这样写 name[-3:] 这样就表示从倒数第三个切到最后一个了

输出结果:

追加元素

如果想在列表的最后面追加一个元素, 就用函数append('元素')。

names = ['zhangsan','lisi','wangwu','zhaoliu','vector','zhaoliu']
names.append('sunqi')
print(names)

输出结果:

插入元素

插在任意元素的前面, 用函数insert(2,'元素')。

names = ['zhangsan','lisi','wangwu','zhaoliu','vector','zhaoliu']
names.insert(1,'yangsan') # 插在下标为1的元素的前面
print(names)

输出结果:

修改元素

names = ['zhangsan','lisi','wangwu','zhaoliu','vector','zhaoliu']
names[2] = 'shenmegui'
print(names)

输出结果:

删除元素的三种方法

names = ['zhangsan','lisi','wangwu','zhaoliu']
names.remove('shenmegui') # 根据内容删除
del names[2] # 根据下标删除
names.pop(2) # 如果输入下标,则效果=del names[2], 如果不输入下标,则默认删除最后一个元素

根据元素内容找到元素的下标

names = ['zhangsan','lisi','wangwu','zhaoliu','vector','zhaoliu']
print(names.index('zhangsan')) //利用index函数将下标取出来
# 还有一种方式是在循环的时候取出下标
for i in enumerate(names):
print(i) # 这样取的时候就会有下标
# 但是如果我想把下标分离出来, 该怎么处理
for index,i in enumerate(names):
print(index,i) # 这样index里面就装了分离出来的下标

计算某个元素的个数

names = ['zhangsan','lisi','zhangsan','zhaoliu','vector','zhaoliu']
print(names.count('zhangsan'))

输出结果:

清空列表

names = ['zhangsan','lisi','zhangsan','zhaoliu','vector','zhaoliu']
names.clear()

翻转列表

names = ['zhangsan','lisi','zhangsan','zhaoliu','vector','zhaoliu']
names.reverse()
print(names)

输出结果:

排序

规则是按照ASCII码表的顺序排的。

names = ['zhangsan','lisi','zhangsan','zhaoliu','vector','zhaoliu']
names.sort()
print(names)

输出结果:

追加合并

names = ['zhangsan','lisi','zhangsan','zhaoliu','vector','zhaoliu']
names2 = [1,2,3,4]
names.extend(names2)
print(names)

输出结果:

浅拷贝列表

这个第一维时是深拷贝,第二维开始是浅拷贝。

names = ['zhangsan','lisi','wangwu','zhaoliu']
names3 = names.copy() // 第一种方式
p1 = names[:]      // 第二种方式
p2 = list(names)    // 第三种方式

深拷贝  需要引入copy模块

names = ['zhangsan','lisi','zhangsan','zhaoliu','vector','zhaoliu']
import copy
names2 = copy.copy(names)

循环列表

names = ['zhangsan','lisi','zhangsan','zhaoliu','vector','zhaoliu']
for i in names:
print(i)

输出结果:

判断一个元素是否在列表里

names = ['zhangsan','lisi','zhangsan','zhaoliu','vector','zhaoliu']
if 'zhangsan' in names:
print('存在')

输出结果:

元组

元组就是只能查数据的列表。

定义格式:

names = ('zhangsan','lisi')

  它只有两个方法, count 和 index。

Python学习之路2 - 列表和元组的更多相关文章

  1. python学习4—数据结构之列表、元组与字典

    python学习4—数据结构之列表.元组与字典 列表(list)深灰魔法 1. 连续索引 li = [1,1,[1,["asdsa",4]]] li[2][1][1][0] 2. ...

  2. Python学习三---序列、列表、元组

    一.序列 1.1.序列概念 pythn中最基本的数据结构是序列(sequence). 序列中每个元素被分配一个序号-元素索引,第一个索引是0,第二个是1,以此类推.类似JAVA中数组和集合中的下标. ...

  3. python学习笔记之一:列表与元组

    最近在看<python基础教程>(基于python2.x),下面总结一下第二章列表与元组的知识: 在这章中引入了数据结构的概念.数据结构是通过某种方式组织在一起的数据元素的集合.在pyth ...

  4. 【python学习笔记】2.列表和元组

    # 第二章:列表和元组   序列中,每个元素都有个一个序号,序号以0开始,最后一个元素序号为-1,倒数第二个-2 序列类型包括,列表,元组,字符串,unicode字符串,buffer, xrange ...

  5. python学习(二) 列表和元组

    第2章  列表和元组 2.1 序列概论 python有六种内建的序列,本章讨论最常用的两种类型:列表和元组.其他的内建序列有字符串.Unicode字符串.buffer对象和xragne对象. 列表和元 ...

  6. Python学习(四)—— 列表和元组的类中方法

    列表 list:用中括号括起来,用“,”分割每个元素,列表中的元素可以是 数字.字符串.列表.布尔值......所有东西,可以说就是一个“集合” li = [1,3,5,'alex','age',[' ...

  7. python学习之路04——列表和字典

    列表和字典 python中的可变数据类型有:列表和字典 不可变类型:数字,字符串,元组 今天先讲列表和字典 一.列表 1.概念: 变量:使用变量存储数据,但是,变量存储数据每次只能存储一个数据 问题: ...

  8. Python学习笔记 (3) :列表、元组的操作

    列表,即写在方括号之间.用逗号分隔开的数值列表.列表内的项目不必全是相同的类型. >>> a = ['spam', 'eggs', 100, 1234] >>> a ...

  9. python学习小总结(列表、元组、字典、集合、字符串)

    ---恢复内容开始--- 一.列表(list) 1.添加 append():追加,在列表末尾添加元素. 列表名.append(添加的元素) extend():扩展,在列表末尾添加元素. 列表名.ext ...

随机推荐

  1. 【Spark】源码分析之RDD的生成及stage的切分

    一.概述 Spark源码整体的逻辑(spark1.3.1): 从saveAsTextFile()方法入手 -->saveAsTextFile()  --> saveAsHadoopFile ...

  2. linux 编译安装pureFTP

    安装openssl支持 wget -c https://www.openssl.org/source/openssl.org/source/openssl-1.1.0c.tar.gz tar -zxv ...

  3. 大数据&人工智能&云计算

    仅从技术上讲大数据.人工智能都包含工程.算法两方面内容: 一.大数据: 工程: 1)云计算,核心是怎么管理大量的计算机.存储.网络. 2)核心是如何管理数据:代表是分布式存储,HDFS 3)核心是如何 ...

  4. ECharts使用过程遇到的问题汇总

    获取ECharts npm install echarts --save 自定义构建ECharts 我选用的是常用版的echarts/dist/echarts.common.js 在我的项目根目录下m ...

  5. Maximum sum

    描述 Given a set of n integers: A={a1, a2,-, an}, we define a function d(A) as below: t1 t2 d(A) = max ...

  6. windows 设置tomcat为自动启动服务

    1.下载免安装tomcat包,解压 2.配置环境变量: 点击新建,创建一个 变量名为:CATALINA_HOME 变量值为:tomcat解压文件的位置, 例如     F:\apache-tomcat ...

  7. 北京Uber优步司机奖励政策(1月27日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  8. Python:numpy中的tile函数

    在学习机器学习实教程时,实现KNN算法的代码中用到了numpy的tile函数,因此对该函数进行了一番学习: tile函数位于python模块 numpy.lib.shape_base中,他的功能是重复 ...

  9. VINS(八)初始化

    首先通过imu预积分陀螺仪和视觉特征匹配分解Fundamental矩阵获取rotationMatrix之间的约束关系,联立方程组可以求得外参旋转矩阵: 接下来会检测当前frame_count是否达到W ...

  10. Javascript闭包例子

    闭包的概念 内层的函数可以引用存在于包围它的函数内的变量,即使外层函数的执行已经终止.可理解为,闭包就是能够读取其他函数内部变量的函数. 表现形式是:定义在函数内部的函数. function f1() ...