数据大杂烩:探索Python数据容器的通用操作

文章目录

  • 一 数据容器的对比总结
    • 1.1 容器简单分类
    • 1.2 容器特点对比
  • 二 数据容器的通用操作
    • 2.1 通用操作详解
    • 2.2 通用操作总结

一 数据容器的对比总结

1.1 容器简单分类

数据容器可以从以下视角进行简单的分类:

  • 是否支持下标索引
    • 支持:列表、元组、字符串 —— 序列类型
    • 不支持:集合、字典 —— 非序列类型
  • 是否支持重复元素:
    • 支持:列表、元组、字符串 —— 序列类型
    • 不支持:集合、字典 —— 非序列类型
  • 是否可以修改
    • 支持:列表、集合、字典
    • 不支持:元组、字符串

1.2 容器特点对比

列表元组字符串集合字典
元素数量支持多个支持多个支持多个支持多个支持多个
元素类型任意任意仅字符任意Key: Value
Key:除字典外M任意类型
Value:任意类型
下标索引支持支持支持不支持不支持
重复元素支持支持支持不支持不支持
可修改性支持不支持不支持支持支持
数据有序
使用场景可修改、可重复的一批数据记录场景不可修改、可重复的一批数据记录场景一串字符的记录场景不可重复的数据记录场景以Key检索Value的数据记录场景

二 数据容器的通用操作

2.1 通用操作详解

  1. 访问元素:

    • 列表和元组:使用索引来访问单个元素,例如 my_list[0]
    • 字典:通过键来访问对应的值,例如 my_dict["key"]
    my_list = [1, 2, 3, 4, 5]
    my_tuple = (10, 20, 30, 40, 50)
    my_dict = {"a": 1, "b": 2, "c": 3}print(my_list[2])  # 输出: 3
    print(my_tuple[1])  # 输出: 20
    print(my_dict["b"])  # 输出: 2
    
  2. 切片操作:

    • 列表和元组:使用切片语法来获取子序列,例如 my_list[start:end]
    • 字符串:使用切片获取子字符串,例如 my_string[start:end]
    my_list = [1, 2, 3, 4, 5]
    my_string = "Hello, World!"print(my_list[1:4])  # 输出: [2, 3, 4]
    print(my_string[7:12])  # 输出: World
    
  3. 遍历元素:

    • 使用 for 循环遍历容器中的每个元素。
    my_set = {1, 2, 3, 4, 5}for item in my_set:print(item)
    # 输出:
    # 1
    # 2
    # 3
    # 4
    # 5
    
  4. 长度获取:

    • 使用 len() 函数获取容器中元素的数量。
    my_list = [1, 2, 3, 4, 5]
    my_dict = {"a": 1, "b": 2, "c": 3}print(len(my_list))  # 输出: 5
    print(len(my_dict))  # 输出: 3
    
  5. 成员检查:

    • 使用 in 关键字检查元素是否存在于容器中。
    my_list = [1, 2, 3, 4, 5]if 3 in my_list:print("3 exists in the list")
    # 输出: 3 exists in the list
    
  6. 连接/合并容器:

    • 列表和元组:使用 + 运算符来连接或合并容器。
    • 字典:使用 update() 方法来合并字典。
    list1 = [1, 2, 3]
    list2 = [4, 5, 6]merged_list = list1 + list2
    print(merged_list)  # 输出: [1, 2, 3, 4, 5, 6]
  7. 复制容器:

    • 使用 copy() 方法或切片来复制列表和元组。
    • 使用 copy() 方法复制集合。
    • 使用 copy() 方法或 dict() 构造函数复制字典。
    original_list = [1, 2, 3]
    copied_list = original_list.copy()print(copied_list)  # 输出: [1, 2, 3]
    
  8. 删除元素:

    • 列表和元组:使用 del 语句来删除元素,例如 del my_list[0]
    • 字典:使用 del 语句或 pop() 方法删除键值对。
    my_list = [1, 2, 3, 4, 5]
    del my_list[2]
    print(my_list)  # 输出: [1, 2, 4, 5]
    
  9. 清空容器:

    • 使用 clear() 方法来清空列表、集合和字典。
    my_set = {1, 2, 3, 4, 5}
    my_set.clear()
    print(my_set)  # 输出: set()
    
  10. 排序:

    • 列表:使用 sort() 方法或 sorted()或者sorted(容器, [reverse=True]) 函数来排序列表。
    • 集合:使用 sorted() 或者sorted(容器, [reverse=True]) 函数对集合进行排序。
    • 排序后都会得到列表(list)对象。
    my_list = [3, 1, 4, 1, 5, 9, 2, 6]
    sorted_list = sorted(my_list)
    print(sorted_list)  # 输出: [1, 1, 2, 3, 4, 5, 6, 9]
    
  11. 查找最值:

    • 使用 max()min() 函数来查找列表或元组中的最大和最小值。
    my_tuple = (10, 5, 8, 12, 3)
    max_value = max(my_tuple)
    min_value = min(my_tuple)print("Max:", max_value)  # 输出: Max: 12
    print("Min:", min_value)  # 输出: Min: 3
    
  12. 列表推导、字典解析等:

    • 利用列表推导来创建新的列表。
    • 使用字典解析来创建新的字典。
    my_list = [1, 2, 3, 4, 5]
    squared_list = [num ** 2 for num in my_list]
    print(squared_list)  # 输出: [1, 4, 9, 16, 25]
    
  13. 转换为其他类型:

    • 使用 list(), tuple(), set()dict() 等构造函数来进行类型转换。
    my_tuple = (1, 2, 3)
    my_list = list(my_tuple)
    print(my_list)  # 输出: [1, 2, 3]
    
  14. 添加/删除元素:

    • 列表:使用 append(), insert()remove() 方法来添加和删除元素。
    • 集合:使用 add()remove() 方法来添加和删除元素。
    • 字典:使用赋值来新增或修改键值对,使用 pop() 方法删除键值对。

