一.列表

1. 列表:

列表的创建:li = [],列表中可以放置字符串,元组,列表,字典,列表等各种数据类型,32位的Python可以存放2^32个数据

2. 列表的索引和切片

列表的索引:格式lst = [元素,元素....元素]  print(lst[index])index是对应列表中元素的下标,切记index从0开始;

代码展示:

 lst = ["周杰伦", "王力宏", "周润发","成龙","李连杰"]
lst[1] = "周星驰"
print(lst)
#输出 ["周杰伦", "周星驰", "周润发","成龙","李连杰"] #这里赋值的变量可以为其他类型变量,列表,元组,字典都可以
lst = ["周杰伦", "王力宏", "周润发","成龙","李连杰"]
lst[1] = 1
print(lst)
#输出 ["周杰伦", 1, "周润发","成龙","李连杰"]

list列表赋值

列表的切片:和字符串一样,格式为[起始位置:结束位置:步长默认为1时]

代码展示:

 lst = ["马化腾","王江林","太白", "五色", "银王", "日天"]
lst[1:3] = "马化腾" # 迭代修改(深坑请留意)
print(lst)
#输出结果:['马化腾', '马', '化', '腾', '五色', '银王', '日天'] lst = ["马化腾","王江林","太白", "五色", "银王", "日天"]
lst[1:3] = ["马化腾"] # 这里马化腾才会整体添加到列表中
print(lst)
#输出结果:['马化腾', '马化腾', '五色', '银王', '日天']

列表切片修改

列表的切片:[]步长不为1时

代码展示:

 lst = ["马化腾","王江林","太白", "五色", "银王", "日天"]
lst[::2] = ["周杰伦", "他媳妇"] # 这里是两个元素
print(lst)
#输出结果:
lst[::2] = ["周杰伦", "他媳妇"] # 迭代修改
ValueError: attempt to assign sequence of size 2 to extended slice of size 3
报错:因为你步长截取了三个元素,而你替换的只有两个元素,所以会报错! lst = ["马化腾","王江林","太白", "五色", "银王", "日天"]
lst[::2] = ["周杰伦", "他媳妇", "王力宏媳妇"] # 这里是三个元素
print(lst)
#输出结果:['周杰伦', '王江林', '他媳妇', '五色', '王力宏媳妇', '日天']
所以不管你替换的什么,替换的元素个数跟步长截取的个数一致!
例如:lst[::2] = 112,222,333
st[::2] = "sdt"
st[::2] = "fkd","fd","d"
st[::2] = 1,2,3
st[::2] = None.None,None

步长不为1修改列表

3. 列表的其他操作

lst.sort()排序,默认时候升序,一般对数字好使,lst.sort(reverse = True)降序

lst.reverse()将列表翻转.

c = len(lst)列表的长度

4.列表的增删改查

增:

和字符串不一样,lst是可以发生改变的,所以直接在原来的对象上进行了操作

lst.append("元素")注意这里是自动添加到最后一位的;

lst.insert(index."元素")在index的位置添加元素,原来的元素向后移动一位;

lst.extend(元素)这里面元素可以是列表,元组,字典等,不能为数字,注意是迭代添加在末尾

删:

索引删除:list.pop(index)默认删除最后一个,这个是有返回值的,deleted = list.pop() deleted为被删除的元素

index为删除索引,你想要删除第几位,list.pop(index - 1)

指定元素删除:list.remove(指定元素)删除指定元素,没有返回值,不用赋值,如果删除不存在的元素会报错!

切片删除:del lst[起始位置:结束位置:步长]步长默认为1,范围删除,若步长不为1,参考上述讲解!

改:

直接索引赋值修改,切片修改见上述2

查:

for c in lst: print(c) 这里相当于循环一次,列表中索引下标增加1找出元素赋值给c;

5.列表的嵌套

若列表中有嵌套列表:可以采用降维操作找到元素,

若元素为字符串,可以直接应用字符串的操作:

代码展示:

 lst = [1, "太白", "wusir", ["麻花疼", ["可口可乐"], "王剑林"]]
lst[2] = lst[2].capitalize()
print(lst)
#输出结果:[1, '太白', 'Wusir', ['麻花疼', ['可口可乐'], '王剑林']] print(lst[3][1][0])
lst[3][1].append("芬达")
print(lst)
#输出结果:可口可乐
[1, '太白', 'Wusir', ['麻花疼', ['可口可乐', '芬达'], '王剑林']]

列表嵌套

元组:

跟列表相似,但是元组是只读文件,不可变,而子元素内部的子元素是可以变的,这取决于子元素是否是可变对象!

注意:这里有一个坑:如果你定义一个元组为:tul = (108)或者tul = ("string")前者是整形后者为字符串类型,

所以你定义的元组里的元素少于两个的话,就不是元组,只不过加了个扩号而已,定义格式为:tul = (108,)或者tul = ("string",);空元组格式为:tu = tuple();

6.range的应用

range可以帮我们获取一些数据,通过for循环能够获取这些数据

for sum in range(10): print(sum)默认是从0开始的,在这里表示从0到10,10取不到,跟切片索引是一样的,也有步长!

