当前位置: 首页 > news >正文

【Python】数据容器:列表,元组,字符串,集合字典及通用操作

文章目录

  • 一.序列
    • 1.1list列表
      • 定义
      • 常用操作
      • 列表的遍历
    • 1.2tuple元组
      • 定义
      • 常见操作
      • 元组的遍历
    • 1.3str字符串
      • 定义
      • 常见操作
      • 字符串的遍历
    • 1.4序列常用操作——切片
  • 二.set集合
    • 定义
    • 常见操作
    • 集合的遍历
  • 三.dict字典
    • 定义
    • 常用操作
    • 字典的嵌套
  • *数据容器对比总结
  • 四.数据容器的通用操作
    • 4.1通用统计功能
    • 4.2通用转换功能
    • 4.3通用排序功能

我们首先来思考一个问题:如果我想要在程序中,记录5名学生的信息,如姓名。如何做呢?

在这里插入图片描述

学习数据容器,就是为了批量存储或批量使用多份数据

Python中的数据容器:

一种可以容纳多份数据的数据类型,容纳的每一份数据称之为一个元素。每一个元素,可以是任意类型的数据,如字符串、数字、布尔等。

数据容器根据特点的不同,如:

  • 是否支持重复元素
  • 是否可以修改
  • 是否有序

等分为5类,分别是:列表(list)、元组(tuple)、字符串(str)、集合(set)、字典(dict)

一.序列

序列是指:内容连续、有序,可使用下标索引的一类数据容器

列表、元组、字符串,均可以可以视为序列。

1.1list列表

定义

列表内的每一个数据,称之为元素

[ ] 作为标识

列表内每一个元素之间用, 逗号隔开

元素的数据类型没有任何限制,甚至元素也可以是列表,这样就定义了嵌套列表

# 字面量
[元素1,元素2,元素3,元素4, ...]# 定义变量
变量名称 = [元素1,元素2,元素3,元素4, ...]# 定义空变量
变量名称 = []
变量名称 = list()

演示代码:

# 字符串列表
name_list = ['green','yello','blue']
print(name_list)
print(type(name_list))# 各种类型列表
name_list = ['green','666','blue']
print(name_list)
print(type(name_list))# 嵌套列表
name_list = [['green'],['666'],['blue']]
print(name_list)
print(type(name_list))'''运行结果:
['green', 'yello', 'blue']
<class 'list'>
['green', '666', 'blue']
<class 'list'>
[['green'], ['666'], ['blue']]
<class 'list'>'''

列表的下标索引

①如图,列表中的每一个元素,都有其位置下标索引,从前向后的方向,从0开始,依次递增

在这里插入图片描述

我们只需要按照下标索引,即可取得对应位置的元素。

②或者,可以反向索引,如图,从后向前,下标索引为:-1、-2、-3,依次递减。

在这里插入图片描述

③如果列表是嵌套的列表,同样支持下标索引

在这里插入图片描述

演示代码:

# 正向索引
name_list = ['green','yello','blue']
print(name_list[0])
print(name_list[1])
print(name_list[2])# 反向索引
name_list = ['green','yello','blue']
print(name_list[-1])
print(name_list[-2])
print(name_list[-3])# 嵌套索引
name_list = [[1,2,3],[4,5],[6,7,8]]
print(name_list[0][0])
print(name_list[-2][-1])
print(name_list[-3][2])'''运行结果:
green
yello
blue
blue
yello
green
1
5
3
'''

要注意下标索引的取值范围,超出范围无法取出元素,并且会报错。

常用操作

在这里插入图片描述

查找

【功能】:查找指定元素在列表的下标,如果找不到,报错ValueError

【语法】:列表.index(元素)

index就是列表对象(变量)内置的方法(函数)

如果被查找的元素不存在,会报错

修改

【功能】:修改特定位置(索引)的元素值

【语法】:列表[下标]=值

可以使用如上语法,直接对指定下标(正向,反向下标均可)的值进行:重新赋值

插入

【功能】:在指定的下标位置,插入指定的元素

【语法】:列表.insert(下标,元素)

追加

【功能】:将指定元素,追加到列表的尾部

【语法】:列表.append(元素)

追加一批元素->列表.extend(其他数据容器)

索引删除

【语法1】:del 列表[下标]

【语法1】:列表.pop(下标),同时可以把删除的元素作为返回值去得到

指定内容删除

【语法】:列表.remove(元素)

从前到后搜索,只能删掉一个指定内容的元素

清空列表

【语法】:列表.clear()

统计

【语法】:列表.count(元素)

【功能】:统计某元素在列表中数量

【语法】:len(列表)

【功能】:统计列表内有多少元素

代码示例

name_list = ['green','yello','blue']
# 查找
index = name_list.index("yello")
print(f"yello在列表中的下标索引值是:{index}")
# 修改
name_list[0] = "修改"
print(f"列表被修改元素值后,输出结果是:{name_list}")
# 插入
name_list.insert(1,'插入')
print(f"列表插入元素后,结果是:{name_list}")
# 追加
name_list.append('追加')
print(f"列表追加元素后,结果是:{name_list}")
# 追加一批元素
name_list.extend([1,1,3])
print(f"列表追加一个新的列表后,结果是:{name_list}")
# 删除
del name_list[0]
print(f"列表删除元素后,结果是:{name_list}")
element = name_list.pop(0)
print(f"通过pop取出元素后,结果是:{name_list},取出的元素是{element}")
# 指定内容删除
name_list.remove('追加')
print(f"列表删除指定内容元素后,结果是:{name_list}")
# 统计
count = name_list.count(1)
print(f"列表中1的数量是:{count}")
num = len(name_list)
print(f"列表中的元素数量是:{num}")
# 清空
name_list.clear()
print(f"列表被清空了,结果是:{name_list}")'''运行结果:
yello在列表中的下标索引值是:1
列表被修改元素值后,输出结果是:['修改', 'yello', 'blue']
列表插入元素后,结果是:['修改', '插入', 'yello', 'blue']
列表追加元素后,结果是:['修改', '插入', 'yello', 'blue', '追加']
列表追加一个新的列表后,结果是:['修改', '插入', 'yello', 'blue', '追加', 1, 1, 3]
列表删除元素后,结果是:['插入', 'yello', 'blue', '追加', 1, 1, 3]
通过pop取出元素后,结果是:['yello', 'blue', '追加', 1, 1, 3],取出的元素是插入
列表删除指定内容元素后,结果是:['yello', 'blue', 1, 1, 3]
列表中1的数量是:2
列表中的元素数量是:5
列表被清空了,结果是:[]Process finished with exit code 0
'''

总结列表的特点

  • 可以容纳多个元素(上限为 2**63-1 、9223372036854775807个)
  • 可以容纳不同类型的元素(混装)
  • 数据是有序存储的(有下标序号)
  • 允许重复数据存在
  • 可以修改(增加或删除元素等)

列表的遍历

既然数据容器可以存储多个元素,那么,就会有需求从容器内依次取出元素进行操作。