2.2 通用操作总结

操作描述
访问元素使用索引或键来访问容器中的元素。
切片操作使用切片语法获取子序列或子字符串。
遍历元素使用 for 循环遍历容器中的每个元素。
长度获取使用 len() 函数获取容器中元素的数量。
成员检查使用 in 关键字检查元素是否存在于容器中。
连接/合并容器使用+运算符来连接或合并容器。
复制容器使用 copy() 方法或切片来复制容器。
删除元素使用 del 语句来删除容器中的元素。
清空容器使用 clear() 方法来清空容器。
排序使用 sorted() 函数来对容器进行排序。
查找最值使用 max()min() 函数来查找容器中的最大和最小值。
列表推导、字典解析等利用推导式来创建新的容器。
转换为其他类型使用构造函数来进行容器类型之间的转换。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/27793.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux6.32 Kubernetes kubeadm部署

文章目录 计算机系统5G云计算第三章 LINUX Kubernetes kubeadm部署一、kubeadm搭建 Kubernetes v1.20(一主两从)1.环境准备2.所有节点安装docker3.所有节点安装kubeadm,kubelet和kubectl4.部署K8S集群 二、kubeadm搭建 Kubernetes v1.20&…

OSLog与NSLog对比

NSLog: NSLog的文档,第一句话就说:Logs an error message to the Apple System Log facility.,所以首先,NSLog就不是设计作为普通的debug log的,而是error log;其次,NSLog也并非是printf的简单…

单元测试用例分组 demo

文章目录 目标1、使用 Category 进行用例分组(1)设置用例组(2)编写测试类,case设置对应的用例组(3)编写执行类(4)查看运行结果(5)联系项目 2、参数…

鸿蒙应用开发指南:从零开始构建一款智能音乐播放器

介绍 随着鸿蒙操作系统的发布,开发者们迫不及待地想要探索鸿蒙应用的开发。本篇博客将以构建一款智能音乐播放器为例,带你一步步了解鸿蒙应用开发的技术要点和实践。我们将使用HarmonyOS的开发环境和MarkDown进行排版,方便你快速上手。 准备…

App Cleaner Uninstaller for Mac 苹果电脑软件卸载工具

App Cleaner & Uninstaller 是一款非常有用的 Mac 应用程序清理和卸载工具。它可以彻底地清理系统中的应用程序、扩展和残留文件,以释放磁盘空间并优化系统性能。 此外,它还提供了磁盘空间监控和智能清理建议等功能,使用户可以轻松地管理…

计算机网络性能指标

比特:数据量的单位 KB 2^10B 2^13 bit 比特率:连接在计算机网络上的主机在数字通道上传送比特的速率 kb/s 10^3b/s 带宽:信号所包含的各种频率不同的成分所占据的频率范围 Hz 表示在网络中的通信线路所能传送数据的能力&#xff08…

Meta开源AI音频和音乐生成模型

在过去的几年里,我们看到了AI在图像、视频和文本生成方面的巨大进步。然而,音频生成领域的进展却相对滞后。MetaAI这次再为开源贡献重磅产品:AudioCraft,一个支持多个音频生成模型的音频生成开发框架。 AudioCraft开源地址 开源地…

嵌入式该往哪个方向发展?

1. 你所在的城市嵌入式Linux岗位多吗?我觉得这是影响你做决定的另一个大问题。我们学嵌入式Linux这门技术,绝大部分人是为了从事相关的工作,而不是陶冶情操。但是根据火哥统计来看,嵌入式Linux的普遍薪资虽然高于单片机&#xff0…

