首页 > 编程语言 >Python 元组tuple、 列表list、 字典dict、集合set、迭代器、生成器

Python 元组tuple、 列表list、 字典dict、集合set、迭代器、生成器

时间:2023-02-26 09:45:31浏览次数:60  
标签:set tuple 生成器 list1 列表 list print 元组 字典

一、元组:  tuple

Python 的元组与列表类似,不同之处在于元组的元素不能修改。
元组中的元素值是不允许删除的,但我们可以使用del语句来删除整个元组

tup2 = (111, 22, 33, 444, 55, 6, 77 )
for x in (tup2):      #遍历
    print(x)


list2 = [111, 22, 33, 444, 55, 6, 77 ]
tup2 = tuple(list2)    #将列表转变为元组

二、列表:list

遍历列表:

#遍历列表
list1 = [1, 2, 3, 6, 5, 4]
for x in list1:
    print(x, end=",")  # 运行结果:1,2,3,6,5,4,

for i in range(len(list1)):
    print("序号:", i, "  值:", list1[i])

for i, val in enumerate(list1):
    print("序号:", i, "  值:", val)

for i in list1:
    idx = list1.index(i) # 索引
    if (idx < len(list1) - 1):
        print(i, '---------', list1[idx + 1])

三、字典:dict

dict = {'name': 'pp', 'age': 20, "gender": "man"}
dict["name"] = "sss"

for key in dict.keys():  # 遍历字典。字典的 keys() 方法以列表返回可遍历的(键) 元组数组。
    print(key)

for val in dict.values():  # 遍历字典。字典的 values() 方法以列表返回可遍历的(值) 元组数组。
    print(val)

for key, val in dict.items():  # 遍历字典。字典的 items() 方法以列表返回可遍历的(键, 值) 元组数组。
    print(key, " : ", val)

字典的多级嵌套:

citys={
    '北京':{
        '朝阳':['国贸','CBD','天阶'],
        '海淀':['圆明园','苏州街','中关村','北京大学'],
        '昌平':['沙河','南口','小汤山',],
        '怀柔':['桃花','梅花','大山']
    },
    '河北':{
        '石家庄':['石家庄A','石家庄B','石家庄C'],
        '张家口':['张家口A','张家口B','张家口C']
    }
}
for i in citys['北京']:
    print(i)

for i in citys['北京']['海淀']:
    print(i)

四、集合:set

集合(set)是一个无序不重复元素的序列。 基本功能是进行成员关系测试和删除重复元素。

集合无序,元素不能重复。

去重:将列表转化为集合,集合再转化为列表,就可以去重。

可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。

student = {'Tom', 'Jim', 'Mary', 'Tom', 'Jack', 'Rose'}
print(student)   # 输出集合,重复的元素被自动去掉 {'Mary', 'Jim', 'Rose', 'Jack', 'Tom'} 

# 成员测试
if('Rose' in student) :
    print('Rose 在集合中')
else :
    print('Rose 不在集合中')
#Rose 在集合中
从一个大集合里,去除一个小集合
set000 = set("123456789")
set1 = set(["2", "3", "5", "5", "6", "0"])
print(set000 - set1)
#{'7', '8', '9', '1', '4'}

元组 => 列表,字符串 <=> 列表的转换

# 元组 => 列表
tuple1 = (123, 'haha', 'she', 'hehe')
list1 = list(tuple1)   #将元组转换为列表。运行结果:[123, 'haha', 'she', 'hehe']
print(list1)
# 字符串 <=> 列表
str1 = '天地玄黄宇宙洪荒'
list1 = list(str1)  # 字符串转为列表
str2 = "".join(list1)  # 列表转为字符串
print(str2)

str1 = '天地,玄黄,宇宙,洪荒'
list1 = str1.split(",")  # 字符串转为列表
print(list1)

str1 = '天地玄黄宇宙洪荒'
str2 = str1[::-1]  # 字符串倒序
print(str2)

五、迭代器、生成器