将容器内的元素依次取出进行处理的行为,称之为:遍历、迭代

  • while循环
# 定义一个变量来标记列表的下标
index = 0     # 初始值为0
while index < len(列表):   # 循环条件为:下标值<列表的元素数量元素 = 列表[index]对元素进行处理index += 1
  • for循环

对比while,for循环更加适合对列表等数据容器进行遍历

for 临时变量 in 数据容器 :对临时变量进行处理

for循环和while对比

while循环和for循环,都是循环语句,但细节不同:

  1. 在循环控制上:
    ·white循环可以自定循环条件,并自行控制
    ·for循环不可以自定循环条件,只可以一个个从容器内取出数据

  2. 在无限循环上:
    ·while福环可以通过条件控制做到无限循环

    ·for循环理伦上不可以,因为被遍历的容器容量不是无限的

  3. 在使用场景上:
    while循环适用于任何想要循环的场景
    for循环适用于,遍历数据容器的场景或简单的因定次数循环场景

【代码示例】

# 使用while循环遍历列表
def list_while_func():my_list = ["blue", "yello", "green"]# 定义一个变量来标记列表的下标index = 0  # 初始值为0while index < len(my_list):# 通过index变量取出对应下标的元素element = my_list[index]print(f"列表的元素:{element}")index += 1
list_while_func()#使用for循环遍历列表
def list_for_func():my_list = [1,2,3,4,5]for element in my_list:print(f"列表元素有:{element}")
list_for_func()'''运行结果:
列表的元素:blue
列表的元素:yello
列表的元素:green
列表元素有:1
列表元素有:2
列表元素有:3
列表元素有:4
列表元素有:5'''

列表是可以修改的,如果想要传递的信息不被纂改,那么元组来啦~

1.2tuple元组

定义

元组一旦定义完成,就不可修改

元组定义:定义元组使用小括号,且使用逗号隔开各个数据,数据可以是不同的数据类型。

#定义元组字面量
(元素,元素,......,元素)#定义元组数=变量
变量名称 = (元素,元素,...... ,元素)#定义空元组
变量名称 = ()          #方式一
变量名称 = tuple()     #方式二

注:

1、元组只有一个数据时,这个数据后面要添加逗号,否则不是元组类型!

2、元组也支持嵌套

代码示例:

t1 = (1,"Hello",True)
t2 = ()
t3 = tuple ()
t4 = (1,)
t5 = ((4,5,6),(8,9))
print(f"t1的类型是:{type(t1)},内容是:{t1}")
print(f"t2的类型是:{type(t2)},内容是:{t2}")
print(f"t3的类型是:{type(t3)},内容是:{t3}")
print(f"t4的类型是:{type(t4)},内容是:{t4}")
print(f"t5的类型是:{type(t5)},内容是:{t5}")'''运行结果:
t1的类型是:<class 'tuple'>,内容是:(1, 'Hello', True)
t2的类型是:<class 'tuple'>,内容是:()
t3的类型是:<class 'tuple'>,内容是:()
t4的类型是:<class 'tuple'>,内容是:(1,)
t5的类型是:<class 'tuple'>,内容是:((4, 5, 6), (8, 9))'''

元组的下标索引

同列表,示例:

t5 = ((4,5,6),(8,9))
num = t5[1][0]
'''运行结果:
8'''

常见操作

在这里插入图片描述

元组由于不可修改的特性,所以其操作方法非常少。

元组的三种方法和列表相对应的这三种方法操作一致。

元组的遍历

元组同样支持while循环和for循环的遍历操作

用法和列表遍历一致

总结元组的特点

• 可以容纳多个数据

• 可以容纳不同类型的数据(混装)

• 数据是有序存储的(下标索引)

• 允许重复数据存在

不可以修改 (增加或删除元素等),但如果元组中嵌套的有列表,那么列表中的元素可以修改(列表list的本质没有改变,所以不违背元组不可以修改的原则)

• 支持for循环

1.3str字符串

定义

字符串是字符的容器,一个字符串可以存放任意数量的字符

字符串的下标索引

和其它容器如:列表、元组一样,字符串也可以通过下标进行访问

• 从前向后,下标从 0 开始

• 从后向前,下标从 -1 开始

【代码示例】

my_str = "abcdefg"
value1 = my_str[2]
value2 = my_str[-3]
print(f"从字符串中取下标为2的元素值是{value1},下标为-3的元素值是{value2}")'''运行结果:
从字符串中取下标为2的元素值是c,下标为-3的元素值是e'''

常见操作

在这里插入图片描述

同元组一样,字符串是一个:无法修改的数据容器。

字符串的替换

【功能】:将字符串内的全部:字符串1,替换为字符串2

【语法】:字符串.replace(字符串1,字符串2)

注意:不是修改字符串本身,而是得到了一个新字符串

字符串的分割

【功能】:按照指定的分隔符字符串,将字符串划分为多个字符串,并存入列表对象中

【语法】:字符串.split(分隔符字符串)

注意:字符串本身不变,而是得到了一个列表对象

字符串的规整操作

【功能】:去前后空格

【语法】:```字符串.strip()``

【功能】:去前后指定字符串

【语法】:```字符串.strip(字符串)``

注意:传入的是"12",其实就是:"1"和"2"都会移除,是按照单个字符

查找

【功能】:查找给定字符的第一个匹配项的下标

【语法】:字符串.index(字符串)

代码示例

# 查找
str = "mountain and sea"
value = str.index("and")
print(f"在字符串{str}中查找“and”,其起始下标是{value}")# 替换
str = "itmountain and itsea"
new_str = str.replace("it","程序")
print(f"将字符串 {str},进行替换得到 {new_str}")# 分割
my_str = "hello python itCSDN itlove"
my_str_list = my_str.split(" ")
print(f"将字符串{my_str}进行split切分后得到:{my_str_list}, 类型是:{type(my_str_list)}")# 规整操作
my_str = "  itCSDN and itlove  "
new_my_str = my_str.strip() # 不传入参数,去除首尾空格
print(f"字符串{my_str}被strip后,结果:{new_my_str}")
my_str = "12itCSDN and itlove21"
new_my_str = my_str.strip("12")
print(f"字符串{my_str}被strip('12')后,结果:{new_my_str}")# 统计
my_str = "itCSDN and itlove"
count = my_str.count("it")
print(f"字符串{my_str}中it出现的次数是:{count}")
my_str = "itCSDN and itlove"
num = len(my_str)
print(f"字符串{my_str}的长度是:{num}")'''运行结果:
在字符串mountain and sea中查找“and”,其起始下标是9
将字符串 itmountain and itsea,进行替换得到 程序mountain and 程序sea
将字符串hello python itCSDN itlove进行split切分后得到:['hello', 'python', 'itCSDN', 'itlove'], 类型是:<class 'list'>
字符串  itCSDN and itlove  被strip后,结果:itCSDN and itlove
字符串12itCSDN and itlove21被strip('12')后,结果:itCSDN and itlove
字符串itCSDN and itlove中it出现的次数是:2
字符串itCSDN and itlove的长度是:17
'''

