基础数据类型汇总

一、列表(list)

例如:删除索引为奇数的元素

lis=[11,22,33,44,55]

#第一种:
for i in range(len(lis)):
if i%2==1:
del lis[i]
print(lis) #第二种
li=[]
for i in lis:
if lis.index(i)%2==0:
li.append(i)
lis=li
print(lis) #第三种:
for i in range(len(lis)-1,-1,-1):
if i%2==1:
del lis[i]
print(lis) #第四种:当然 最简单了
lis=lis[0::2]
print(lis)

注意:在循环一个列表时,最好不要删除列表中的元素,这样会使索引发生改变,从而报错。

二、字典(dict)

dic=dict.fromkeys([1,2,3],"二哥")
print(dic) #{1: '二哥', 2: '二哥', 3: '二哥'}

1.同一个列表

dic=dict.fromkeys([1,2,3],[])
print(dic) #{1: [], 2: [], 3: []} dic[1].append("二哥")
print(dic) #{1: ['二哥'], 2: ['二哥'], 3: ['二哥']}

2.删除键为“k”开头的键值对

dic={"k1":"v1","k2":"v2","a1":"v3"}
#第一种:
dic1={}
for i in dic:
if "k" not in i:
dic1.setdefault(i,dic[i])
dic=dic1
print(dic) #第二种:
l=[]
for i in dic:
if "k" in i:
l.append(i)
for i in l:
del dic[i]
print(dic)

注意:字典、列表删除时不能循环键值对

三、元组(tuple)

tu1 = (1)
tu2 = (1,)
print(tu1,type(tu1)) #1 <class 'int'>
print(tu2,type(tu2)) #(1,) <class 'tuple'> tu1 = ([1])
tu2 = ([1],)
print(tu1,type(tu1)) #[1] <class 'list'>
print(tu2,type(tu2)) #([1],) <class 'tuple'>

注意:如果元组里面只有一个元素 ,且不加逗号,则此元素是啥类型就是啥类型;

如果有其他元素或只有一个逗号,就是元组。

四、集合

集合操作

特点:1)集合为可变的数据类型,但集合元素必须是不可变的数据类型。

2)无序

3不重复

1、创建集合

# set1=set({1,2,3,4,5})
# set2={4,5,6,7,8}

2、增

1)add

set1={"alex","wusir","ritain","egon","barry",}

set1.add("女神")
print((set1)) #{'wusir', 'barry', 'ritain', 'egon', 'alex', '女神'}

2)update:迭代添加

set1={"alex","wusir","ritain","egon","barry",}

set1.update("abc")
print(set1) #{'egon', 'barry', 'c', 'b', 'alex', 'a', 'wusir', 'ritain'}

3、删除

1)、pop(随机删除,有返回值)

set1={"alex","wusir","ritain","egon","barry",}

set1.pop()       #随机删除(有返回值)
print(set1) #{'egon', 'barry', 'alex', 'ritain'}

2)remove(按元素)

set1={"alex","wusir","ritain","egon","barry",}

set1.remove("alex")   #按元素
print(set1) {'ritain', 'egon', 'wusir', 'barry'}

3)clear(清空集合)

set1={"alex","wusir","ritain","egon","barry",}

set1.clear()       #清空集合
print(set1) #set()

4)del(删除字典)

set1={"alex","wusir","ritain","egon","barry",}

del set1      #删除集合
print(set1) #报错

不能改:无序、元素为不可变数据类型

4、查

for循环

set1={"alex","wusir","ritain","egon","barry",}

for i in set1:
print(i)

5、交集(&  或者 intersection)

set1={1,2,3,4,5}
set2={4,5,6,7,8}
print(set1 & set2)
print(set1.intersection(set2)) #{4, 5}

6、并集(| 或者 union)

set1={1,2,3,4,5}
set2={4,5,6,7,8}
print(set1|set2)
print(set2.union(set1)) #{1, 2, 3, 4, 5, 6, 7, 8}

7、反交集(^ 或者 symmetric_difference)

set1={1,2,3,4,5}
set2={4,5,6,7,8}
print(set1^set2)
print(set1.symmetric_difference(set2)) #{1, 2, 3, 6, 7, 8}

