【python-进阶】set和dict

2024-05-23 23:08
文章标签 python 进阶 set dict

本文主要是介绍【python-进阶】set和dict,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

6.1collections中的abc

6.2dict的常用方法
clear()
copy()#浅拷贝
使用的是同一个地址的值

深拷贝

import copy
new_d=copy.deepcopy(d)

此时使用的是不同的地址

fromkeys()
入参:可迭代的对象,如字典,元组,列表,字符串
出参:变换后的字典
例子:
d={‘a’:’1’,’b’:’2’}
dict.fromkeys(‘hi’,d)
pringt(d)
=>{‘h’:{‘a’:’1’,’b’:’2’},’i’:{‘a’:’1’,’b’:’2’}}

setdedault()
入参:key value
出参:新key的value值
例子:
print d.setdedault(‘c’,3)
=>3

update()
入参:需要添加的字典
出参:变更后的字典
例子:
d1={‘q’:2,’w’:3,’r’:4}
d.update(d1)
print d
=>{‘a’:’1’,’b’:’2’,’q’:2,’w’:3,’r’:4}

get()
根据key获取value值
6.3defaultdict
from collections import defaultdict

d = defaultdict(int)
v = d[‘a’] # 添加一个新key
print(v)
=>0 如果是int型,则空值为0

d = defaultdict(dict)
v = d[‘a’] # 添加一个新key
print(v)
=>{} 如果是int型,则空值为{}

原理是运用了一个魔方函数:miss()

6.4set和frozenset
set()
入参:是一个可迭代的对象
出参:是入参的一个无序的对象,用大括号{}包裹,而且是去重的
s=set(‘abcde’)
print s
=>{‘e’,’c’,’b’,’d’,’a’}

s=set([‘a’,’b’,’d’,’b’])
print s
=>{‘b’,’d’,’a’}

add()
clear()
copy()
update()
remove()
pop()

difference()# 集合的差集,原集合不变,返回一个新的集合,即差集
如下:
s={‘a’,’b’}
s1={‘a’}
diff_s = s.difference(s1)
print(diff_s)
=>{‘b’}
这个方法和ior()魔法函数相关
实际上和s-s1类似

交集:
s & s1

并集:
s | s1
set的性能很高,可以运用在去重操作中
由于有__contains__()魔法函数,可以用于if … in …的操作中

6.5dict和set的实现原理
dict查找的性能远远大于list
在list中随着list数据的增大,查找时间会增大
在dict中查找元素不会随着dict的增大而增大

dict背后的实现原理是哈希表

1、dict的key或者set的值,都必须是可以hash的
不可变对象,都是可hash的,如str,frozenset,tuple,自己实现类__hash__
2、dict的内存花销大,但是查询速度快,自定义对象或者python内部的对象都是dict包装的
3、dict的存储顺序和元素添加的顺序有关
4、添加数据可能会更改已有数据的顺序

这篇关于【python-进阶】set和dict的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/996674

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key:

poj 3050 dfs + set的妙用

题意: 给一个5x5的矩阵,求由多少个由连续6个元素组成的不一样的字符的个数。 解析: dfs + set去重搞定。 代码: #include <iostream>#include <cstdio>#include <set>#include <cstdlib>#include <algorithm>#include <cstring>#include <cm

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念