字符串的遍历

同列表,元组一样

总结元组的特点

作为数据容器,字符串有如下特点:

只可以存储字符串

• 长度任意(取决于内存大小)

• 支持下标索引

• 允许重复字符串存在

不可以修改 (增加或删除元素等

• 支持for循环

1.4序列常用操作——切片

序列支持切片,即:列表、元组、字符串,均支持进行切片操作

切片:从一个序列中,取出一个子序列

【语法】:序列[起始下标:结束下标:步长]

表示从序列中,从指定位置开始,依次取出元素,到指定位置结束,得到一个新序列:

• 起始下标表示从何处开始,可以留空,留空视作从头开始

• 结束下标(不含)表示何处结束,可以留空,留空视作截取到结尾

• 步长表示,依次取元素的间隔,默认为1:步长 1 表示,一个个取元素;步长 2 表示,每次跳过1个元素取;步长 N表示,每次跳过N-1 个元素取

• 步长为负数表示,反向取(注意,起始下标和结束下标也要反向标记)

注意. 此操作不会影响序列本身,而是会得到一个新的序列(列表、元组、字符串)

# 对List进行切片,从1开始,4结束,步长1
my_List = [0,1,2,3,4,5,6]
result1 = my_List[1:4]   # 步长默认是1,所以可以省略不写
print(f"结果1:{result1}")
result6 = my_List[3:1:-1]   # 步长默认是1,所以可以省略不写
print(f"结果6:{result6}")# 对tuple进行切片,从头开始,到最后结束,步长1
my_tuple = (0,1,2,3,4,5,6)
result2 = my_tuple[:]   # 起始和结束不写表示从头到尾,步长为1可以省略
print(f"结果2:{result2}")
result5 = my_tuple[::-2]
print(f"结果5:{result5}")# 对str进行切片,从头开始,到最后结束,步长2
my_str = "01234567"
result3 = my_str[::2]
print(f"结果3:{result3}")
result4 = my_str[::-1]
print(f"结果4:{result4}")'''运行结果:
结果1:[1, 2, 3]
结果6:[3, 2]
结果2:(0, 1, 2, 3, 4, 5, 6)
结果5:(6, 4, 2, 0)
结果3:0246
结果4:76543210
'''

总结

  • 列表可修改,支持重复元素且有序
  • 元组,字符串不可修改,支持重复元素且有序

序列这三种数据容器基本可以满足大多数使用场景,但是它们存在局限:都支持重复元素。如果场景需要对内容做去重处理,就不方便了,那么集合来啦~

二.set集合

定义

• 集合内不允许重复元素(去重)

• 集合内元素是无序的(不支持下标索引)

# 定义集合字面量
{元素,元素,.... ,元素}
# 定义集合变量
变量名称 = {元素,元素,.... ,元素}
# 定义空集合
变量名称 = set()

结合集合特点进行代码演示:

my_set_empty = set()        # 定义空集合
print(f"my_set_empty的内容是:{my_set_empty}, 类型是:{type(my_set_empty)}")
my_set = {"CSDN程序员社区", "CSDN灌水乐园", "itCSDN", "CSDN灌水乐园", "CSDN程序员社区", "itCSDN"}
print(f"my_set的内容是:{my_set}, 类型是:{type(my_set)}")'''运行结果:
my_set_empty的内容是:set(), 类型是:<class 'set'>
my_set的内容是:{'itCSDN', 'CSDN灌水乐园', 'CSDN程序员社区'}, 类型是:<class 'set'>'''

常见操作

首先,因为集合是无序的,所以集合不支持下标索引访问

但是结合和列表一样,是允许修改的,所以我们来看看集合的修改方法——

在这里插入图片描述

添加新元素

【语法】:集合.add(元素),将指定元素添加到集合内

结果:结合本身被修改,添加了新元素

移除元素

【语法】:集合.remove(元素),将指定元素,从集合内移除

结果:集合本身被修改,移除了元素

随机取出元素

【语法】:集合.pop(),从集合中随机取出一个元素

结果:会得到一个元素的结果,同时集合本身被修改,元素被移除

清空集合

【语法】:集合.clear(),清空集合

结果:集合本身被清空

取出两个集合的差集

【语法】:集合1.difference(集合2),取出集合1和集合2的差集(集合1有二集合2没有的)

结果:得到一个新集合,集合1和集合2不变

消除差集

【语法】:集合1.difference_update(集合2),对比集合1和集合2相同的元素

结果::集合1被修改,集合2不变

两个集合合并

【语法】:集合1.union(集合2),将集合1和集合2组合成新集合

结果:得到新集合,集合1和集合2不变

【代码示例】

# 添加新元素
my_set = {"blue", "green", "pink"}
my_set.add("purple")
my_set.add("pink")
print(f"my_set添加元素后结果是:{my_set}")# 移除元素
my_set.remove("green")
print(f"my_set移除green后,结果是:{my_set}")# 随机取出元素
my_set.pop()
print(f"my_set随机取出元素后,结果是:{my_set}")# 清空集合
my_set.clear()
print(f"my_set清空集合后,结果是:{my_set}")# 取两个集合的差集
set1 = {1,2,3}
set2 = {1,4,5,6}
set3 = set1.difference(set2)
print(f"取差集后,原有set1的内容:{set1}")
print(f"取差集后,原有set2的内容:{set2}")# 消除差集
set1 = {1,2,3}
set2 = {1,4,5,6}
set3 = set1.difference_update(set2)
print(f"消除差集后,原有set1的内容:{set1}")
print(f"消除差集后,原有set2的内容:{set2}")
print(f"消除差集后的集合3是:{set3}")# 两个集合合并
set1 = {1,2,3}
set2 = {1,4,5,6}
set3 = set1.union(set2)
print(f"合并后,原有set1的内容:{set1}")
print(f"合并后,原有set2的内容:{set2}")
print(f"合并后的集合3是:{set3}")# 统计集合的元素数量
set1 = {1,2,3}
set2 = {1,2,3,1,2,3}
num1 = len(set1)
num2 = len(set2)
print(f"集合1内的元素数量有:{num1}个")
print(f"集合2内的元素数量有:{num2}个")'''运行结果:
my_set添加元素后结果是:{'pink', 'purple', 'green', 'blue'}
my_set移除green后,结果是:{'pink', 'purple', 'blue'}
my_set随机取出元素后,结果是:{'purple', 'blue'}
my_set清空集合后,结果是:set()
取差集后,原有set1的内容:{1, 2, 3}
取差集后,原有set2的内容:{1, 4, 5, 6}
消除差集后,原有set1的内容:{2, 3}
消除差集后,原有set2的内容:{1, 4, 5, 6}
消除差集后的集合3是:None
合并后,原有set1的内容:{1, 2, 3}
合并后,原有set2的内容:{1, 4, 5, 6}
合并后的集合3是:{1, 2, 3, 4, 5, 6}
集合1内的元素数量有:3个
集合2内的元素数量有:3个'''

集合的遍历

因为集合是无序的,不支持下标索引,所以不可以使用while循环遍历,用for循环遍历

# 集合的遍历
set1 = {1,2,3,4,5}
for element in set1:print(f"集合的元素有:{element}")'''运行结果:
集合的元素有:1
集合的元素有:2
集合的元素有:3
集合的元素有:4
集合的元素有:5'''

总结集合的特点

• 可以容纳多个数据

• 可以容纳不同类型的数据(混装)

数据是无序存储的(不支持下标索引)

不允许重复数据存在

• 可以修改 (增加或删除元素等)

• 支持for循环

三.dict字典

定义

通过 key 找出对应的 value

在这里插入图片描述
qa4tRBmD-1736684061659)

