第四节

一、列表 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. 邻居子系统 之 邻居表的初始化neigh_table_init

    概述 邻居子系统支持多种实现,例如ARP,ND等,这些实现需要在其初始化的时候,调用neigh_table_init将邻居表项添加到全局邻居子系统数组中,并对实例中的字段(如hash,定时器等)进行相 ...

  2. VS下创建网站发布到IIS

    http://www.51zxw.net/show.aspx?id=27297&cid=410

  3. Ubuntu16.04下安装最新版本的CMake

      当前最新版CMake为3.9.1.. Ubuntu中更新cmake到最新版本,过程如下: 1. 卸载已经安装的旧版的CMake[非必需] apt-get autoremove cmake 2. 文 ...

  4. 文字和符号组合成图 Banner

    springboot 启动 logo.... 文字符号组合成的图. <<< | /\\\ /--\\\ / \\\\ <*| /________\\\\ | ___ | | | ...

  5. PHP安装 (结合之前的nginx安装与mysql安装组合为lnmp)

    检查安装PHP所需的lib库 yum -y install zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel libiconv-de ...

  6. LC 274. H-Index

    Given an array of citations (each citation is a non-negative integer) of a researcher, write a funct ...

  7. SVN服务器的安装

    运行VisualSVN-Server-2.7.3.msi程序, 如下图 点击Next, 下一步 选中 I accept选项, 点击Next, 下一步 选择默认配置, 服务和控制台组件方式, 点击Nex ...

  8. 阶段3 3.SpringMVC·_04.SpringMVC返回值类型及响应数据类型_2 响应之返回值是String类型

    返回字符串 新建一个response的页面 新建后台Controller类 视图解析器配置的前缀地址 是WEB-INF下的pages下的页面. 创建pages文件夹在下面创建success.jsp页面 ...

  9. dokcer部署code-server web版vscode

    #dokcer部署code-server web版vscode codercom/code-server:latest不支持插件在线安装 codercom/code-server:v2目前为最新版1. ...

  10. ERROR [org.hibernate.engine.jdbc.spi.SqlExceptionHelper] - Data truncation: Incorrect datetime value: '' for column 'pubdate' at row 1

    之前的Connector/J版本是:mysql-connector-java-5.0.4-bin.jar 后来换成mysql-connector-java-5.1.45-bin.jar,问题解决 20 ...