百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

一文详解Python常用数据类型,列表、字典、元组和集合

liuian 2025-02-18 12:23 14 浏览

打了激素的列表

变量可以存储一个元素,而列表是一个“大容器”可以存储N多个元素,程序可以方便地对这些数据进行整体操作。

列表的创建:列表需要使用中括号[],元素之间使用英文的逗号进行分隔

  • 创建方式使用中括号调用内置函数list()
lst=['黑猫','徐筵彭']
lst2=list([‘黑猫’,‘徐筵彭'])

列表的特点

获取列表中的单个元素

获取列表中指定元素索引

列表切片查询

判断指定元素在列表中是否存在

列表元素的遍历

列表元素的增加操作

列表元素的删除操作

列表元素的排序操作

  • 调用sort()方法,列有中的所有元素默认按照从小到大的顺序进行排序,可以 指定 reverse=True,进行降序 排序
  • 调用内置函数sorted(),可以指定reverse=True,进行降序排序,原列表不发生改变
li = [3, 1, 2, 4, 5]
# li.sort(reverse=True)
# print(li)

li2 = sorted(li, reverse=True)
print(li, li2)

列表生成式:即生成列表的公式

总结

成双成对的字典

  • Python内置的数据结构之一,与列表一样是一个可变序列
  • 键值对的方式存储数据,字典是一个无序的序列

字典的实现原理

字典的实现原理与查字典类似,查字典是先根据部首或拼音查找汉字对应的页码,Python中的字典是根据key查找value所在的位置。

字典的创建

  • 最常用的方式:使用花括号
  • 使用内置函数dict()

字典的常用操作

字典中元素的获取

  • []取值:如果字典中不存在指定的key,抛出keyError异常
  • get()方法取值,如果字典中不存在指定的key,并不会抛出KeyError而是返回None,可以通过参数设置默认的value,以便指定的key不存在时返回

key的判断

字典元素的删除

字典元素的新增

获取字典视图的三种方法

字典元素的遍历

字典的特点

  • 字典中的所有元素都是一个 key-value对,key不允许重复, value可以重复
  • 字典中的元素是无序
  • 字典中的key必须是不可变对象
  • 字典也可以根据需要动态地伸缩
  • 字典会浪费较大的内存,是一种使用空间换时间的数据结构

zip和字典生成式

  • 内置函数zip()
  • 字典生成式

总结

元组和集合

Python内置的数据结构之一,是一个不可变序列

不变可变序列:比如字符串、元组,没有增、删,改的操作

可变序列:比如列表、字典执行增、删、改操作,对象地址不发生更改

元组的创建方式

  • 直接小括号
  • 使用内置函数tuple()
  • 只包含一个元组的元素需要使用逗号和小括号

为什么要将元组设计成不可变序列

  • 在多任务环境下,同时操作对象时不需要加锁
  • 注意事项:元组中存储的是对象的引用如果元组中对象本身不可变对象,则不能再引用其它对象如果元组中的对象是可变对象,则可变对象的引用不允许改变,但数据可以改变

元组的遍历

什么是集合

  • Python语言提供的内置数据结构
  • 与列表、字典一样都属于可变类型的序列
  • 集合是没有value的字典

集合的创建方式

  • 直接{ }
  • 使用内置函数set()

集合的相关操作

  • 集合元素的判断操作innot in
  • 集合元素的新增操作
    • 调用add()方法,一次添加一个元素
    • 调用update()方法至少添加一个元素
  • 集合元素的删除操作
    • 调用remove()方法,一次删除一个指定元素,如果指定的元素不存在抛出KeyError
    • 调用discard()方法,一次删除一个指定元素,如果指定的元素不存在不抛异常
    • 调用pop()方法,一次只删除一个任意元素
    • 调用clear()方法,清空集合

集合间的关系

  • 两个集合是否相等:可以使用运算符==!=进行判断
  • 一个集合是否是另一个集合的子集:可以调用方法issubset进行判断B是否是A的子集
  • 一个集合是否是另一个集合的超集:可以调用方法issuperset进行判断A是否是B的超集
  • 两个集合是否有交集 :可以调用方法isdisjoint进行判断

集合的数学操作

集合生成式

总结

相关推荐

相关推荐

软件测试/测试开发丨Pytest 自动化测试框架(五)

公众号搜索:TestingStudio霍格沃兹测试开发的干货都很硬核测试报告在项目中是至关重要的角色,一个好的测试报告:可以体现测试人员的工作量;开发人员可以从测试报告中了解缺陷的情况;测试经理可以...

python爬虫实战之Headers信息校验-Cookie

一、什么是cookie上期我们了解了User-Agent,这期我们来看下如何利用Cookie进行用户模拟登录从而进行网站数据的爬取。首先让我们来了解下什么是Cookie:Cookie指某些网站为了辨别...

软件测试 | 结合Allure生成测试报告

简介测试报告在项目至关重要,测试人员可以在测试报告中体现自己的工作量,开发人员可以从测试报告中了解缺陷的情况,测试经理可以从测试报告中看到测试人员的执行情况及测试用例的覆盖率,项目负责人可以通过测...

使用FUSE挖掘文件上传漏洞(文件上传漏洞工具)

关于FUSEFUSE是一款功能强大的渗透测试安全工具,可以帮助广大研究人员在最短的时间内迅速寻找出目标软件系统中存在的文件上传漏洞。FUSE本质上是一个渗透测试系统,主要功能就是识别无限制可执行文件上...

第42天,我终于意识到,爬虫这条路,真的好艰难

昨天说到学爬虫的最初四行代码,第四行中的print(res.text),我没太懂。为啥最后的输出的结果,不是显示百度网页全部的源代码呢?这个世界上永远不缺好心人。评论区的大神告诉我:因为只包含静态h...

详解Pytest单元测试框架,轻松搞定自动化测试实战

pytest是目前企业里面使用最多、最流行的Python的单元测试框架,那我们今天就使用这个框架来完成一个网易163邮箱登录的自动化实战案例。下面我们先把我们案例需要的工具进行相关的介绍:01pyt...

干货|Python大佬手把手带你破解哔哩哔哩网滑动验证(上篇)

/1前言/有爬虫经验的各位小伙伴都知道,正常我们需要登录才能获取信息的网站,是比较难爬的。原因就是在于,现在各大网站为了反爬,与爬虫机制斗智斗勇,一般的都加入了图片验证码、滑动验证码之类的干扰,让...

Python 爬虫-如何抓取需要登录的网页

本文是Python爬虫系列第四篇,前三篇快速入口:Python爬虫-开启数据世界的钥匙Python爬虫-HTTP协议和网页基础Python爬虫-使用requests和B...

使用Selenium实现微博爬虫:预登录、展开全文、翻页

前言想实现爬微博的自由吗?这里可以实现了!本文可以解决微博预登录、识别“展开全文”并爬取完整数据、翻页设置等问题。一、区分动态爬虫和静态爬虫1、静态网页静态网页是纯粹的HTML,没有后台数据库,不含程...

从零开始学Python——使用Selenium抓取动态网页数据

1.selenium抓取动态网页数据基础介绍1.1什么是AJAX  AJAX(AsynchronouseJavaScriptAndXML:异步JavaScript和XML)通过在后台与服务器进...

PHP自动测试框架Top 10(php单元测试工具)

对于很多PHP开发新手来说,测试自己编写的代码是一个非常棘手的问题。如果出现问题,他们将不知道下一步该怎么做。花费很长的时间调试PHP代码是一个非常不明智的选择,最好的方法就是在编写应用程序代码之前就...

10款最佳PHP自动化测试框架(php 自动化测试)

为什么测试如此重要?PHP开发新手往往不会测试自己编写的代码,我们中的大多数通过不断测试我们刚刚所编写浏览器窗口的新特性和功能来进行检测,但是当事情出现错误的时候我们往往不知道应该做些什么。为我们的代...

自动化运维:Selenium 测试(seleniumbase搭建自动化测试平台)

本文将以Buddy中的Selenium测试流水线示例,来看看自动化测试就是如此简单易用!Selenium是一套用于浏览器测试自动化的工具。使用Buddy专有服务,您可以直接在Buddy中运行Selen...

Selenium自动化测试(selenium自动化测试工具)

Selenium是一系列基于web的自动化测试工具。它提供了一系列测试函数,用于支持Web自动化测试。这些函数非常灵活,它们能够通过多种方式定位界面元素,并可以将预期结果与系统实际表现进行比较。作为一...

技术分享 | Web自动化之Selenium安装

本文节选自霍格沃兹测试开发学社内部教材Web应用程序的验收测试常常涉及一些手工任务,例如打开一个浏览器,并执行一个测试用例中所描述的操作。但是手工执行的任务容易出现人为的错误,也比较费时间。因此,将...