字典的定义,同样使用{},不过存储的元素是一个个的:键值对:key,:,value三者结合被称为键值对,如下语法:

# 定义字典字面量
{key : value , key value : value ,....,key : value}
# 定义字典字面量
my_dict = {key : value , key :value , ....,key :value}
# 定义空字典
my_dict = {}     # 空字典定义方式1
my_dict = dict() # 空字典定义方式2

• 使用 {} 存储原始,每一个元素是一个键值对

• 每一个键值对包含 Key 和 Value (用冒号分隔)

• 键值对之间使用逗号分隔

• Key 和 Value 可以是任意类型的数据key 不可为字典

• Key 不可重复,重复会对原有数据覆盖

•字典不可用下标索引,而是通过Key检索Value

【代码示例】

# 定义字典
my_dict1 = {"王力鸿": 99, "周杰轮": 88, "林俊节": 77}
# 定义空字典
my_dict2 = {}
my_dict3 = dict()
print(f"字典1的内容是:{my_dict1}, 类型:{type(my_dict1)}")
print(f"字典2的内容是:{my_dict2}, 类型:{type(my_dict2)}")
print(f"字典3的内容是:{my_dict3}, 类型:{type(my_dict3)}")'''运行结果:
字典1的内容是:{'王力鸿': 99, '周杰轮': 88, '林俊节': 77}, 类型:<class 'dict'>
字典2的内容是:{}, 类型:<class 'dict'>
字典3的内容是:{}, 类型:<class 'dict'>'''

常用操作

字典同集合一样,不可以使用下标索引

但是字典可以通过Key值来取得对应的Value

【代码示例】

# 从字典中基于Key获取Value
my_dict1 = {"王力鸿": 99, "周杰轮": 88, "林俊节": 77}
score = my_dict1["王力鸿"]
print(f"王力鸿的考试分数是:{score}")
score = my_dict1["周杰轮"]
print(f"周杰轮的考试分数是:{score}")'''运行结果:
王力鸿的考试分数是:99
周杰轮的考试分数是:88'''

在这里插入图片描述
新增元素

【语法】:字典[Key] = Value

结果:字典被修改,新增了元素

更新元素

【语法】:字典[Key] = Value

结果:字典被修改,元素被更新

注意:字典Key不可以重复,所以对已存在的Key执行上述操作,就是更新Value值

删除元素

【语法】:字典.pop(Key)

结果:获得指定Key的Value,同时字典被修改,指定Key的数据被删除

清空字典

【语法】:字典.clear()

结果:字典被修改,元素被清空

获取全部Key

【语法】:字典.Keys()

结果:得到字典中全部的Key

计算字典中元素数量

【语法】:len.(字典)


【代码示例】

# 从字典中基于Key获取Value
my_dict = {"王力鸿": 99, "周杰轮": 88, "林俊节": 77}
score = my_dict["王力鸿"]
print(f"王力鸿的考试分数是:{score}")
score = my_dict["周杰轮"]
print(f"周杰轮的考试分数是:{score}")# 新增元素
my_dict["张信哲"] = 66
print(f"字典经过新增元素后,结果:{my_dict}")
#更新元素
my_dict["周杰轮"] = 33
print(f"字典经过更新后,结果:{my_dict}")# 删除元素
my_dict = {"周杰轮": 99, "林俊节": 88, "张学油": 77}
score = my_dict.pop("周杰轮")
print(f"字典中被移除了一个元素,结果:{my_dict}, 周杰轮的考试分数是:{score}")# 清空字典
my_dict = {"周杰轮": 99, "林俊节": 88, "张学油": 77}
my_dict.clear()
print(f"字典被清空了,内容是:{my_dict}")# 获取字典中全部的Key
my_dict = {"周杰轮": 99, "林俊节": 88, "张学油": 77}
keys = my_dict.keys()
print(f"字典的全部keys是:{keys}")
# 遍历字典
# 方式1:通过获取到全部的key来完成遍历
for key in keys:print(f"字典的key是:{key}")print(f"字典的value是:{my_dict[key]}")# 计算字典中的元素数量
my_dict = {"周杰轮": 99, "林俊节": 88, "张学油": 77}
num = len(my_dict)
print(f"字典中的元素数量有:{num}个")'''运行结果:
王力鸿的考试分数是:99
周杰轮的考试分数是:88
字典经过新增元素后,结果:{'王力鸿': 99, '周杰轮': 88, '林俊节': 77, '张信哲': 66}
字典经过更新后,结果:{'王力鸿': 99, '周杰轮': 33, '林俊节': 77, '张信哲': 66}
字典中被移除了一个元素,结果:{'林俊节': 88, '张学油': 77}, 周杰轮的考试分数是:99
字典被清空了,内容是:{}
字典的全部keys是:dict_keys(['周杰轮', '林俊节', '张学油'])
字典的key是:周杰轮
字典的value是:99
字典的key是:林俊节
字典的value是:88
字典的key是:张学油
字典的value是:77
字典中的元素数量有:3个
'''

字典的嵌套

字典的Key和Value可以是任意数据类型(Key不可为字典)

那么,就表明,字典是可以嵌套的。

方法①:通过获取到全部的key来遍历完成

my_dict = {"周杰轮": 99, "林俊节": 88, "张学油": 77}
keys = my_dict.keys()
print(f"字典的全部keys是:{keys}")
# 遍历字典
# 方式1:通过获取到全部的key来完成遍历
for key in keys:print(f"字典的key是:{key}")print(f"字典的value是:{my_dict[key]}")'''运行结果:
字典的全部keys是:dict_keys(['周杰轮', '林俊节', '张学油'])
字典的key是:周杰轮
字典的value是:99
字典的key是:林俊节
字典的value是:88
字典的key是:张学油
字典的value是:77
'''

方法②:直接对字典进行for循环,每一次循环都是直接得到key

my_dict = {"周杰轮": 99, "林俊节": 88, "张学油": 77}
for key in my_dict:print(f"字典的key是:{key}")print(f"字典的value是:{my_dict[key]}")'''运行结果:
字典的key是:周杰轮
字典的value是:99
字典的key是:林俊节
字典的value是:88
字典的key是:张学油
字典的value是:77
'''

总结字典的特点

• 可以容纳多个数据

• 可以容纳不同类型的数据

每一份数据是 KeyValue 键值对

