Python-内置数据结构listdictset

关于元组的函数

  • 以下看代码
  • 以下函数,对list基本适用
# len: 获取元组的长度
t = (1,2,3,4,5)
len(t)

输出结果如下:

5

==================================

# max, min:最大最小值
# 如果,列表或元组中有多个最大最小值,则实际打印出哪个
print(max(t))
print(min(t))

输出结果如下:

5
1

==================================

# tuple:转化或创建元组
l = [1,2,3,4,5]
t = tuple(l)
print(t)

t = tuple()
print(t)

输出结果如下:

(1, 2, 3, 4, 5)
()
View Code

元组的函数

  • 基本跟list通用
# count: 计算制定数据出现的次数
t = (2,1,2,3,45,1,1,2,)

print(t.count(2))

# index:求制定元素在元组中的索引位置

print(t.index(45))
# 如果需要查找的数字是多个,则返回第一个

print(t.index(1))


输出结果如下:

3
4
1
View Code

元组变量交换法

  • 两个变量交换值
    # 两个变量交换值
    a = 1
    b = 3
    
    print(a)
    print(b)
    print("*" * 20)
    # java程序员会这么写:
    c = a
    a = b
    b = c
    print(a)
    print(b)
    
    print("*" * 20)
    # python的写法
    a,b = b,a
    print(a)
    print(b)
    
    输出结果如下:
    
    1
    3
    ********************
    3
    1
    ********************
    1
    3
    View Code

集合-set

  • 集合是高中数学中的一个概念
  • 一堆确定的无序的唯一的数据,集合中每一个数据成为一个元素
# 集合的定义
s = set()
print(type(s))
print(s)

# 此时,大括号内一定要有值,否则定义出的是一个dict
s = {1,2,3,4,5,6,7}
print(s)

输出结果如下:

<class 'set'>
set()
{1, 2, 3, 4, 5, 6, 7}

==================================

# 如果只是用大括号定义,则定义的是一个dict类型
d = {}
print(type(d))
print(d)

输出结果如下:

<class 'dict'>
{}
View Code

集合的特征

  • 集合内数据无序,即无法使用索引和分片
  • 集合内部数据元素具有唯一性,可以用来排除重复数据
  • 集合内的数据,str, int, float, tuple,冰冻集合等,即内部只能放置可哈希数据

集合序列操作

# 成员检测
# in, not in
s = {4,5,"i", "love", "wangxiaojing"}
print(s)

if "love" in s:
    print("爱呀")

if  "haha" not in s:
    print("挨个锤子")

输出结果如下:

{'i', 4, 5, 'wangxiaojing', 'love'}
爱呀
挨个锤子
View Code

集合便利操作

# for 循环
s = {4,5,"i", "love", "wangxiaojing"}

for i in s:
    print(i, end=" ")

输出结果如下:

i 4 5 wangxiaojing love

============================

# 带有元组的集合遍历
s = {(1,2,3), ("i", "love", "wangxiaojing"), (4,5,6)}

for k,m,n in s:
    print(k, "--", m, "--", n)
    
for k in s:
    print(k)

输出结果如下:

4 -- 5 -- 6
i -- love -- wangxiaojing
1 -- 2 -- 3
(4, 5, 6)
('i', 'love', 'wangxiaojing')
(1, 2, 3)
View Code

集合的内涵

# 普通集合内涵
# 以下集合在初始化后自动过滤掉重复元素
s = {23,223,545,3,1,2,3,4,3,2,3,1,2,4,3}
print(s)

# 普通集合内涵
ss = {i for i in s}
print(ss)

输出结果如下:

{545, 1, 3, 2, 4, 23, 223}
{545, 2, 3, 4, 1, 23, 223}

==============================

# 带条件的集合内涵
sss = {i for i in s if i % 2 == 0}
print(sss)

输出结果如下:

{2, 4}

==============================

# 多循环的集合内涵
s1 = {1,2,3,4}
s2 = {"i", "love", "wangxiaojing"}

s = {m*n for m in s2 for n in s1}
print(s)

s = {m*n for m in s2 for n in s1 if n ==2}
print(s)

输出结果如下:

