一、定义列表

1.names = ['mike','mark','candice','laular'] #定义列表

2.num_list = list(range(1,10)) #range生成1-10范围内的数,并强制转化成列表

二、增:append()、insert()方法

1.append()方法:在末尾添加元素

#szz = ['ab','jhj','nhy']

#szz.append('msr')

#szz打印结果:['ab', 'jhj', 'nhy', 'msr']

2.insert()方法:在指定位置添加元素或者列表

#szz = ['ab','jhj','nhy']

#szz1 = ['msr','mike']

#szz.insert(0,'mark') #szz打印结果['mark', 'ab', 'jhj', 'nhy']

#szz.insert(0,szz1) #szz打印结果[['msr', 'mike'], 'ab', 'jhj', 'nhy']

三、删:del、pop()、remove()、clear()

1.del:可以删除指定下标的值

#del szz[1] #删除下标为1的值

2.pop()方法: #默认从列表的末尾删除,也可以删除指定的值

#szz.pop() #默认删除末尾的值

#szz.pop(1) #删除下标为1的值

3.remove()方法:删除指定的值

#szz =[['msr', 'mike'], 'ab', 'jhj', 'nhy']

#szz.remove('jhj') #在原list中的可以直接删除

#szz[0].remove('mike') #在另一个list里的需要定位到list才能删除,szz.remove('mike')这种方法是不能正确执行的,会报错ValueError: list.remove(x): x not in list

4.clear()方法:清空数据

#szz.clear() #清空列表数据,如果有嵌套list也直接清空,无需定位到嵌套的list再清空

四、改:

1.通过定位到下标直接修改

#['mark', 'ab', 'jhj', 'nhy']

#szz[1] = 'zzj'

#print(szz) #打印结果:['mark', 'zzj', 'jhj', 'nhy']

五、查:查询列表可通过下标和切片的方式

1.下标取值,从0开始

#names = ['mike','mark','candice','laular'] #定义列表

#print(names[2]) #读取列表的值

#num_list = list(range(1,10)) #range生成一个长度为10的列表

#print(num_list) #打印结果:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

2.切片:顾头不顾尾,且切片下标的操作同样用于字符串

#names = ['mike','mark','candice','laular']

#info = 'abcdefghijklmn'

#num_list = list(range(1,10))

#print(names[1:3]) #通过切片方式取值,切片是顾头不顾尾,打印结果:['mark', 'candice']

#print(names[1:]) #取下标后面所有的值,打印结果:['mark', 'candice', 'laular']

#print(names[:3]) #取下标前面所有的值,打印结果:['mike', 'mark', 'candice']

#print(names[:]) #取所有的值,打印结果:['mike', 'mark', 'candice', 'laular']

#print(names[-1]) #取最后一个值,打印结果:laular

#print(names[:1:2])#隔几位取一次,默认不写步长为1,即隔一位取一次;结果为取下标为1之前的值,隔2位取一个['mike']

#print(num_list[::-1])#从后往前取值,步长为1,打印结果:['laular', 'candice', 'mark', 'mike']

#print(info[1:7]) #打印结果:bcdefg

六、列表其他方法:

1.index()方法:获取指定元素的下标

#szz.index('jhj')

2.count()方法:获取指定元素的次数

#szz.count('mike')

3.extend()方法:合并列表,修改原列表的值,只能合并到原列表的末尾

#szz = ['ab','jhj','nhy']

#szz1 = ['msr','mike']

#szz.extend(szz1) #打印结果:['ab', 'jhj', 'nhy', 'msr', 'mike']

4.sort()方法:进行排序,默认是升序,想要降序排序需要加:reverse=True ,reverse返转的意思

#sort本身只是一个方法,没有返回值,所以不能打印

#numbs = [12,425,334,32]

#numbs.sort()

#print numbs #打印结果:[12, 32, 334, 425]

#numbs.sort(reverse=True)

#print numbs #打印结果:[425, 334, 32, 12]

七、insert和extend的区别:

1.insert可以指定插入元素的位置,extend不能指定,只能合并到末尾

2.insert是在原列表的基础上增加元素,什么都可以加(列表、字符串……),extend只能合并2个列表,对列表进行扩展,不能添加字符串

八、元祖

1.元组的值,不能改变,是一个不可便的列表,可以通过访问下标和切片的方式查询,但是想要修改必须先转成list

#tup1 = ('physics', 'chemistry', 1997, 2000)  #定义元祖
#print tup1[1]   #打印结果:chemistry
#tup1[0] = 100   #这种修改方式是非法的
#tup2=list(tup1) #想要修改元祖,必须先将其转换成list才可以
#print tup2      #打印结果:['physics', 'chemistry', 1997, 2000]
#tup2[2] = '1989'
#print tup2           #打印结果:['physics', 'chemistry', 1989, 2000]
2.元祖只有count和index方法

names = ('mike','mark','candice','laular','mark','msr')