可以通过 Key 获取到 Value , Key 不可重复(重复会覆盖)

• 不支持下标索引

• 可以修改 (增加或删除更新元素等)

• 支持for循环,不支持 while 循环

*数据容器对比总结

在这里插入图片描述

• 列表使用: []

• 元组使用: ()

• 字符串使用:“”

• 集合使用: {}

•字典使用:{}和键值对

遍历方式不同:

  • 5类数据容器都支持for循环遍历
  • 列表,元组,字符串支持while循环,集合,字典不支持(无法下标索引)

四.数据容器的通用操作

4.1通用统计功能

在这里插入图片描述

【代码示例】

my_list = [1, 2, 3, 4, 5]
my_tuple = (1, 2, 3, 4, 5)
my_str = "abcdefg"
my_set = {1, 2, 3, 4, 5}
my_dict = {"key1": 1, "key2": 2, "key3": 3, "key4": 4, "key5": 5}# len元素个数
print(f"列表 元素个数有:{len(my_list)}")
print(f"元组 元素个数有:{len(my_tuple)}")
print(f"字符串元素个数有:{len(my_str)}")
print(f"集合 元素个数有:{len(my_set)}")
print(f"字典 元素个数有:{len(my_dict)}")# max最大元素
print(f"列表 最大的元素是:{max(my_list)}")
print(f"元组 最大的元素是:{max(my_tuple)}")
print(f"字符串最大的元素是:{max(my_str)}")
print(f"集合 最大的元素是:{max(my_set)}")
print(f"字典 最大的元素是:{max(my_dict)}")# min最小元素
print(f"列表 最小的元素是:{min(my_list)}")
print(f"元组 最小的元素是:{min(my_tuple)}")
print(f"字符串最小的元素是:{min(my_str)}")
print(f"集合 最小的元素是:{min(my_set)}")
print(f"字典 最小的元素是:{min(my_dict)}")'''运行结果:
列表 元素个数有:5
元组 元素个数有:5
字符串元素个数有:7
集合 元素个数有:5
字典 元素个数有:5
列表 最大的元素是:5
元组 最大的元素是:5
字符串最大的元素是:g
集合 最大的元素是:5
字典 最大的元素是:key5
列表 最小的元素是:1
元组 最小的元素是:1
字符串最小的元素是:a
集合 最小的元素是:1
字典 最小的元素是:key1'''

4.2通用转换功能

在这里插入图片描述

【代码示例】

my_list = [1, 2, 3, 4, 5]
my_tuple = (1, 2, 3, 4, 5)
my_str = "abcdefg"
my_set = {1, 2, 3, 4, 5}
my_dict = {"key1": 1, "key2": 2, "key3": 3, "key4": 4, "key5": 5}# 类型转换: 容器转列表
print(f"元组转列表的结果是:{list(my_tuple)}")
print(f"字符串转列表结果是:{list(my_str)}")
print(f"集合转列表的结果是:{list(my_set)}")
print(f"字典转列表的结果是:{list(my_dict)}")# 类型转换: 容器转元组
print(f"列表转元组的结果是:{tuple(my_list)}")
print(f"字符串转元组结果是:{tuple(my_str)}")
print(f"集合转元组的结果是:{tuple(my_set)}")
print(f"字典转元组的结果是:{tuple(my_dict)}")# 类型转换: 容器转字符串
print(f"列表转字符串的结果是:{str(my_list)}")
print(f"元组转字符串的结果是:{str(my_tuple)}")
print(f"集合转字符串的结果是:{str(my_set)}")
print(f"字典转字符串的结果是:{str(my_dict)}")# 类型转换: 容器转集合
print(f"列表转集合的结果是:{set(my_list)}")
print(f"元组转集合的结果是:{set(my_tuple)}")
print(f"字符串转集合结果是:{set(my_str)}")
print(f"字典转集合的结果是:{set(my_dict)}")'''运行结果:
元组转列表的结果是:[1, 2, 3, 4, 5]
字符串转列表结果是:['a', 'b', 'c', 'd', 'e', 'f', 'g']
集合转列表的结果是:[1, 2, 3, 4, 5]
字典转列表的结果是:['key1', 'key2', 'key3', 'key4', 'key5']
列表转元组的结果是:(1, 2, 3, 4, 5)
字符串转元组结果是:('a', 'b', 'c', 'd', 'e', 'f', 'g')
集合转元组的结果是:(1, 2, 3, 4, 5)
字典转元组的结果是:('key1', 'key2', 'key3', 'key4', 'key5')
列表转字符串的结果是:[1, 2, 3, 4, 5]
元组转字符串的结果是:(1, 2, 3, 4, 5)
集合转字符串的结果是:{1, 2, 3, 4, 5}
字典转字符串的结果是:{'key1': 1, 'key2': 2, 'key3': 3, 'key4': 4, 'key5': 5}
列表转集合的结果是:{1, 2, 3, 4, 5}
元组转集合的结果是:{1, 2, 3, 4, 5}
字符串转集合结果是:{'c', 'b', 'd', 'a', 'f', 'e', 'g'}
字典转集合的结果是:{'key1', 'key5', 'key2', 'key3', 'key4'}
'''

4.3通用排序功能

在这里插入图片描述

【语法】:sorted(容器,[reverse = True]),将给定的容器进行排序

# 进行容器的排序
my_list = [3, 1, 2, 5, 4]
my_tuple = (3, 1, 2, 5, 4)
my_str = "bdcefga"
my_set = {3, 1, 2, 5, 4}
my_dict = {"key3": 1, "key1": 2, "key2": 3, "key5": 4, "key4": 5}# 正序排序
print(f"列表对象的排序结果:{sorted(my_list)}")
print(f"元组对象的排序结果:{sorted(my_tuple)}")
print(f"字符串对象的排序结果:{sorted(my_str)}")
print(f"集合对象的排序结果:{sorted(my_set)}")
print(f"字典对象的排序结果:{sorted(my_dict)}")# 逆序排序
print(f"列表对象的反向排序结果:{sorted(my_list, reverse=True)}")
print(f"元组对象的反向排序结果:{sorted(my_tuple, reverse=True)}")
print(f"字符串对象反向的排序结果:{sorted(my_str, reverse=True)}")
print(f"集合对象的反向排序结果:{sorted(my_set, reverse=True)}")
print(f"字典对象的反向排序结果:{sorted(my_dict, reverse=True)}")'''运行结果:
列表对象的排序结果:[1, 2, 3, 4, 5]
元组对象的排序结果:[1, 2, 3, 4, 5]
字符串对象的排序结果:['a', 'b', 'c', 'd', 'e', 'f', 'g']
集合对象的排序结果:[1, 2, 3, 4, 5]
字典对象的排序结果:['key1', 'key2', 'key3', 'key4', 'key5']
列表对象的反向排序结果:[5, 4, 3, 2, 1]
元组对象的反向排序结果:[5, 4, 3, 2, 1]
字符串对象反向的排序结果:['g', 'f', 'e', 'd', 'c', 'b', 'a']
集合对象的反向排序结果:[5, 4, 3, 2, 1]
字典对象的反向排序结果:['key5', 'key4', 'key3', 'key2', 'key1']
'''