C++ Visual Studio工程目录相对路径设置

文章目录 相对路径相对路径是相对vs工程的哪个目录而言书写格式 参考 相对路径 要设对相对路径,需要搞清楚下面两个问题: 相对路径是相对vs工程的哪个目录而言相对路径的书写格式 相对路径是相对vs工程的哪个目录而言 注意: 并非以解决方案…

网络安全进阶学习第十四课——MSSQL注入

文章目录 一、MSsql数据库二、MSsql结构三、MSsql重点表1、master 数据库中的Sysdatabases 表2、Sysobjects 表3、Syscolumns 表 四、Mssql常用函数五、Mssql的报错注入六、Mssql的盲注常用以下函数进行盲注: 七、联合注入1、获取当前表的列数2、获取当前数据库名3、…

网络编程(JavaEE初阶系列10)

目录 前言: 1.网络编程的基础 1.1为什么需要网络编程 1.2什么是网络编程 1.3网络编程中的基本概念 1.3.1发送端和接收端 1.3.2请求和响应 1.3.3客户端和服务端 2.Socket套接字 2.1概念 2.2分类 3.UDP数据报套接字编程 3.1DataGramSocket API 3.2Datagr…

坐标转换-使用geotools读取和转换地理空间表的坐标系(sqlserver、postgresql)

前言: 业务上通过GIS软件将空间数据导入到数据库时,因为不同的数据来源和软件设置,可能导入到数据库的空间表坐标系是各种各样的。 如果要把数据库空间表发布到geoserver并且统一坐标系,只是在geoserver单纯的设置坐标系只是改了…

JMeter命令行执行+生成HTML报告

1、为什么用命令行模式 使用GUI方式启动jmeter,运行线程较多的测试时,会造成内存和CPU的大量消耗,导致客户机卡死; 所以一般采用的方式是在GUI模式下调整测试脚本,再用命令行模式执行; 命令行方式支持在…

MyBatis-动态SQL-foreach

目录 标签有以下常用属性&#xff1a; 小结 <froeach> <foreach>标签有以下常用属性&#xff1a; collection&#xff1a;指定要迭代的集合或数组的参数名&#xff08;遍历的对象&#xff09;。item&#xff1a;指定在迭代过程中的每个元素的别名&#xff08;遍历…

vue2过渡vue3技术差异点指南

基础点 reactive() 定义响应式变量(仅仅引用类型有效&#xff1a;对象数组map&#xff0c;set)&#xff1a;reactive(),类似于data中return的数据 例子&#xff1a; import { reactive } from vueexport default {setup() {const state reactive({ count: 0 })function in…

Flask学习笔记_异步CMS(五)

Flask学习笔记_异步CMS&#xff08;五&#xff09; 1.环境1.安装nvm2.安装node 2.使用vue-cli创建项目3.安装相关插件4.后台CMS开发1.页面结构1.app.vue搭建结构2.element-icon组件的使用3.iconfont组件的使用 2.使用[Vue-router](https://router.vuejs.org/installation.html)…

OnlyOffice社区版破解最大连接限制部署

onlyoffice社区版部署并且破解最大连接数 docker镜像 docker pull onlyoffice/documentserver:5.3.1.265.4或更高的版本已经解决了此方法的Bug 运行镜像 docker run -d --name onlyoffice --restartalways -p 暴露端口号:80 onlyoffice/documentserver:5.3.1.26进入容器内部…

策略模式——算法的封装与切换

1、简介 1.1、概述 在软件开发中&#xff0c;常常会遇到这种情况&#xff0c;实现某一个功能有多条途径。每一条途径对应一种算法&#xff0c;此时可以使用一种设计模式来实现灵活地选择解决途径&#xff0c;也能够方便地增加新的解决途径。为了适应算法灵活性而产生的设计模…

Python faker 生成测试数据

pip install Faker faker官网 基本使用 from faker import Fakerif __name__ __main__:fake Faker()print(fake.name())print(fake.user_name())print(fake.phone_number())print(fake.address()) # 输出&#xff1a; Jorge Campbell grobbins 769.415.0562x2019 255 Broo…

[机器学习]线性回归模型

线性回归 线性回归&#xff1a;根据数据&#xff0c;确定两种或两种以上变量间相互依赖的定量关系 函数表达式&#xff1a; y f ( x 1 , x 2 . . . x n ) y f(x_1,x_2...x_n) yf(x1​,x2​...xn​) ​ 回归根据变量数分为一元回归[ y f ( x ) yf(x) yf(x)]和多元回归[ y …