print(names.count('mark')) #打印结果:2

print(names.index('msr')) #打印结果:5

Python列表的增删改查和元祖的更多相关文章

  1. Python列表的增删改查排嵌套特殊输出格式

    Python列表的增删改查排嵌套特殊输出格式 一.列表的样子: a = ['q' , 'w' , 'e ', 'r','t'] a为列表名,[ ]为列表内容,' '为列表内的元素,'q'为a[0] 二 ...

  2. python列表的增删改查和嵌套

    列表 python常用的数据类型 可承载任意的数据类型 列表是有序的,可索引.切片(步长) 列表的创建 list1 = [1, 2, 'whll'] #1. list2 = list() #2. #3 ...

  3. Python列表的增删改查

    列表的增: li = ['libai','sushi','dufu','sushi',"白居易"] 第一种: append():向列表末尾追加元素 li.append('diaoc ...

  4. python 列表(增删改查)

    列表 :(列表可以嵌套,列表的中的元素可以为任意) 列表的创建:1.   a = [1, 2, 3] 2.   a = list([1, 2, 3]) 1.查: 索引(下标),都是从0开始 切片 .c ...

  5. python 列表的增删改查

    列表 有序可变的,索引 作用:存储数据的,支持很多种数据类型 定义方式: lst = [1,"alex",True,('a','b')]增 append() # 追加 extend ...

  6. day04 列表增删改查、元祖以及range

    01 课前小甜点 千万不要随意做决定 只要你做了决定,你要坚持下去. 02 昨日内容回顾 int <---> bool : 非0 True 0 False True 1 False 0 i ...

  7. python列表的增删改查用法

    列表,元组 查 索引(下标) ,都是从0开始 切片 .count 查某个元素的出现次数 .index 根据内容找其对应的位置 "haidilao ge" in a 增加 a.app ...

  8. Python(二)列表的增删改查

    一,列表的增删改查 列表中增加元素: 1,从列表的末尾增加一个元素:append("") 2,从列表中插入一个元素:insert(下标位置,插入的元素) 合并列表: 1,name. ...

  9. day5 列表的增删改查

    1,列表的增删改查,其他操作.2,元祖.3,列表的嵌套操作.4,开一点dict. 昨日内容回顾: 字符串的方法:1,find通过元素找索引,可切片,找不到返回-12,index,找不到报错.3,spl ...

随机推荐

  1. [java] 软工实践WordCount-Plus

    整体思路 模块化 对于任何一个小模块,例如:输入.输出.计算都独立开来,降低耦合. 插件化 对于任何一个模块均作成插件,可拔插,可更换,而不会导致其他的插件出现故障. 事件驱动 使用观察者模式,用事件 ...

  2. Linux常用命令——关机重启命令

    Linux常用命令--关机重启命令 Linux  shutdown 语法:shutdown [选项] 时间 -c 取消前一个关机命令 -h 关机 -r 重启 示例:shutdown -r now 其它 ...

  3. ZJOI2019游记

    Day-2 本蒟蒻有幸能去参加ZJOI2019,然而出发前就做好了爆0的准备. 坐了差不多6,7个小时的车,车上基本就是在颓知乎和打雀,然后就到了酒店. 招宝山酒店--本人住过的第一个四星级酒店,看上 ...

  4. Java 的 clone 方法 && 浅复制和深复制

    1 Java中对象的创建过程 java创建对象的方式有以下两种: (1)使用new操作符创建一个对象 (2)使用clone的方法复制一个对象,(在Java中,clone是Object类的protect ...

  5. AI外包 人工智能外包 长年承接人工智能项目 北京动点软件

    人工智能artificial intelligence,AI是科技研究中最热门的方向之一.像 IBM.谷歌.微软.Facebook  和亚马逊等公司都在研发上投入大量的资金.或者收购那些在机器学习.神 ...

  6. Jmeter接口测试实例

    此文章作为工作中用到的jmeter接口测试相关内容简述,方便日后查阅参考,如有理解描述有误之处,欢迎指出. 首先Jmeter环境准备网上有很多教程,在此不多做赘述: 1.接口简述 接口可理解为从客户端 ...

  7. 报错:keep must be either "first", "last" or False

    data_mac_set = data_mac.drop_duplicates(['std_mac']) 此时会报错:keep must be either "first", &q ...

  8. OpenGL.Tutorial15_Lightmaps

    ZC:撤销 & 重做 — Blender Manual.html(https://docs.blender.org/manual/zh-hans/dev/interface/undo_redo ...

  9. 从零开始,搭建 AI 音箱 Alexa 语音服务

    https://blog.csdn.net/gitchat/article/details/78869367

  10. Activity与Fragment数据传递之Fragment从Activity获取数据

    整理Fragment与Activity之间的数据交换,大体上包括三种: 1.Fragment从Activity获取数据 2.Activity从Fragment获取数据 3.Fragment之间获取数据 ...