《Python》 基础数据类型补充和深浅copy
一.基础数据类型的补充
元组:
如果元组中只有一个数据,且没有逗号,则该‘元组’数据类型与里面的数据类型一致
列表:
列表之间可加不可减,可跟数字相乘
l1=['wang','rui']
l2=['chen']
l3=l1+l2
print(l3)
将列表中索引为奇数的元素,全部删除:
l1=[11,22,33,44,55,66,77,88]
l2=[]
(1)del l1[1::2]
print(l1)
(2)for i in l1:
if i % 2 ==1:
l2.append(i)
l1=l2
print(l1)
(3)for i in range(len(l1)-1,-1,-1):
if i % 2==1:
l1.pop(i)
print(l1)
在循环一个列表时,如果对列表中的某些元素进行删除,
那么此元素后面的所有元素就会向前进一位,他们的索引就会发生变化。
在循环一个列表时,最好不要对此列表进行改变大小(增删)的操作。
字典:
fromkeys():创建一个新的字典 只改变key,不改变values
dic1 = dict.fromkeys([1,2,3],'alex')
print(dic1)
面试题:创建字典的方式
1,
dic = {'name':'alex'}
2,
dic = dict({'name':'alex'})
print(dic)
3, fromkeys() 陷阱:
dic1=dict.fromkeys([1,2,3],[])
print(dic1)
dic1[1].append(666)
print(dic1)
print(id(dic1[1]))=print(id(dic1[2]))=print(id(dic1[3])) 二、集合set
set:
集合要求里面的元素必须是不可变的数据类型,但是集合本身是可变的数据类型
集合里面的元素不重复,无序。
用途:去重、关系测试 list去重
l1=[1,2,3,4,1,1,2,3]
set1=set(l1)
print(set1) 集合的增删:
set1={'yang','wang',1,2,3}
set1.add('zhang') 增
print(set1)
set1.update('abc') 迭代增加
print(set1)
set1.remove(1) 删 元素
print(set1)
set1.pop() 随机
print(set1)
set1.clear() 清空
print(set1)
del set1 删除
print(set1)
关系测试:
set1={1,2,3,4,5}
set2={1,2,3,6,7}
print(set1&set2) 交集
print(set1.intersection(set2))
print(set1|set2) 并集
print(set1.union(set2))
print(set1^set2) 反交集
print(set1.symmetric_difference(set2))
print(set1-set2) 差集
print(set2.difference(set1)) set3={1,2,3}
set4={1,2,3,4,5}
print(set3<set4) 子集
print(set3.issubset(set4))
print(set3>set4) 超集
print(set3.issuperset(set4)
set1={1,2,3}
set2=frozenset(set1) #冻
print(set2)
frozenset 不可变的数据类型
三、深浅copy
浅copy:
l1=[1,2,3,4,[22,1]]
l2=l1.copy()
l1.append(999)
print(l2)
l1[-1].append(999)
print(l2) 深copy:
import copy
l1=[2,3,4,5,[7,8]]
l2=copy.deepcopy(l1)
print(l2)
l1[-1].append(666)
print(l2) 应用场景:
深copy:完全独立的copy一份数据,与原数据无关系。
浅copy:如果一份数据,第二层开始,你想与原数据进行共用。 面试题:
切片属于浅copy
《Python》 基础数据类型补充和深浅copy的更多相关文章
- Python基础数据类型补充及深浅拷贝
本节主要内容:1. 基础数据类型补充2. set集合3. 深浅拷贝主要内容:一. 基础数据类型补充首先关于int和str在之前的学习中已经讲了80%以上了. 所以剩下的自己看一看就可以了.我们补充给一 ...
- python基础(9):基本数据类型四(set集合)、基础数据类型补充、深浅拷贝
1. 基础数据类型补充 li = ["李嘉诚", "麻花藤", "⻩海峰", "刘嘉玲"] s = "_&qu ...
- python基础数据类型补充
python_day_7 一. 今日主要内容: 1. 补充基础数据类型的相关知识点 str. join() 把列表变成字符串 列表不能再循环的时候删除. 因为索引会跟着改变 字典也不能直接循环删除.把 ...
- Python 基础之函数、深浅copy,set及练习
三元运算符通常在Python里被称为条件表达式,这些表达式基于真(true)/假(not)的条件判断,在Python 2.4以上才有了三元操作. 语法格式: X if C else Y 有了三元表达式 ...
- 基本数据类型补充,深浅copy
#str s=' ' #只能是以至少一个空格组成的字符串(全空格) print(s.isspace()) #tuple 当元组只有一个元素组成,并没有",",则该元素是什么数据类型 ...
- Python——基础数据类型(补充)
1.基础数据类型汇总补充 (1)小数据池: 为了节省空间,数字和字符串有,其他的没有[了解] 数字:-5---256之间的数字共用一个内存地址 #(1)i1 = i2 id(i1) == id ...
- python基础数据类型补充以及编码的进阶
一.基本数据类型的补充循环列表改变列表大小的问题#请把列表中索引为基数的元素写出l1=[1,2,3,4,5,6]for i in l1: if i%2!=0: print(i)结果:135二:基本数据 ...
- python之数据类型补充、集合、深浅copy
一.内容回顾 代码块: 一个函数,一个模块,一个类,一个文件,交互模式下,每一行就是一个代码块. is == id id()查询对象的内存地址 == 比较的是两边的数值. is 比较的是两边的内存地址 ...
- 基础数据类型补充 set集合 深浅拷贝
一.基础数据类型补充 1. "拼接字符串".join(可迭代对象) 可迭代对象为列表时,输出列表元素与拼接字符串的拼接 li = ['张三', '李四', '王五', '赵四'] ...
随机推荐
- PHP Extension
新手搞PHP ,之前用过 PERL, BASH: 所以开始用PHP 写程序上手比较快, 几天之后对PHP 的内部实现机制产生了兴趣,所以自己尝试着写写简单的PHP 扩展,以增加对PHP 的理解. ...
- linux性能分析工具之火焰图
一.环境 1.1 jello@jello:~$ uname -a Linux jello 4.4.0-98-generic #121-Ubuntu SMP Tue Oct 10 14:24:03 UT ...
- P1471 方差
题目 luogu 思路 \[\frac{1}{n}*\sum_{1}^{n}( a_{i}-A)^{2}\] \[\frac{1}{n}*\sum_{1}^{n}( a_{i}^2-2*A*a_{i} ...
- Linq 对List的一些操作
代码: public class Person { public int ID { get; set; } public string Name { get; set; } public int Ag ...
- 【附1】hystrix详述(1)
一.hystrix的作用 控制被依赖服务的延时和失败 防止在复杂系统中的级联失败 可以进行快速失败(不需要等待)和快速恢复(当依赖服务失效后又恢复正常,其对应的线程池会被清理干净,即剩下的都是未使用的 ...
- samba基本应用24-4及示例
samba smb:service message block(137/udp, 138/udp, 139/tcp, 445/tcp) 协议是:CIFS:Common Internet File Sy ...
- 读jQuery源码有感
读之前的预备工作: 1.基础的js知识,以及html和css知识,和正则表达式知识.可以参考妙味课堂的基础js,html和css大纲. 2.JavaScript核心指南的知识http://www.cn ...
- python 阶乘
product= i= : product=i*product print('i=%d' %i,end='') print('\tproduct=%d' %product) i+= print('\n ...
- 【Golang 接口自动化08】使用标准库httptest完成HTTP请求的Mock测试
前言 Mock是一个做自动化测试永远绕不过去的话题.本文主要介绍使用标准库net/http/httptest完成HTTP请求的Mock的测试方法. 可能有的小伙伴不太了解mock在实际自动化测试过程中 ...
- Codeforces D - The Child and Zoo
D - The Child and Zoo 思路: 并查集+贪心 每条边的权值可以用min(a[u],a[v])来表示,然后按边的权值从大到小排序 然后用并查集从大的边开始合并,因为你要合并的这两个联 ...