相关文章:

【Python】数据容器:列表,元组,字符串,集合字典及通用操作

文章目录 一.序列1.1list列表定义常用操作列表的遍历 1.2tuple元组定义常见操作元组的遍历 1.3str字符串定义常见操作字符串的遍历 1.4序列常用操作——切片 二.set集合定义常见操作集合的遍历 三.dict字典定义常用操作字典的嵌套 *数据容器对比总结四.数据容器的通用操作4.1通…...

Wi-Fi Direct (P2P)原理及功能介绍

目录 Wi-Fi Direct &#xff08;P2P&#xff09;介绍Wi-Fi Direct P2P 概述P2P-GO&#xff08;P2P Group Owner&#xff09;工作流程 wifi-Direct使用windows11 wifi-directOpenwrtwifi的concurrent mode Linux环境下的配置工具必联wifi芯片P2P支持REF Wi-Fi Direct &#xff…...

系统看门狗配置--以ubuntu为例

linux系统配置看门狗 以 ubuntu 系统配置看门狗为例 配置看门狗使用的脚本文件&#xff0c;需要使用管理员权限来执行&#xff1a; 配置是&#xff1a;系统每 30S 喂一次狗&#xff0c;超过 60S 不进行投喂&#xff0c;就会自动重启。 1. 系统脚本内容&#xff1a; #!/bin/b…...

Mysql--基础篇--多表查询(JOIN,笛卡尔积)

在MySQL中&#xff0c;多表查询&#xff08;也称为联表查询或JOIN操作&#xff09;是数据库操作中非常常见的需求。通过多表查询&#xff0c;你可以从多个表中获取相关数据&#xff0c;并根据一定的条件将它们组合在一起。MySQL支持多种类型的JOIN操作&#xff0c;每种JOIN都有…...

44_Lua迭代器

在Lua中,迭代器是一种用于遍历集合元素的重要工具。掌握迭代器的使用方法,对于提高Lua编程的效率和代码的可读性具有重要意义。 1.迭代器概述 1.1 迭代器介绍 迭代器是一种设计模式,它提供了一种访问集合元素的方法,而不需要暴露其底层结构。在Lua中,迭代器通常以一个函…...

网络原理(三)—— 传输层 之 UDP 和 TCP协议

传输层 在传输层两大关键的协议就是UDP和TCP协议了&#xff0c;除此之外&#xff0c;还有别的传输层协议&#xff0c;本文章将介绍UDP和TCP协议&#xff0c;重点介绍TCP协议。 首先回顾TCP和UDP 的特点&#xff1a; UDP&#xff1a;不可靠传输&#xff0c;面向数据包&#xf…...

Swin Transformer模型详解(附pytorch实现)

写在前面 Swin Transformer&#xff08;Shifted Window Transformer&#xff09;是一种新颖的视觉Transformer模型&#xff0c;在2021年由微软亚洲研究院提出。这一模型提出了一种基于局部窗口的自注意力机制&#xff0c;显著改善了Vision Transformer&#xff08;ViT&#xf…...

opencv进行人脸识别环境搭建

1. 构建人脸识别环境 1) 下载安装opencv 下载地址&#xff1a;Releases - OpenCV 参考博文&#xff1a;OpenCV下载安装教程&#xff08;Windows&#xff09;-CSDN博客 下载对应系统的opencv&#xff0c;如windows版&#xff0c;opencv-4.5.5-vc14_vc15.exe 2) 然后解压缩到…...

java小灶课详解:关于char和string的区别和对应的详细操作

char和string的区别与操作详解 在编程语言中&#xff0c;char和string是用于处理字符和字符串的两种重要数据类型。它们在存储、操作和应用场景上存在显著差异。本文将从以下几个方面详细解析两者的区别及常见操作。 1. 基本定义与存储差异 char&#xff1a; 定义&#xff1a;…...

计算机网络之---RIP协议

RIP协议的作用 RIP (Routing Information Protocol) 协议是一个基于距离矢量的路由协议&#xff0c;它在网络中用来动态地交换路由信息。RIP 是最早的路由协议之一&#xff0c;通常用于小型和中型网络中。它的工作原理简单&#xff0c;易于实现&#xff0c;但在一些大型网络中效…...

F#语言的文件操作

F#语言的文件操作 F#是一种功能性编程语言&#xff0c;运行在.NET平台上&#xff0c;特别适合处理并发和复杂的数据处理任务。在这篇文章中&#xff0c;我们将介绍F#语言中的文件操作&#xff0c;包括读取、写入和管理文件的基本方法。通过实例来帮助理解&#xff0c;适合初学…...

微信小程序开发设置支持scss文件

在微信小程序开发中&#xff0c;默认是不支持scss文件的&#xff0c;创建文件的时候&#xff0c;css文件默认创建的是wxss后缀结尾的&#xff0c;但是用习惯了scss的怎么办呢&#xff1f; 首先找到project.config.json文件&#xff0c;打开文件在setting下设置useCompilerPlug…...

【Excel笔记_3】execl的单元格是#DIV/0!,判断如果是这个,则该单元格等于空

在 Excel 中&#xff0c;可以使用 IF 函数来判断单元格是否是 #DIV/0! 错误&#xff0c;并将其替换为空值&#xff08;即空字符串 ""&#xff09;。具体公式如下&#xff1a; IF(ISERROR(A1), "", A1)或者&#xff0c;如果只想判断 #DIV/0! 错误&#xff…...

51单片机入门基础

目录 一、基础知识储备 &#xff08;一&#xff09;了解51单片机的基本概念 &#xff08;二&#xff09;掌握数字电路基础 &#xff08;三&#xff09;学习C语言编程基础 二、开发环境搭建 &#xff08;一&#xff09;硬件准备 &#xff08;二&#xff09;软件准备 三、…...

设计模式 行为型 访问者模式(Visitor Pattern)与 常见技术框架应用 解析

访问者模式&#xff08;Visitor Pattern&#xff09;是一种行为设计模式&#xff0c;它允许你在不改变元素类的前提下定义作用于这些元素的新操作。这种模式将算法与对象结构分离&#xff0c;使得可以独立地变化那些保存在复杂对象结构中的元素的操作。 假设我们有一个复杂的对…...

stable diffusion 量化学习笔记

文章目录 一、一些tensorRT背景及使用介绍1&#xff09;深度学习介绍2&#xff09;TensorRT优化策略介绍3&#xff09;TensorRT基础使用流程4&#xff09;dynamic shape 模式5&#xff09;TensorRT模型转换 二、TensorRT转onnx模型1&#xff09;onnx介绍2&#xff09;背景知识&…...

金融项目实战 04|JMeter实现自动化脚本接口测试及持续集成