8、差集(- 或者 difference)

set1={1,2,3,4,5}
set2={4,5,6,7,8}
print(set1-set2)
print(set1.difference(set2)) #{1, 2, 3}

9、子集与超集

set1 = {1,2,3}
set2 = {1,2,3,4,5,6} print(set1 < set2)
print(set1.issubset(set2)) # 这两个相同,都是说明set1是set2子集。 print(set2 > set1)
print(set2.issuperset(set1)) # 这两个相同,都是说明set2是set1超集。

10、5,frozenset不可变集合,让集合变成不可变类型。

s = frozenset('barry')
print(s,type(s)) # frozenset({'a', 'y', 'b', 'r'}) <class 'frozenset'>

深浅copy

1、赋值运算

l1 = [1,2,3,['barry','alex']]
l2 = l1 l1[0] = 111
print(l1) # [111, 2, 3, ['barry', 'alex']]
print(l2) # [111, 2, 3, ['barry', 'alex']] l1[3][0] = 'wusir'
print(l1) # [111, 2, 3, ['wusir', 'alex']]
print(l2) # [111, 2, 3, ['wusir', 'alex']]

注意:对于赋值运算来说,l1与l2指向的是同一个内存地址,所以他们是完全一样的。

2、浅拷贝copy

l2 = l1.copy()
print(l1,id(l1)) # [1, 2, 3, ['barry', 'alex']] 2380296895816
print(l2,id(l2)) # [1, 2, 3, ['barry', 'alex']] 2380296895048
l1[1] = 222
print(l1,id(l1)) # [1, 222, 3, ['barry', 'alex']] 2593038941128
print(l2,id(l2)) # [1, 2, 3, ['barry', 'alex']] 2593038941896 l1[3][0] = 'wusir'
print(l1,id(l1[3])) # [1, 2, 3, ['wusir', 'alex']] 1732315659016
print(l2,id(l2[3])) # [1, 2, 3, ['wusir', 'alex']] 1732315659016

注意:对于浅copy来说,第一层创建的是新的内存地址,而从第二层开始,指向的都是同一个内存地址,所以,对于第二层以及更深的层数来说,保持一致性。

3,深拷贝deepcopy

import copy
l1 = [1,2,3,['barry','alex']]
l2 = copy.deepcopy(l1) print(l1,id(l1)) # [1, 2, 3, ['barry', 'alex']] 2915377167816
print(l2,id(l2)) # [1, 2, 3, ['barry', 'alex']] 2915377167048 l1[1] = 222
print(l1,id(l1)) # [1, 222, 3, ['barry', 'alex']] 2915377167816
print(l2,id(l2)) # [1, 2, 3, ['barry', 'alex']] 2915377167048 l1[3][0] = 'wusir'
print(l1,id(l1[3])) # [1, 222, 3, ['wusir', 'alex']] 2915377167240
print(l2,id(l2[3])) # [1, 2, 3, ['barry', 'alex']] 2915377167304

注意:对于深copy来说,两个是完全独立的,改变任意一个的任何元素(无论多少层),另一个绝对不改变。

枚举

放可迭代对象,自动匹配索引,默认从0开始。

li=["alex","taibai","wusir","egon"]
for i in enumerate(li):
print(i) # (0, 'alex')
# (1, 'taibai')
# (2, 'wusir')
# (3, 'egon')
li=["alex","taibai","wusir","egon"]
for index,i in enumerate(li): #默认从0开始
print(index,i) # 0 alex
# 1 taibai
# 2 wusir
# 3 egon
li=["alex","taibai","wusir","egon"]
for index,i in enumerate(li,1): #可设置索引从1开始
print(index,i) # 1 alex
# 2 taibai
# 3 wusir
# 4 egon 

