集合:{},可变的数据类型,他里面的元素必须是不可变的数据类型,无序,不重复。(不重要)
集合的书写

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及基础数据类型汇总的更多相关文章

  1. 基础数据类型汇总补充;集合set ;深浅copy

    首先回顾: 小数据池:int -5~256str 特殊字符,*数字20 ascii : 8位 1字节 表示1个字符unicode 32位 4个字节 表示一个字符utf- 8 1个英文 8位,1个字节 ...

  2. 基础数据类型汇总补充,python集合与深浅拷贝

    一.基础数据类型汇总补充 1.查看str所有方法方式 2.列表:在循环中删除元素,易出错或报错(飘红) lis = [11,22,33,44,55] # for i in range(len(lis) ...

  3. python 基础数据类型汇总

    数据类型小结(各数据类型常用操作) 一.数字/整型int int()强行转化数字 二.bool类型False&True bool()强行转化布尔类型. 0,None,及各个空的字符类型为Fal ...

  4. python基础数据类型汇总

    list和dict 在循环一个列表和字典时,最好不要删除其中的元素,这样会使索引发生改变,从而报错! lis = [11, 22, 33, 44, 55] for i in range(len(lis ...

  5. Python基础数据类型之集合以及其他和深浅copy

    一.基础数据类型汇总补充 list  在循环一个列表时,最好不要删除列表中的元素,这样会使索引发生改变,从而报错(可以从后向前循环删除,这样不会改变未删元素的索引). 错误示范: lis = [,,, ...

  6. day7 基础数据类型&集合&深浅拷贝

    基础数据类型汇总: #!/usr/bin/env python # -*- coding:utf-8 -*- ''' str int ''' # str s = ' a' print(s.isspac ...

  7. 二: python基础数据类型(int,

    一.什么是数据类型?2018-12-20   20:57:3õ # (3) num = 0 while num < 10: num += 1 if num == 7: num += 1 # 7执 ...

  8. Python——基础数据类型(补充)

    1.基础数据类型汇总补充 (1)小数据池:   为了节省空间,数字和字符串有,其他的没有[了解]   数字:-5---256之间的数字共用一个内存地址 #(1)i1 = i2 id(i1) == id ...

  9. 基础数据类型的坑和集合及深浅copy

    一.基础数据类型的坑: 元组: 如果一个元组中,只有一个元素,且没有逗号,则该"元组"与里面的数据的类型相同. # 只有一个数据,且没有逗号的情况: print(tu1,type( ...

随机推荐

  1. 被addPropertyChangeListener("...",this)差点搞崩溃

    以前常用的是addPropertyChangeListener(this)方法 记得有一天我发现还有另一种写法: addPropertyChangeListener(String propertyNa ...

  2. 如何计算Java对象所占内存的大小

    [ 简单总结: 随便一个java项目,引入jar包: lucene-core-4.0.0.jar 如果是 maven项目,直接用如下依赖: <dependency> <groupId ...

  3. 2. github创建 git仓库,克隆,拉取和推送操作(所有的git命令前提是一定在当前项目目录下)

    步骤: 1.点击小猫,回到初始页面 2.点击start a project,首先会出现一个验证email地址(我们注册的时候,有一个email输入,进去邮箱验证一下) 3.重新点击start a pr ...

  4. ansible的主机的默认配置部分

    Ansible默认安装好后有一个配置文件/etc/ansible/ansible.cfg,该配置文件中定义了ansible的主机的默认配置部分,如默认是否需要输入密码.是否开启sudo认证.actio ...

  5. 百度富文本ueditor使用小结

    最近因工作需要使用了ueditor,根据自己的需求将开发使用时遇到的问题小结分享下. 1.可到官网根据自身情况下载最新版本,https://ueditor.baidu.com/website/ 2.h ...

  6. Java基础方法整理

    方法 9.1方法概述 方法就是用来完成解决某件事情或实现某个功能的办法 可以通过在程序代码中引用方法名称和所需的参数,实现在该程序中执行(或称调用)该方法.方法,一般都有一个返回值,用来作为事情的处理 ...

  7. HDFS集群优化篇

    HDFS集群优化篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.操作系统级别优化 1>.优化文件系统(推荐使用EXT4和XFS文件系统,相比较而言,更推荐后者,因为XF ...

  8. 【.NET】VS 本地调试 无法加载Json文件

    1.如果要是发布到iis,还加载不出来,那就要配置一下MIME类型: 2.本地调试时,无法加载json文件: 解决方案: 在web.config中添加如下配置:mimeMap <system.w ...

  9. Java面试题全集(下)转载

    Java面试题全集(下)   这部分主要是开源Java EE框架方面的内容,包括hibernate.MyBatis.spring.Spring MVC等,由于Struts 2已经是明日黄花,在这里就不 ...

  10. java io系列12之 BufferedInputStream(缓冲输入流)的认知、源码和示例

    本章内容包括3个部分:BufferedInputStream介绍,BufferedInputStream源码,以及BufferedInputStream使用示例. 转载请注明出处:http://www ...