{'iii', 'i', 'lovelovelove', 'ii', 'lovelovelovelove', 'wangxiaojingwangxiaojingwangxiaojingwangxiaojing', 'wangxiaojing', 'lovelove', 'wangxiaojingwangxiaojing', 'love', 'wangxiaojingwangxiaojingwangxiaojing', 'iiii'}
{'lovelove', 'wangxiaojingwangxiaojing', 'ii'}
View Code

集合函数/关于集合的函数

# len, max, min:跟其他基本函数一致
s = {43,23,56,223,4,2,1222,4,323,1}
print(len(s))
print( max(s))
print(min(s))

输出结果如下:

9
1222
1

============================

# set:生成一个集合
l = [1,2,3,4,3,23,1,2,3,4]
s = set(l)
print(s)

输出结果如下:

{1, 2, 3, 4, 23}

============================

# add:向集合内添加元素
s = {1}
s.add(334)
print(s)

输出结果如下:

{1, 334}

============================

#clear
s = {1,2,3,4,5}
print(id(s))
s.clear()
print(id(s))
# 结果表明clear函数是原地清空数据

输出结果如下:

140040159572936
140040159572936

============================

# copy:拷贝
# remove:移除制定的值,直接改变原有值,如果要删除的值不存在,报错
# discard:移除集合中指定的值,跟remvoe一样,但是入股要删除的话,不报错
s = {23,3,4,5,1,2,3}
s.remove(4)
print(s)
s.discard(1)
print(s)

print("*" * 20)
s.discard(1100)
print(s)

s.remove(1100)
print(s)

# 为啥remove不存在的值会报keyerror

输出结果如下:

{1, 2, 3, 5, 23}
{2, 3, 5, 23}
********************
{2, 3, 5, 23}
---------------------------------------------------------------------------
KeyError                                  Traceback (most recent call last)
<ipython-input-52-97b440627674> in <module>()
     12 print(s)
     13 
---> 14 s.remove(1100)
     15 print(s)
     16 

KeyError: 1100

============================

# pop 随机移除一个元素
s = {1,2,3,4,5,6,7}
d = s.pop()
print(d)
print(s)

输出结果如下:

1
{2, 3, 4, 5, 6, 7}

============================

# 集合函数
# intersection: 交集
# difference:差集
# union: 并集
# issubset: 检查一个集合是否为另一个子集
# issuperset: 检查一个集合是否为另一个超集
s1 = {1,2,3,4,5,6}
s2 = {5,6,7,8,9}

s_1 = s1.intersection(s2)
print(s_1)

s_2 = s1.difference(s2)
print(s_2)

s_3 = s1.issubset(s2)
print(s_3)

输出结果如下:

{5, 6}
{1, 2, 3, 4}
False

============================

# 集合额数学操作
s1 = {1,2,3,4,5,6}
s2 = {5,6,7,8,9}

s_1 = s1 - s2
print(s_1)

s_2 = s1 + s2
print(s_2)

输出结果如下:

{1, 2, 3, 4}
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-61-e8f896159ead> in <module>()
      6 print(s_1)
      7 
----> 8 s_2 = s1 + s2
      9 print(s_2)

TypeError: unsupported operand type(s) for +: 'set' and 'set'
View Code

frozen set:冰冻集合

  • 并冻和就是不可以进行任何修改的集合
  • frozenset是一种特殊集合
    # 创建
    s = frozenset()
    print(type(s))
    print(s)
    
    输出结果如下:
    
    <class 'frozenset'>
    frozenset()
    View Code

dict字典

  • 字典是一种组合数据,没有顺序的组合数据,数据以键值对形式出现
    # 字典的创建
    # 创建空字典1
    d = {}
    print(d)
    
    # 创建空字典2
    d = dict()
    print(d)
    
    # 创建有值的字典, 每一组数据用冒号隔开, 每一对键值对用逗号隔开
    d = {"one":1, "two":2, "three":3}
    print(d)
    
    # 用dict创建有内容字典1
    d = dict({"one":1, "two":2, "three":3})
    print(d)
    
    # 用dict创建有内容字典2
    # 利用关键字参数
    d = dict(one=1, two=2, three=3)
    print(d)
    
    
    # 
    d = dict( [("one",1), ("two",2), ("three",3)])
    print(d)
    
    输出结果如下:
    
    {}
    {}
    {'one': 1, 'two': 2, 'three': 3}
    {'one': 1, 'two': 2, 'three': 3}
    {'one': 1, 'two': 2, 'three': 3}
    {'one': 1, 'two': 2, 'three': 3}
    View Code