迭代器有两个基本的方法:iter() 和 next()

import sys  # 引入 sys 模块

list = [1, 2, 3, 4]
it = iter(list)  # 创建迭代器对象

while True:
    try:
        print(next(it))
    except StopIteration:
        sys.exit()

使用了 yield 的函数被称为生成器(generator)。  跟普通函数不同的是,生成器是一个返回迭代器的函数,只能用于迭代操作

import sys
def fibonacci(n):  # 生成器函数 - 斐波那契
    a, b, counter = 0, 1, 0
    while True:
        if (counter > n):
            return
        yield a
        a, b = b, a + b
        counter += 1

f = fibonacci(10)  # f 是一个迭代器,由生成器返回生成

while True:
    try:
        print(next(f), end=" ")
    except StopIteration:
        sys.exit()

六、Map,Filter,Reduce

1.Map 会将一个函数映射到一个输入列表的所有元素上(可以同时对list里的所有元素进行操作,并以列表方式给出返回值。)
2. filter 过滤列表中的元素,并且返回一个由所有符合要求的元素所构成的列表。  (可以用来过滤原有的list,并把过滤结果放进新的list里。)
3. 当需要对一个列表进行一些计算并返回结果时,Reduce 是个非常有用的函数。(可以对列表顺序执行算术运算。)

参考文献

https://www.cnblogs.com/qq21270/p/7872824.html

标签:set,tuple,生成器,list1,列表,list,print,元组,字典
From: https://www.cnblogs.com/mario24678/p/17156139.html

相关文章

  • python基础-集合set { }
    集合的定义和操作集合的特性:元素数量支持多个元素类型任意下标索引支持重复元素不支持可修改性支持数据有序否使用场景不可重复的数据记录......
  • k8s部署daemonset filebeat
    实现:收集容器控制台日志部署daemonsetfilebeat,如上图红框位置找一台机器打镜像FROMdocker.elastic.co/beats/filebeat:7.9.0COPYfilebeat.yml/usr/share/filebeat/fileb......
  • 部署logstash收集daemonset filebeat发过去的kafka日志
    实现:部署如下图红框位置logstash架构:主机:10.0.7.56部署logstashyum-yinstalljava-1.8.0-openjdkyum-yinstallhttps://mirror.tuna.tsinghua.edu.cn/elasticstack/7......
  • 为什么在连接mysql时,设置 SetConnMaxIdleTime 没有作用
    目录测试1go1.15.15go1.17.12测试2go1.15.15go1.17.12参考在使用golang连接mysql时,为了节省连接资源,在连接使用过后,希望在指定长度时间不再使用后,自动关闭连接。这......
  • python基础-元组tuple( )
    元组的定义和操作元组的特性:元素数量支持多个元素类型任意下标索引支持重复元素支持可修改性不支持数据有序是使用场景不可修改、可重复的......
  • 17.SET操作符
    1.setoperators操作符--表达式必须在数量上匹配--后一个语句中列的数据类型必须与前一个语句中的对应列数据类型一致--括号可改变优先级--orderby语句可以出现在语句......
  • Jedis_操作list与Jedis_操作set&sortedset
    Jedis_操作list1)字符串类型stringsetget2)哈希类型hash:map......
  • set的自定义排序
    看下面的代码就好了structcmp{ booloperator()(constpair<int,int>&a,constpair<int,int>&b)const{ intlena=a.second-a.first+1; intlenb=b.second-b.firs......
  • {"errcode":40033,"errmsg":"invalid charset. please check your request, if i
    问题​​{"errcode":40033,"errmsg":"invalidcharset.pleasecheckyourrequest,ifinclude\\uxxxxwillcreatefail!hint:[FISJMa0799shc2]"}​​解决方案:最重要的......
  • 3 生成器模式
    3生成器模式定义:封装一个复杂对象构造过程,并允许按步骤构造。定义解释:我们可以将生成器模式理解为,假设我们有一个对象需要建立,这个对象是由多个组件(Component)组合而成,每......