Python_004(列表和元组)的更多相关文章

  1. Python列表和元组

    Python是没有数组的概念,但是和数组比较相近的概念是列表和元素. 下面两个例子展示列表和元组. # coding=utf-8 # 元组 students = ('小明', '小黄', '小李', ...

  2. Python黑帽编程2.3 字符串、列表、元组、字典和集合

    Python黑帽编程2.3  字符串.列表.元组.字典和集合 本节要介绍的是Python里面常用的几种数据结构.通常情况下,声明一个变量只保存一个值是远远不够的,我们需要将一组或多组数据进行存储.查询 ...

  3. 第二天----列表、元组、字符串、算数运算、字典、while

    列表 列表是最常用的Python数据类型,它可以作为一个方括号内的逗号分隔值出现. 基本操作: 索引切片追加删除长度切片循环包含 创建.查看列表: 列表中的数字不要加引号,列表的索引从0开始: lis ...

  4. python:列表与元组

    1.python包含六种内建的序列,列表和元组是其中的两种,列表可以修改,元组则不能 2.通用序列操作 2.1 索引:和C#的区别是索引可以为负数,最后一个元素索引为-1,索引超出范围会报错 例:&g ...

  5. python中列表,元组,字符串互相转换

    列表,元组和字符串python中有三个内建函数:,他们之间的互相转换使用三个函数,str(),tuple()和list(),具体示例如下所示 >>> s = "xxxxx& ...

  6. Python【2】-列表和元组

    一.序列 python包含六种内建的序列:列表.元组.字符串.unicode字符串.buffer对象.xrange对象. 列表可以修改,元组是不能修改的. 二.列表 列表list是变长序列,其中的内容 ...

  7. python基础知识3——基本的数据类型2——列表,元组,字典,集合

    磨人的小妖精们啊!终于可以归置下自己的大脑啦,在这里我要把--整型,长整型,浮点型,字符串,列表,元组,字典,集合,这几个知识点特别多的东西,统一的捯饬捯饬,不然一直脑袋里面乱乱的. 一.列表 1.列 ...

  8. .Net程序员之Python基础教程学习----列表和元组 [First Day]

    一. 通用序列操作: 其实对于列表,元组 都属于序列化数据,可以通过下表来访问的.下面就来看看序列的基本操作吧. 1.1 索引: 序列中的所有元素的下标是从0开始递增的. 如果索引的长度的是N,那么所 ...

  9. 基本数据类型-集合(set)_上周内容回顾(字符串_数字_列表_元组_字典_集合)

    上周内容回顾 1.字符串 2.数字 除了布尔类型外,int.long.float和complex都可以使用的运算为:加.减.乘.除.整除.幂运算和取余 3.列表和元组 列表的内容可变,可以包含任意对象 ...

随机推荐

  1. pandas 基础介绍与概览

    pandas是 基于NumPy数组构建的,特别是基于数组的函数和不使用for循环的数据处理 相关联的几个库, 分析库 scikit-learn 和 statsmodels 数值计算工具,NumPy 可 ...

  2. sprint test 添加事务回滚机制

    1.原因: 单元测试的时候频繁操作数据库需要修改很多数据,造成不必要的操作,添加事务之后就可以重复对一条数据进行操作,并且在返回结果后进行回滚. 2.解决: 原先继承的是  AbstractJUnit ...

  3. Generative Model vs Discriminative Model

    In this post, we are going to compare the two types of machine learning models-generative model and ...

  4. Cors 跨域 共享

    CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing). 它允许浏览器向跨源服务器,发出XMLHttpRequest请求,从 ...

  5. 20190901 On Java8 第十五章 异常

    第十五章 异常 要想创建健壮的系统,它的每一个构件都必须是健壮的. 异常概念 C++的异常处理机制基于 Ada,Java 中的异常处理则建立在 C++的基础之上(尽管看上去更像 Object Pasc ...

  6. tbox新增stackless协程支持

    tbox之前提供的stackfull协程库,虽然切换效率已经非常高了,但是由于每个协程都需要维护一个独立的堆栈, 内存空间利用率不是很高,在并发量非常大的时候,内存使用量会相当大. 之前考虑过采用st ...

  7. 管理MySQL 从入门到出门

    MySQL 中的数据库(Database)就像是一个容器,其中包含了各种对象.例如,数据表(Table).视图(View).存储过程(Stored Procedure)以及触发器(Trigger)等. ...

  8. Haystack Python全文检索框架

    Haystack 1.什么是Haystack Haystack是django的开源全文搜索框架(全文检索不同于特定字段的模糊查询,使用全文检索的效率更高 ),该框架支持Solr,Elasticsear ...

  9. Java WebService 参考文档

    webservice 基础使用 java 与tomcat使用http://cxshun.iteye.com/blog/1275408 spring mvc中使用https://www.cnblogs. ...

  10. java_第一年_JavaWeb(14)

    EL :EL表达式主要用于获取数据.执行运算.获取对象.调用java方法: 获取数据 语法:"${标识符}" 会调用pageContext.findAttribute方法,从pag ...