目录 一、⾃动化测试理论 二、自动化脚本 1、添加断言 1️⃣注册、登录 2️⃣认证、充值、开户、投资 2、可重复执行&#xff1a;清除测试数据脚本按指定顺序执行 1️⃣如何可以做到可重复执⾏&#xff1f; 2️⃣清除测试数据&#xff1a;连接数据库setup线程组 ①明确…...

无需昂贵GPU:本地部署开源AI项目LocalAI在消费级硬件上运行大模型

无需昂贵GPU&#xff1a;本地部署开源AI项目LocalAI在消费级硬件上运行大模型 随着人工智能技术的快速发展&#xff0c;越来越多的AI模型被广泛应用于各个领域。然而&#xff0c;运行这些模型通常需要高性能的硬件支持&#xff0c;特别是GPU&#xff08;图形处理器&#xff09…...

selenium学习笔记

一.搭建环境 1.安装chrome #下载chrome wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb#安装chrome apt --fix-broken install ./google-chrome-stable_current_amd64.deb2.安装chromedriver 首先先查看版本&#xff1a;google-chrome --…...

SOME/IP协议详解 基础解读 涵盖SOME/IP协议解析 SOME/IP通讯机制 协议特点 错误处理机制

车载以太网协议栈总共可划分为五层&#xff0c;分别为物理层&#xff0c;数据链路层&#xff0c;网络层&#xff0c;传输层&#xff0c;应用层&#xff0c;其中今天所要介绍的内容SOME/IP就是一种应用层协议。 SOME/IP协议内容按照AUTOSAR中的描述&#xff0c;我们可以更进一步…...

nginx 实现 正向代理、反向代理 、SSL(证书配置)、负载均衡 、虚拟域名 ,使用其他中间件监控

我们可以详细地配置 Nginx 来实现正向代理、反向代理、SSL、负载均衡和虚拟域名。同时&#xff0c;我会介绍如何使用一些中间件来监控 Nginx 的状态和性能。 1. 安装 Nginx 如果你还没有安装 Nginx&#xff0c;可以通过以下命令进行安装&#xff08;以 Ubuntu 为例&#xff0…...

基于单片机的智能花卉浇水系统的设计与实现

摘要&#xff1a; 随着人们生活水平的不断提高&#xff0c;生活节奏也越来越快。人们经常忽视办公室或者家居的花卉&#xff0c;忘记浇水。本文设计了一种基于单片机的智能浇水系统。目的是解决养殖花卉的人忘记浇水的问题。本系统以单片机AT89S52为控制芯片&#xff0c;能够按…...

《使用 YOLOV8 和 KerasCV 进行高效目标检测》

《使用 YOLOV8 和 KerasCV 进行高效目标检测》 作者&#xff1a;Gitesh Chawda创建日期&#xff1a;2023/06/26最后修改时间&#xff1a;2023/06/26描述&#xff1a;使用 KerasCV 训练自定义 YOLOV8 对象检测模型。 &#xff08;i&#xff09; 此示例使用 Keras 2 在 Colab 中…...

【Domain Generalization(3)】领域泛化与文生图之 -- QUOTA 任意领域中的生成物体的数量可控

系列文章目录 【Domain Generalization(1)】增量学习/在线学习/持续学习/迁移学习/多任务学习/元学习/领域适应/领域泛化概念理解第一篇了解了 DG 的概念&#xff0c;那么接下来将介绍 DG 近年在文生图中的相关应用/代表性工作。【Domain Generalization(2)】领域泛化在文生图…...

qml XmlListModel详解

1、概述 XmlListModel是QtQuick用于从XML数据创建只读模型的组件。它可以作为各种view元素的数据源&#xff0c;比如ListView、GridView、PathView等&#xff1b;也可以作为其他和model交互的元素的数据源。通过XmlRole定义角色&#xff0c;如name、age和height&#xff0c;并…...

CAPL如何设置TCP/IP传输层动态端口范围

在TCP/IP协议中,应用程序通过传输层协议TCP/UDP传输数据,接收方传输层收到数据后,根据传输层端口号把接收的数据上交给正确的应用程序。我们可以简单地认为传输层端口号是应用程序的标识,这就是为什么我们说应用程序在使用TCP/IP协议通信时要打开传输层端口号或者绑定端口号…...

Pandas常用数据类型

扩展库pandas常用的数据结构如下&#xff1a; &#xff08;1&#xff09;Series&#xff1a;带标签的一维数组 &#xff08;2&#xff09;DatetimeIndes&#xff1a;时间序列 &#xff08;3&#xff09;DateFrame&#xff1a;带标签且大小可变的二维表格结构 &#xff08;4…...

【AI大模型】BERT GPT ELMo模型的对比

目录 &#x1f354; BERT, GPT, ELMo之间的不同点 &#x1f354; BERT, GPT, ELMo各自的优点和缺点 &#x1f354; 小结 学习目标 理解BERT, GPT, ELMo相互间的不同点理解BERT, GPT, ELMo相互比较下的各自优点和缺点 &#x1f354; BERT, GPT, ELMo之间的不同点 关于特征提取…...

探索AGI:智能助手与自我赋能的新时代

目录 1 AGI1.1 DeepMind Levels&#xff08;2023年11月)1.2 OpenAI Levels&#xff08;2024年7月&#xff09;1.3 对比与总结1.4 AGI可能诞生哪里 2 基于AI的智能自动化助手2.1 通用型大模型2.2 专业的Agent和模型工具开发框架2.3 编程与代码生成助手2.4 视频和多模态生成2.5 商…...

Oracle Dataguard(主库为双节点集群)配置详解(5):将主库复制到备库并启动同步

Oracle Dataguard&#xff08;主库为双节点集群&#xff09;配置详解&#xff08;5&#xff09;&#xff1a;将主库复制到备库并启动同步 目录 Oracle Dataguard&#xff08;主库为双节点集群&#xff09;配置详解&#xff08;5&#xff09;&#xff1a;将主库复制到备库并启动…...

webrtc自适应分辨率的设置

DegradationPreference 是一个枚举类&#xff0c;用于在视频编码或实时通信&#xff08;如 WebRTC&#xff09;中指定系统资源不足时如何处理质量下降的策略。以下是该枚举类的中文解释&#xff1a; enum class DegradationPreference {// 禁用&#xff1a;不根据资源过载信号…...

提供的 IP 地址 10.0.0.5 和子网掩码位 /26 来计算相关的网络信息

网络和IP地址计算器 https://www.sojson.com/convert/subnetmask.html提供的 IP 地址 10.0.0.5 和子网掩码位 /26 来计算相关的网络信息。 子网掩码转换 子网掩码 /26 的含义二进制表示:/26 表示前 26 位是网络部分&#xff0c;剩下的 6 位是主机部分。对应的子网掩码为 255…...

WPF系列八:图形控件Path

简介 Path控件支持一种称为路径迷你语言&#xff08;Path Mini-Language&#xff09;的紧凑字符串格式&#xff0c;用于描述复杂的几何图形。这种语言通过一系列命令字母和坐标来定义路径上的点和线段&#xff0c;最终绘制出想要的图形。 绘制任意形状&#xff1a;可以用来绘…...