字典的特征

  • 字典是序列类型,但是是无序序列,所以没有分片和索引
  • 字典中的数据每个都有键值对组成,即kv对
    • key: 必须是可哈希的值,比如int,string,float,tuple, 但是,list,set,dict 不行
    • value: 任何值

字典常见操作

# 访问数据
d = {"one":1, "two":2, "three":3}
# 注意访问格式
# 中括号内是键值
print(d["one"])


d["one"] = "eins"
print(d)

# 删除某个操作
# 使用del操作
del d["one"]
print(d)

输出结果如下:

1
{'one': 'eins', 'two': 2, 'three': 3}
{'two': 2, 'three': 3}

==============================

# 成员检测, in, not in
# 成员检测检测的是key内容
d = {"one":1, "two":2, "three":3}

if 2 in d:
    print("value")
    
if "two" in d:
    print("key")
    
if ("two",2) in d:
    print("kv")

输出结果如下:

key

==============================

# 便利在python2 和 3 中区别比较大,代码不通用
# 按key来使用for循环
d = {"one":1, "two":2, "three":3}
# 使用for循环,直接按key值访问
for k in d:
    print(k,  d[k])
    
# 上述代码可以改写成如下
for k in d.keys():
    print(k,  d[k])
    
# 只访问字典的值
for v in d.values():
    print(v)
    
# 注意以下特殊用法
for k,v in d.items():
    print(k,'--',v)

输出结果如下:

one 1
two 2
three 3
one 1
two 2
three 3
1
2
3
one -- 1
two -- 2
three -- 3
View Code

字典生成式

d = {"one":1, "two":2, "three":3}

# 常规字典生成式
dd = {k:v for k,v in d.items()}
print(dd)


# 加限制条件的字典生成式
dd = {k:v for k,v in d.items() if v % 2 == 0}
print(dd)

输出结果如下:

{'one': 1, 'two': 2, 'three': 3}
{'two': 2}
View Code

字典相关函数

# 通用函数: len, max, min, dict
# str(字典): 返回字典的字符串格式
d = {"one":1, "two":2, "three":3}
print(str(d))

输出结果如下:

{'one': 1, 'two': 2, 'three': 3}

===============================

# clear: 清空字典
# items: 返回字典的键值对组成的元组格式

d = {"one":1, "two":2, "three":3}
i = d.items()
print(type(i))
print(i)

输出结果如下:

<class 'dict_items'>
dict_items([('one', 1), ('two', 2), ('three', 3)])

===============================

# keys:返回字典的键组成的一个结构
k = d.keys()
print(type(k))
print(k)

输出结果如下:

<class 'dict_keys'>
dict_keys(['one', 'two', 'three'])

===============================

# values: 同理,一个可迭代的结构
v = d.values()
print(type(v))
print(v)

输出结果如下:

<class 'dict_values'>
dict_values([1, 2, 3])

===============================

# get: 根据制定键返回相应的值, 好处是,可以设置默认值

d = {"one":1, "two":2, "three":3}
print(d.get("on333"))

# get默认值是None,可以设置
print(d.get("one", 100))
print(d.get("one333", 100))

#体会以下代码跟上面代码的区别
print(d['on333'])

输出结果如下:

None
1
100
---------------------------------------------------------------------------
KeyError                                  Traceback (most recent call last)
<ipython-input-109-7a2a24f5a7b6> in <module>()
      9 
     10 #体会以下代码跟上面代码的区别
---> 11 print(d['on333'])

KeyError: 'on333'

===============================

# fromkeys: 使用指定的序列作为键,使用一个值作为字典的所有的键的值
l = ["eins", "zwei", "drei"]
# 注意fromkeys两个参数的类型
# 注意fromkeys的调用主体
d = dict.fromkeys(l, "hahahahahah")
print(d)

输出结果如下:

{'eins': 'hahahahahah', 'zwei': 'hahahahahah', 'drei': 'hahahahahah'}
View Code

 

posted @ 2020-04-10 18:28  kellen-fang  阅读(176)  评论(0编辑  收藏  举报