Python基础 之列表、字典、元组、集合的更多相关文章

  1. python之字符串,列表,字典,元组,集合内置方法总结

    目录 数字类型的内置方法 整型/浮点型 字符串类型的内置方法 列表的内置方法 字典的内置方法 元组的内置方法 集合类型内置方法 布尔类型 数据类型总结 数字类型的内置方法 整型/浮点型 加 + 减 - ...

  2. python基础之列表list元组tuple

    作者:tongqingliu 转载请注明出处:http://www.cnblogs.com/liutongqing/p/7041763.html python基础之列表list元组tuple 列表li ...

  3. python基础之 列表、元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码

    本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...

  4. Python基础之列表、元组、字典、集合的使用

    一.列表 1.列表定义 names=["Jhon","Lucy","Michel","Tom","Wiliam ...

  5. python基础之 列表,元组,字典

    other help(str.strip) #查看是否有返回值以及返回值类型[] :称为索引操作符 1.列表 列表相比字符串来说能存储大量数据的python的基本数据类型,并且也拥有字符串的一些方法( ...

  6. Python基础2 列表 字典 集合

    本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...

  7. Python基础学习 -- 列表与元组

    本节学习目的: 掌握数据结构中的列表和元组 应用场景: 编程 = 算法 + 数据结构 数据结构: 通过某种方式(例如对元素进行编号)组织在一起的数据元素的集合,这些元素可以是数字或者字符,或者其他数据 ...

  8. python基础4 列表和元组

    一. 列表列表:python基础数据类型之一:其他语言中也有列表的概念,js 数组,可索引,可切片,可加步长li = ['hello', 100, True, [1, 2, 3], {'name':' ...

  9. python基础之列表、元组

    一.列表 列表(list)是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 作用:多个装备,多个爱好,多门课程,多个女朋友等 定义:[ ]内可以有多个任意类型的值,逗号 ...

  10. Python基础:列表,元组和字典的基本操作

    列表(集合list)的基本操作: # 列表的常见操作 nameList = ["张学友", "刘德华", "郭富城", "黎明&q ...

随机推荐

  1. 【java规则引擎】一个基于drools规则引擎实现的数学计算例子

    最近在研究JBPM工作流引擎,发现JBPM是基于Drools的,官方文档查看得知Drools是一款规则引擎.兴趣之下,仔细了解了下 Drools,Drools作为JBoss出品的一款开源推理和规则引擎 ...

  2. LINUX TCP套接字详细配置

    提高服务器的负载能力,是一个永恒的话题.在一台服务器CPU和内存资源额定有限的情况下,最大的压榨服务器的性能,是最终的目的.要提高 Linux系统下的负载能力,可以先启用Apache的Worker模式 ...

  3. RK3288 模块单独编译

    模块以Email为例: 1.执行build目录下的脚本文件envsetup.sh $ source ./build/envsetup.sh 2.选择版本(user为用户版本   eng为工程版本) $ ...

  4. phpcms文档

    http://www.phpcms.cn/doc/PHPCMSDocumentor/cache_module.html http://www.cnblogs.com/Braveliu/p/507493 ...

  5. FPGA市场潜力有几多?

    FPGA市场未来成长潜力 本文来源:DIGITIMES 2014年FPGA市场规模为52.7亿美元,据Green Mountain Outlook报导,研调机构Global Market Insigh ...

  6. 事务之三:编程式事务、声明式事务(XML配置事务、注解实现事务)

    Spring2.0框架的事务处理有两大类: JdbcTemplate操作采用的是JDBC默认的AutoCommit模式,也就是说我们还无法保证数据操作的原子性(要么全部生效,要么全部无效),如: Jd ...

  7. 初学者手册-IDEA常用快捷键

    一.快速创建基于某个接口的类(引入相关包) 左键选择接口名称,使用快捷键Alt+enter,然后实现该类 二.打开选中的文件所在的文件夹 点选需要打开的文件,右键菜单,点击“Show in Explo ...

  8. php中的move_uploaded_file

    1.定义和用法 move_uploaded_file() 函数将上传的文件移动到新位置. 若成功,则返回 true,否则返回 false. 2.语法 move_uploaded_file(file,n ...

  9. 【转载】解决SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource' 的访问的方法

    1.开启Ad Hoc Distributed Queries组件,在sql查询编辑器中执行如下语句: exec sp_configure 'show advanced options',1 recon ...

  10. openstack 租户ip 手动配置 openstack静态租户ip

    作者:[吴业亮]云计算开发工程师 博客:http://blog.csdn.net/wylfengyujiancheng 1.综述: 在日常开发和生产环境中经常需要将OpenStack虚拟机配置一个静态 ...