day 7 - 1 集合、copy及基础数据类型汇总
集合:{},可变的数据类型,他里面的元素必须是不可变的数据类型,无序,不重复。(不重要)
集合的书写
set1 = set({1,2,3})
#set2 = {1,2,3,[2,3],{'name':'alex'}} #错的
print(set1)
#print(set2)
set = {'alex','wusir','ritian','egon','barry'}
增 add update
set.add("女神")
print(set) set.add("abc")
print(set) set.update("abc")
print(set)
删 pop remove clear del
set.pop() #随机删除
print(set.pop())
print(set) set.remove('alex') #按元素删除
print(set) set.remove('alex2')
print(set) set.clear() #清空列表 set()
print(set) del set #删除字典
print(set)
查 for
for i in set:
print(i)
交集 & intersection
set1 = {1,2,3,4,5}
set2 = {4,5,6,7,8} set3 = set1 & set2
print(set3) # {4, 5}
print(set1.intersection(set2)) # {4, 5}
并集 | union
set1 = {1,2,3,4,5}
set2 = {4,5,6,7,8}
print(set1 | set2) # {1, 2, 3, 4, 5, 6, 7,8}
print(set2.union(set1)) # {1, 2, 3, 4, 5, 6, 7}
反交集 ^ symmetric_difference
set1 = {1,2,3,4,5}
set2 = {4,5,6,7,8}
print(set1 ^ set2) # {1, 2, 3, 6, 7, 8}
print(set1.symmetric_difference(set2)) # {1, 2, 3, 6, 7, 8}
差集 - difference
set1 = {1,2,3,4,5}
set2 = {4,5,6,7,8}
print(set1 - set2) # {1, 2, 3} set1独有的
print(set2 - set1)
print(set1.difference(set2)) # {1, 2, 3}
子集 < issubset
超集 > issuperset
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超集。
面试题
#去重
li = [1,2,33,33,2,1,4,5,6,6] set1 = set(li)
print(set1) li = list(set1)
print(li)
让集合变为不可变类型 frozenset 冻结
s1 = {1,2,3}
print(s1,type(s1)) #让集合变为不可变类型 frozenset 冻结
s = frozenset('barry')
print(s,type(s)) #不可变类型只可以查
for i in s:
print(i)
copy
赋值运算
l1 = [1,2,3]
l2 = l1
l1.append('a')
print(l1,l2) [1, 2, 3, 'a'] [1, 2, 3, 'a']
运用 copy 赋值
l1 = [1,2,3]
l2 = l1.copy()
print(l1,l2)
print(id(l1),id(l2))
l2.append('a')
print(l1,l2)
copy 赋值与数组
#第一组
l1 = [1,2,[4,5,6],3]
l2 = l1.copy()
print(l1,id(l1))
print(l2,id(l2)) #第二组
l1.append('a')
print(l1,l2) #第三组
l1[2].append('a')
print(l1,l2)
print(id(l1[2]))
print(id(l2[2]))
#第一组
[1, 2, [4, 5, 6], 3] 2371695834312
[1, 2, [4, 5, 6], 3] 2371695834440 #第二组
[1, 2, [4, 5, 6], 3, 'a'] [1, 2, [4, 5, 6], 3] #第三组
[1, 2, [4, 5, 6, 'a'], 3, 'a'] [1, 2, [4, 5, 6, 'a'], 3]
2371695834184
2371695834184
copy 赋值与数组(2)
l1 = [1,[1],2,3,4]
l2 = l1[:] #第一组
l1[1].append('a')
#l2 的结果是什么?
print(l2) #第二组
print(l1,id(l1))
print(l2,id(l2))
print(l1[1] is l2[1])
#第一组
[1, [1, 'a'], 2, 3, 4] #第二组
[1, [1], 2, 3, 4] 2179834995912
[1, [1], 2, 3, 4] 2179834996040
True
通过定义 copy 赋值
import copy #定义 copy
l1 = [1,2,[4,5,6],3]
l2 = copys.deepcopy(l1) #第一组
print(l1,id(l1))
print(l2,id(l2)) #第二组
l1[2].append('a')
print(l1,l2)
#第一组
[1, 2, [4, 5, 6], 3] 1651493850184
[1, 2, [4, 5, 6], 3] 1651493850696 #第二组
[1, 2, [4, 5, 6, 'a'], 3] [1, 2, [4, 5, 6], 3]
index 与 enumerate 用法
打印序号与值
li = ['alex','taibai','wusir','egon']
for i in li:
print(li.index(i),i) for index,i in enumerate(li,1):
print(index,i)
基础数据类型汇总
list
列表中元素的删除过程
当每次列表中有元素被删除,则列表的原始下标发生变化
range 的值并不会跟随列表的变化而变化
lis = [11,22,33,44,55]
for i in range(len(lis)):
print(i) # i = 0 i = 1 i = 2
del lis[i]
print(lis) # [11,22,33,44,55] [22, 44, 55] [22, 44]
0
[22, 33, 44, 55]
1
[22, 44, 55]
2
[22, 44]
3
Traceback (most recent call last):
File "E:/py/day7-1.py", line 4, in <module>
del lis[i]
IndexError: list assignment index out of range
删除数组中的奇数位
lis = [11,22,33,44,55] #方法一
lis = lis[::2]
print(lis) #方法二
l1 = []
for i in lis:
if lis.index(i) % 2 == 0:
l1.append(i)
lis = l1
print(lis) #方法三
for i in range(len(lis)-1,-1,-1):
if i % 2 == 1:
print(i)
del lis[i]
print(lis)
print(lis)
字典的灵活用法
dic = dict.fromkeys([1,2,3],'春哥')
print(dic)
dic = dict.fromkeys([1,2,3],[])
#dic = dict.fromkeys([1,2,3],['ysg'])
print(dic) # {1: [], 2: [], 3: []}
dic[1].append('袁姐')
print(dic)
dic[2].extend('二哥')
print(dic)
数组的灵活用法
l1 = []
l2 = l1
l3 = l1
l3.append('a')
print(l1,l2,l3)
不打印含有 k 的键值对
dic = {'k1':'v1','k2':'v2','a3':'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)
可以转化成 bool 值
0 '' [] () {} set()
元祖:如果元祖里面只有一个元素且不加逗号,那此元素是什么类型,该元祖就是什么类型。
#第一组
tu1 = (1)
tu2 = (1,)
print(tu1,type(tu1))
print(tu2,type(tu2)) #第二组
tu1 = ([1])
tu2 = ([1],)
print(tu1,type(tu1))
print(tu2,type(tu2)) #元祖的灵活用法
dic = dict.fromkeys([1,2,3,],3)
dic[1] = 4
print(dic)
#第一组
1 <class 'int'>
(1,) <class 'tuple'> #第二组
[1] <class 'list'>
([1],) <class 'tuple'> #元祖的灵活用法
{1: 4, 2: 3, 3: 3}
day 7 - 1 集合、copy及基础数据类型汇总的更多相关文章
- 基础数据类型汇总补充;集合set ;深浅copy
首先回顾: 小数据池:int -5~256str 特殊字符,*数字20 ascii : 8位 1字节 表示1个字符unicode 32位 4个字节 表示一个字符utf- 8 1个英文 8位,1个字节 ...
- 基础数据类型汇总补充,python集合与深浅拷贝
一.基础数据类型汇总补充 1.查看str所有方法方式 2.列表:在循环中删除元素,易出错或报错(飘红) lis = [11,22,33,44,55] # for i in range(len(lis) ...
- python 基础数据类型汇总
数据类型小结(各数据类型常用操作) 一.数字/整型int int()强行转化数字 二.bool类型False&True bool()强行转化布尔类型. 0,None,及各个空的字符类型为Fal ...
- python基础数据类型汇总
list和dict 在循环一个列表和字典时,最好不要删除其中的元素,这样会使索引发生改变,从而报错! lis = [11, 22, 33, 44, 55] for i in range(len(lis ...
- Python基础数据类型之集合以及其他和深浅copy
一.基础数据类型汇总补充 list 在循环一个列表时,最好不要删除列表中的元素,这样会使索引发生改变,从而报错(可以从后向前循环删除,这样不会改变未删元素的索引). 错误示范: lis = [,,, ...
- day7 基础数据类型&集合&深浅拷贝
基础数据类型汇总: #!/usr/bin/env python # -*- coding:utf-8 -*- ''' str int ''' # str s = ' a' print(s.isspac ...
- 二: python基础数据类型(int,
一.什么是数据类型?2018-12-20 20:57:3õ # (3) num = 0 while num < 10: num += 1 if num == 7: num += 1 # 7执 ...
- Python——基础数据类型(补充)
1.基础数据类型汇总补充 (1)小数据池: 为了节省空间,数字和字符串有,其他的没有[了解] 数字:-5---256之间的数字共用一个内存地址 #(1)i1 = i2 id(i1) == id ...
- 基础数据类型的坑和集合及深浅copy
一.基础数据类型的坑: 元组: 如果一个元组中,只有一个元素,且没有逗号,则该"元组"与里面的数据的类型相同. # 只有一个数据,且没有逗号的情况: print(tu1,type( ...
随机推荐
- selinux 的使用
SELinux 的启动.关闭与查看 1,并非所有的 Linux distributions 都支持 SELinux 的 目前 SELinux 支持三种模式,分别如下: •enforcing:强制模式, ...
- nginx最简安装
在 CentOS 6.2 下安装nginx 一:nginx所需依赖的安装 用yum安装依赖: yum -y install zlib zlib-devel openssl openssl-devel ...
- Kubernetes的负载均衡问题(Nginx Ingress)
nginx 反向代理 https://www.cnblogs.com/ericnie/p/6965091.html Kubernetes 集群中使用 Traefik https://blog.csdn ...
- VM中的Linux如何设置共享文件夹
1.点击[编辑虚拟机设置]-[选项]-[共享文件夹],选择“总是启用” 2.点击[确定],并重启系统,已经设置好了
- python对象初始化
当python对象被创建以后,需要将对象进行初始化.Python有一个构造函数和一个初始化函数: 1.构造函数__new__,只接受一个参数,即类本身(它会在对象被构造之前调用,所以这里也就没有sel ...
- Java引用类型传递整理
引用数据类型(类) 10.1引用数据类型分类 可以把类的类型为两种: Java为我们提供好的类,如Scanner类,Random类等,这些已存在的类中包含了很多的方法与属性,可供我们使用. 我们自己创 ...
- 《Go并发编程实战》读书笔记-初识Go语言
<Go并发编程实战>读书笔记-初识Go语言 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在讲解怎样用Go语言之前,我们先介绍Go语言的特性,基础概念和标准命令. 一. ...
- JAVA核心技术I---JAVA基础知识(查漏补缺private,static)
一:private对于类和对象(同C++) private是只有这个类内部可以访问(类的成员函数和定义初始化) private是类之间的限制,而不是对对象的限制<重点> 同类对象是可以直接 ...
- 完美解决distinct中使用多个字段的方法
众所周知,distinct可以列出不重复的记录,对于单个字段来说distinct使用比较简单,但是对于多个字段来说,distinct使用起来会使人发狂.而且貌似也没有见到微软对distinct使用多字 ...
- Shell编程(三)Shell特性
!$:显示上一条命令最后一个参数 $?: 上个命令的退出状态,或函数的返回值. alias xxx="命令":给命令取别名 xxx 通过 vim ~/.bashrc 里编辑,可以来 ...