第四节

一、列表 list

  • 数据类型之一,存储大量的,不同类型的数据

  • 列表中只要用逗号隔开的就是一个元素

  • 有序可变的。

1.1列表的索引

  • 列表和字符串一样也拥有索引,但是列表可以修改:

lst = ['张三','李四','赵五','陈六']print(lst[0])  # 列表中第一个元素print(lst[1])  # 列表中第二个元素print(lst[2])  # 列表中第三个元素

1.2列表的切片

  • 切片的用法和步长和字符串一样。顾头不顾尾。

lst = ["章", "菲", "绣", "花", "鲁迅"] print(lst[0:3])     # ['章', '菲', '绣'] print(lst[:3])      # ['章', '菲', '绣']print(lst[1::2])    # ['菲', '花'] 也有步长 print(lst[2::-1])   # ['绣', '菲', '章'] 也可以倒着取 print(lst[-1:-3:-2])    # 倒着带步长

练习:

li = [1, 3, 2, "a", 4, "b", 5,"c"]通过对li列表的切片形成新的列表l1,l1 = [1,3,2]通过对li列表的切片形成新的列表l2,l2 = ["a",4,"b"]通过对li列表的切片形成新的列表l3,l3 = ["1,2,4,5]通过对li列表的切片形成新的列表l4,l4 = [3,"a","b"]通过对li列表的切片形成新的列表l5,l5 = ["c"]通过对li列表的切片形成新的列表l6,l6 = ["b","a",3]

1.3列表的增删改查

    • 注意:list和str是不一样的. lst可以发生改变. 所以直接就在原来的对象上进行了操作

    追加模式

    • append() —— 追加,在列表的末尾进行添加

    lst = ["章", "菲", "绣", "花", "鲁迅"] print(lst)  # ["章", "菲", "绣", "花", "鲁迅"] lst.append("吃鸡") print(lst) # ["章", "菲", "绣", "花", "鲁迅","吃鸡"] 
    • insert(索引,插入内容) —— 插入

    lst = ["章", "菲", "绣", "花", "鲁迅"] lst.insert(1, "许褚")    # 在1的位置插入许褚. 原来的元素向后移动一位print(lst) # ["章", "许褚","菲", "绣", "花", "鲁迅"]
    • extend() —— 迭代添加

    # 迭代添加lst = ["金志文", "张一山", "苦海无涯"]lst.extend(["麻花藤", "麻花不疼"])print(lst) # ["金志文", "张一山", "苦海无涯","麻花藤", "麻花不疼"]
    • pop —— 删除

    lst = ["章", "菲", "绣", "花", "鲁迅"]print(repr(lst.pop(2)))    # repr()查看当前数据的原生态print(lst)  #["章", "菲", "花", "鲁迅"]
    • clear() —— 清空

    lst = ["章", "菲", "绣", "花", "鲁迅"] print(lst)  # ["章", "菲", "绣", "花", "鲁迅"] lst.clear()print(lst) # [s]
    • del list —— 通过索引,切片,步长删除

    lst = ["章", "菲", "绣", "花", "鲁迅"]del lst[3] #  ["章", "菲", "绣", "鲁迅"] del lst[1:4]# ["章","鲁迅"]del lst[1::2] # ['章', '绣', '鲁迅']
    • 通过索引修改

      lst = ["章", "菲", "绣", "花", "鲁迅"]lst[1] = "小野猪"print(lst) # ["章", "小野猪", "绣", "花", "鲁迅"]
    • 通过切片进行修改,默认步长为1,修改的内容必须是可迭代的对象,修改的内容可多可少

      lst = ["章", "菲", "绣", "花", "鲁迅"]lst[1:3] = "小野猪" # 默认步长为1print(lst) # ['章', '小', '野', '猪', '花', '鲁迅']lst[1:5:2] = "小芳","青青草原" # 步长不为1的时候,必须一一对应print(lst) # ['章', '小芳', '绣', '青青草原', '鲁迅']
    • for循环

      lst = ["章", "菲", "绣", "花", "鲁迅"]for i in lst:    print(i)
    • 索引

1.4列表的嵌套

  • 一层一层的查找,[...]视为一个元素

    lst1 = ["国际章", "阿娇", ['汪峰', "国际章", "小苹果", "小姨"],["蔡徐坤", ["篮球", "姚明", "林书豪"], ["唱", "邓丽君", "蔡国庆", "腾格尔"],["跳", "蔡依林", "罗志祥", "赵四", "社会摇"],["cnb", "alex", "rimo"]]]print(lst[-3][-1]) # 腾格尔

二、元组

python数据类型之一。tuple:有序,不可变;只支持查询,不支持增删改。

(元组就是一个不可变的列表)

  1. 统计 —— count():统计某个元素出现的次数

    tu = (1,2,3,4,5,1,2,1)print(tu.count(1)) # 3   统计元素在元组中出现的次数
  2. 获取索引 —— index():通过元素查询索引

    tu = (1,2,3,4,5,1,2,1)print(tu.index(2)) #  1 通过元素查询索引
  3. 用途:就是将一些非常重要的不可让人改动的数据放在元祖中,只供查看。

  4. 元组的嵌套

    tu = (1,2,3,4,(5,6,7,8,("alex","wusir",[1,23,4])))print(tu[4][4][0]) # alex

三、range

range —— 范围

print(range(1,10))   # Python3中打印range是自己range自己本身
print range(1,10)    # Python2中打印range获取的是一个列表,列表的元素是1-9
range(1,10)   # [起始位置:终止位置]  顾头不顾尾
range(1,10,2) # [起始位置:终止位置:步长] 默认为 1
range(10)    # 10代表的是终止位置,起始位置默认为0  range是一个可迭代对象
range的诞生是为了解决不能循环数字
for i in range(2,10,2):
    print(i) # 2 4 6 8
for i in range(0,100,2):
    print(i) # 0到100(不包含)以内的所有偶数
for i in range(1,100,2):
    print(i) # 1到100(不包含)以内的所有奇数
for i in range(100):
    print(i) # 0~99所有的数
for i in range(100,-1,-1):
	print(i) # 100~0
for i in range(100,-11,-1):
    print(i) # 100~-10

后续还会持续更新,从入门到放弃  ^.^。

python_0基础开始_day04的更多相关文章

  1. python_0基础学习_day02

    第二节 一,while while也称为无限循环.死循环 while 条件: 缩进 循环体 应用领域:音乐播放:单曲循环,列表循环,随机播放(也是有规律的) 登陆界面:…… 数学计算:1~100的和, ...

  2. python_0基础学习_day01

    Python是一门动态解释型的强类型定义语言 一.变量 变量命名规则 由数字.字母.下划线组成 不能以数字开头 要具有描述性 要区分大小写 禁止使用python的关键字(在pycharm中关键字明明变 ...

  3. python_0基础开始_day07

    第七节 1,基础数据类型补充 str: print(str.capitalize()) —— 首字母大写 print(str.title()) —— 每个单词的首字母大写 print(str.swap ...

  4. python_0基础开始_day06

    第六节 1.小数据池 ==,is,id ==:查看等号两边的值是否一样 a = 9b = 9print(a == b) # 返回Truec = "dog"d = "dog ...

  5. python_0基础开始_day03

    第三节 一.整形和布尔值的转换 int整型 python3: 全部都是整型 python2: 整型,长整型long 十进制转换二进制 # 将十进制的168转换为二进制 ​#得出结果 将十进制的168转 ...

  6. python_0基础开始_day05

    第五节 一.字典 python的数据结构之一 字典 —— dict 定义:dic = {"key":"dajjlad"} 作用:存储数据,大量,将数据和数据起到 ...

  7. python_0基础开始_day13

    第十三节 一,匿名函数 匿名函数 == 一行函数 lambda == def == 关键字 函数体中存放的是代码 生成器体中存放的也是代码 就是yield导致函数和生成器的结果不统一 lambda x ...

  8. python_0基础开始_day12

    第十二节 一,生成器 生成器的核心:生成器的本质就是迭代器 迭代器是python自带的 生成器是程序员自己写的一种迭代器 在python中有三种方式来创建生成器: 基于函数编写 推导式方式编写 pyt ...

  9. python_0基础开始_day11

    第十一节 一,函数名的第一类对象 函数名当作值,赋值给变量 print(函数名) 查看看书的内存地址 函数名可以当作容器中的元素 lis = []dic = {}def func():    prin ...

随机推荐

  1. CentOS7 安装MySQL8修改密码

    1. 添加MySQL8的本地源 执行以下命令获取安装MySQL源 [root@virde ~]# wget https://repo.mysql.com//mysql80-community-rele ...

  2. Konrad and Company Evaluation

    F. Konrad and Company Evaluation 参考:[codeforces 1230F]Konrad and Company Evaluation-暴力 思路:题意分析见参考博客. ...

  3. MySort作业与IO-Myhead

    一.MySort 1.题目要求 模拟实现Linux下Sort -t : -k 2的功能. 要有伪代码,产品代码,测试代码(注意测试用例的设计) 参考 Sort的实现.提交博客链接. 2.产品代码 im ...

  4. (转)linux中wget未找到命令

    转:https://blog.csdn.net/djj_alice/article/details/80407769 在装数据库的时候发现无法使用wget命令,提示未找到命令,如图所示 那是因为没有安 ...

  5. 石川es6课程---17、ES7 预览

    石川es6课程---17.ES7 预览 一.总结 一句话总结: 人的价值恒定规律:无论得意还是迷茫之时,你的价值都不靠外界的评判或者你内心的悲喜而决定.而是当时的恒定的.能够提升他只能靠你提升自己的能 ...

  6. 判断List是否为空的问题

    今天公司安排给页面调试Bug,感觉公司人员写的判断判断List是否为空存在一定的问题,公司判断是list!=null这是完全不对的,这只会判断是否有list对象.如果为空,他也会执行if(list!= ...

  7. [SQL Server 视图的创建- (create view必须是批处理中仅有的语句问题)]

    当我们SQL Server在创建视图时 ,会出现"create view 必须是批处理中仅有的语句"这个语法错误提示 ,实际上这本身没什么错! 因为create view 必须是批 ...

  8. 《视觉SLAM十四讲》第1讲

    目录 一 视觉SLAM 注:原创不易,转载请务必注明原作者和出处,感谢支持! 一 视觉SLAM 什么是视觉SLAM? SLAM是Simultaneous Localization and Mappin ...

  9. c# httphelper (苏飞老师)

    /// <summary> /// 类说明:HttpHelper类,用来实现Http访问,Post或者Get方式的,直接访问,带Cookie的,带证书的等方式,可以设置代理 /// 重要提 ...

  10. 003-Spring4 扩展分析-spring类初始化@PostConstruct > InitializingBean > init-method、ApplicationContext、BeanPostProcessor、BeanFactoryPostProcessor、BeanDefinitionRegistryPostProcessor

    一.spring类初始化@PostConstruct > InitializingBean > init-method InitializingBean接口为bean提供了初始化方法的方式 ...