如何移除git中被跟踪的commit文件

忽略已被跟踪的文件 问题描述 如果某个文件已经被 Git 跟踪&#xff08;即已被提交到仓库&#xff09;&#xff0c;即使后来将其添加到 .gitignore 文件中&#xff0c;Git 仍会继续跟踪它。 解决方案 更新 .gitignore 文件 将需要忽略的文件加入 .gitignore&#xff1a; .env…...

15. C语言 函数指针与回调函数

本章目录: 前言什么是函数指针&#xff1f;定义声明方式 函数指针的基本用法示例&#xff1a;最大值函数输出示例&#xff1a; 回调函数与函数指针什么是回调函数&#xff1f;通俗解释 示例&#xff1a;回调函数实现动态数组填充输出示例&#xff1a; 进一步探索&#xff1a;带…...

tomcat12启动流程源码分析

信息: Server.服务器版本: Apache Tomcat/12.0.x-dev 信息: Java虚拟机版本: 21下载源码https://github.com/apache/tomcat&#xff0c;并用idea打开&#xff0c;配置ant编译插件&#xff0c;或者使用我的代码 启动脚本是/bin/startup.bat&#xff0c;内部又执行了bin\cata…...

Pycharm 使用教程

一、基本配置 1. 切换Python解释器 pycharm切换解释器版本 2. pycharm虚拟环境配置 虚拟环境的目的&#xff1a;创建适用于该项目的环境&#xff0c;与系统环境隔离&#xff0c;防止污染系统环境&#xff08;包括需要的库&#xff09;虚拟环境配置存放在项目根目录下的 ven…...

数据仓库: 9- 数据仓库数据治理

目录 9- 数据治理9.1 数据标准化9.1.1 数据标准化的定义9.1.2 数据标准化的重要性9.1.3 数据标准化的主要内容9.1.4 数据标准化的实施步骤9.1.5 数据标准化常用工具9.1.6 数据标准化的挑战与应对策略9.1.7 案例分析9.1.8 总结 9.2 主数据管理(MDM)9.2.1 主数据管理的核心目标9.…...

Kutools for Excel 简体中文版 - 官方正版授权

Kutools for Excel 是一款超棒的 Excel 插件&#xff0c;就像给你的 Excel 加了个超能助手。它有 300 多种实用功能&#xff0c;现在还有 AI 帮忙&#xff0c;能把复杂的任务变简单&#xff0c;重复的事儿也能自动搞定&#xff0c;不管是新手还是老手都能用得顺手。有了它&…...

回归预测 | MATLAB实MLR多元线性回归多输入单输出回归预测

回归预测 | MATLAB实MLR多元线性回归多输入单输出回归预测 目录 回归预测 | MATLAB实MLR多元线性回归多输入单输出回归预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 回归预测 | MATLAB实MLR多元线性回归多输入单输出回归预测。 程序设计 完整代码&#xff1a;回…...

lerna使用指南

lerna版本 以下所有配置命令都是基于v8.1.9&#xff0c;lerna v5 v7版本差别较大&#xff0c;在使用时&#xff0c;注意自身的lerna版本。 lerna开启缓存及缓存配置 nx缓存是v5版本以后才有的&#xff0c;小于该版本的无法使用该功能。 初始化配置 缓存配置文件nx.json&am…...

LightGCN:为推荐系统简化图卷积网络的创新之作

LightGCN: Simplifying and Powering Graph Convolution Network for RecommendationSIGIR2020Collaborative Filtering, Recommendation, Embedding Propagation, Graph Neural Network &#x1f31f; 研究背景 在信息爆炸的互联网时代&#xff0c;个性化推荐系统成为缓解信…...

【图像去噪】论文精读:High-Quality Self-Supervised Deep Image Denoising(HQ-SSL)

请先看【专栏介绍文章】:【图像去噪(Image Denoising)】关于【图像去噪】专栏的相关说明,包含适配人群、专栏简介、专栏亮点、阅读方法、定价理由、品质承诺、关于更新、去噪概述、文章目录、资料汇总、问题汇总(更新中) 文章目录 前言Abstract1 Introduction2 Convoluti…...

Elasticsarch:使用全文搜索在 ES|QL 中进行过滤 - 8.17

8.17 在 ES|QL 中引入了 match 和 qstr 函数&#xff0c;可用于执行全文过滤。本文介绍了它们的作用、使用方法、与现有文本过滤方法的区别、当前的限制以及未来的改进。 ES|QL 现在包含全文函数&#xff0c;可用于使用文本查询过滤数据。我们将回顾可用的文本过滤方法&#xf…...

17.C语言输入输出函数详解:从缓存原理到常用函数用法

目录 1.前言2.缓存和字节流3.printf4.scanf5.sscanf6.getchar与putchar7.puts与gets 1.前言 本篇原文为&#xff1a;C语言输入输出函数详解&#xff1a;从缓存原理到常用函数用法。 更多C进阶、rust、python、逆向等等教程&#xff0c;可点击此链接查看&#xff1a;酷程网 C…...

高等数学学习笔记 ☞ 不定积分与积分公式

1. 不定积分的定义 1. 原函数与导函数的定义&#xff1a; 若函数可导&#xff0c;且&#xff0c;则称函数是函数的一个原函数&#xff0c;函数是函数的导函数。 备注&#xff1a; ①&#xff1a;若函数是连续的&#xff0c;则函数一定存在原函数&#xff0c;反之不对。 ②&…...

Debye-Einstein-模型拟合比热容Python脚本

固体比热模型中的德拜模型和爱因斯坦模型是固体物理学中用于估算固体热容的两种重要原子振动模型。 爱因斯坦模型基于三种假设&#xff1a;1.晶格中的每一个原子都是三维量子谐振子&#xff1b;2.原子不互相作用&#xff1b;3.所有的原子都以相同的频率振动&#xff08;与德拜…...

Ubuntu24.04安装AppImage报错AppImages require FUSE to run.

报错如下&#xff1a; 解决&#xff1a; sudo apt install libfuse2t64如果不行&#xff1a; sudo add-apt-repository universe sudo apt install libfuse2t64安装时又报错&#xff1a; [10354:0109/100149.571068:FATAL:setuid_sandbox_host.cc(158)] The SUID sandbox hel…...

3_CSS3 渐变 --[CSS3 进阶之路]

CSS3 引入了渐变&#xff08;gradients&#xff09;&#xff0c;它允许在两个或多个指定的颜色之间显示平滑的过渡。CSS3 支持两种类型的渐变&#xff1a; 线性渐变&#xff08;Linear Gradients&#xff09;&#xff1a;颜色沿着一条线性路径变化&#xff0c;可以是水平、垂直…...

uniapp 左右滑动切换Tab

各种开发会遇到很多奇葩的需求&#xff0c;今天这个是在页面 左右滑动&#xff0c;然后自动去切换Tab <viewtouchstart"touchStart"touchcancel"touchCancel"touchend"touchEnd"><components is"xxx"/></view>//---…...