1,判断字符串是不是空格isspace函数

s1 = ' '
s2 = ' ssss'
print(s1.isspace())
print(s2.isspace()) 运行结果:
True
False

2,list和dict不可以边循环边删除,删除其中一个,index就变了

li = ["apple","pear","peach","watermelon",'grape']
# 要求删除里面所有的项
for i in range(len(li)):
del li[i] # 错误原因,不可以边循环,边删除,因为删除每一个之后,index就变了,后面的循环就无效了,dict也是这个原因 运行结果:
Traceback (most recent call last):
File "/Users/guolixiao/PycharmProjects/lisa's_practise/boys/7.1.py", line 18, in <module>
del li[i]
IndexError: list assignment index out of range
dict1 = {"name1":"lisa","name2":"lucy","hobby":"piano"}

# 删掉name的key
for i in dict1:
if "name" in i:
del dict1[i] 运行结果:
Traceback (most recent call last):
  File "/Users/guolixiao/PycharmProjects/lisa's_practise/boys/7.1.py", line 25, in <module>
    for i in dict1:
RuntimeError: dictionary changed size during iteration

3,如何解决上面的问题呢?利用逆向思维,找出要删除的项之外的项,放到另外一个dict或者list里面,然后在赋值给原来的list即可

dict1 = {"name1":"lisa","name2":"lucy","hobby":"piano"}
for i in dict1:
if "name" not in i:
dict2.setdefault(i,dict1[i]) dict1 = dict2
print(dict1.items()) 运行结果:
dict_items([('hobby', 'piano')])

4,如果不想这样的话,可以单独把要删除的项找出来,组成一个单独的list,然后再删除,只是不要一边循环原来的字典一边从原来的的字典里面删除就行,因为这样会打乱已有的循环动作

dict1 = {"name1":"lisa","name2":"lucy","hobby":"piano"}
li2 = []
for i in dict1:
if "name" in i:
li2.append(i) for i in li2: # 发现没循环的不是原来的dict,是新生成的列表
del dict1[i] print(dict1.items()) 运行结果:
dict_items([('hobby', 'piano')])

5,空字典 { }  空集合set(),由于大括号给字典用了了,空字典[] ,空元祖() ,所有这些空值,bool值是false,元祖只有一个值的时候注意加上一个逗号,不然原来是什么类型,还是什么类型

print(type(1))
print(type(1,)) print(type("sss"))
print(type("sss",)) 运行结果:
<class 'int'>
<class 'int'>
<class 'str'>
<class 'str'>

6,集合是可变的数据类型,它里面的数据类型,必须是不可变的数据类型。不可变,意味着可哈希

set1 = {1,2,3,(4,5),"sss",True}
print(set1) 运行结果:
{1, 2, 3, (4, 5), 'sss'} set2 = {"str",[1,2,3],{"name":"alex"}}
print(set2)
运行结果:
Traceback (most recent call last):
File "/Users/guolixiao/PycharmProjects/lisa's_practise/boys/7.2_set.py", line 12, in <module>
set2 = {"str",[1,2,3],{"name":"alex"}}
TypeError: unhashable type: 'list'

7,集合添加元素add函数

set1 = {1,2,3,(4,5),"sss",True}
print(set1)
set1.add("lisa")
print(set1) # 集合是无序的,找一找,看看新加的元素添加到哪儿啦? 运行结果:
{1, 2, 3, (4, 5), 'sss'}
{'lisa', 1, 2, 3, (4, 5), 'sss'}

8,set也可以迭代增加,把增加的元素,按照最小单位拆分添加update

set1 = {1,2,3,(4,5),"sss",True}
print(set1)
set1.add("lisa")
print(set1) # 集合是无序的,找一找,看看新加的元素添加到哪儿啦?
set1.update("bobocddd") # 这儿无序,去重,迭代添加都体现出来了
print(set1) 运行结果:
{1, 2, 3, (4, 5), 'sss'}
{1, 2, 3, (4, 5), 'lisa', 'sss'}
{1, 2, 3, 'b', (4, 5), 'd', 'lisa', 'o', 'c', 'sss'}

9,删除,pop (remove return arbitrary refer to the introduction of this function)

set1 = {1,2,3,(4,5),"sss",True}
print(set1.pop())
print(set1) 运行结果:
1
{2, 3, (4, 5), 'sss'}

10,删除的另外一种方法,remove ,无返回值,但是如果指定的元素不存在的话,程序会崩溃

set1 = {1,2,3,(4,5),"sss",True}
print(set1.remove("sss"))
print(set1) # 无返回值
运行结果:
None
{1, 2, 3, (4, 5)}
set1 = {1,2,3,(4,5),"sss",True}
print(set1.remove("XXX",))
print(set1) 运行结果:
Traceback (most recent call last):
File "/Users/guolixiao/PycharmProjects/lisa's_practise/boys/7.2_set.py", line 28, in <module>
print(set1.remove("XXX",))
KeyError: 'XXX'

11,清空集合 clear函数,

12,删除集合 del 函数 ,注意清空完是空集合,del完集合就彻底没了

13,集合也可以遍历,按照for....in....

14,求交集,就是数学概念里面的交集 符号& 或者函数intersection

set1 = {1,2,3,(4,5),"sss",True}
set2 = {3,(4,5),"kkk"}
print(set1&set2)
print(set1.intersection(set2)) 运行结果:
{(4, 5), 3}
{(4, 5), 3}

15,求并集,符号|和函数union

set1 = {1,2,3,(4,5),"sss",True}
set2 = {3,(4,5),"kkk"} print(set1|set2)
print(set1.union(set2)) 运行结果:
{'sss', 1, 2, 3, 'kkk', (4, 5)}
{'sss', 1, 2, 3, 'kkk', (4, 5)}

16,反交集 符号^ 或者函数symmetric_difference

set1 ={1,2,3,4,5,6,7}
set2 ={4,5,6,7,8,9,0}
print(set1^set2)
print(set1.symmetric_difference(set2)) 运行结果:
{0, 1, 2, 3, 8, 9}
{0, 1, 2, 3, 8, 9}

17,set1 独有的,符号-和different函数

set1 ={1,2,3,4,5,6,7}
set2 ={4,5,6,7,8,9,0} print(set1-set2) # set1独有的
print(set2-set1) # set2独有的 print(set1.difference(set2))
print(set2.difference(set1)) 运行结果:
{1, 2, 3}
{0, 8, 9}
{1, 2, 3}
{0, 8, 9}

18,子集与超集合 符号> 和符号<

set1 ={1,2,3,4,5,6,7}
set2 ={1,2,3,4} print(set1>set2) #超集
print(set1.issuperset(set2)) #超集
print(set2<set1) #子集
print(set2.issubset(set1)) #子集 运行结果:
True
True
True
True

19,列表去重,先转化为set再把set转化为列表

li = [1,2,3,4,5,6,6,5,4,3,7,6,5,4]
set1 =set(li)
print(set1)
li=list(set1)
print(li) 运行结果:
{1, 2, 3, 4, 5, 6, 7}
[1, 2, 3, 4, 5, 6, 7]

20,深浅copy 浅copy不会改变孙子里面地址,只是儿子地址变了,深copy完完全全一个新的,函数copy和deepcopy

21,enumerate函数

li = ['lisa', 'mary', 'lucy', 'hh']
for i in enumerate(li):
print(i) 运行结果:
(0, 'lisa')
(1, 'mary')
(2, 'lucy')
(3, 'hh') # 可以指定起始位置,自我感觉用处不是很大:
li = ['lisa', 'mary', 'lucy', 'hh']
for i in enumerate(li,3):
print(i) 运行结果:
(3, 'lisa')
(4, 'mary')
(5, 'lucy')
(6, 'hh')

22,集合变成不可变的,frozenset

set1 ={1,2,3,4,5,6,7}
set1=frozenset(set1) #生成一个新的set,注意要赋值回去
print(set1,type(set1))
set1.add(9) 运行结果:
frozenset({1, 2, 3, 4, 5, 6, 7}) <class 'frozenset'>
File "/Users/guolixiao/PycharmProjects/lisa's_practise/boys/7.2_set.py", line 67, in <module>
set1.add(9)
AttributeError: 'frozenset' object has no attribute 'add'

day7:set和深浅copy的更多相关文章

  1. python 全栈开发,Day7(元组转换,列表以及字典的坑,集合,关系测试,深浅copy,编码补充)

    一.元组转换 数字 tu = (1) tu1 = (1,) print(tu,type(tu)) print(tu1,type(tu1)) 执行输出: 1 <class 'int'>(1, ...

  2. Python基础学习Day7 基础数据类型的扩展 集合 深浅copy

    一.基础数据类型的扩展 1.1GBK ---> UTF - 8 # str --->bytes s1 = '太白' # 字符串是unicode编码 b1 = s1.encode('gbk' ...

  3. python基础3(元祖、字典、深浅copy、集合、文件处理)

    本次内容: 元祖 字典 浅copy和深copy 集合 文件处理 1.1元祖 元祖(tuple)与列表类似,不同之处在于元祖的元素不能修改,元祖使用小括号(),列表使用方括号[].元祖创建很简单,只需要 ...

  4. python学习笔记三 深浅copy,扩展数据类型(基础篇)

    深浅copy以及赋值 对于字符串和数字而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. import copy n1 = #n1 = 'hahahaha' #赋值n2 = n1#浅co ...

  5. Python 第三篇(下):collections系列、集合(set)、单双队列、深浅copy、内置函数

     一.collections系列: collections其实是python的标准库,也就是python的一个内置模块,因此使用之前导入一下collections模块即可,collections在py ...

  6. Python 基础之函数、深浅copy,set及练习

    三元运算符通常在Python里被称为条件表达式,这些表达式基于真(true)/假(not)的条件判断,在Python 2.4以上才有了三元操作. 语法格式: X if C else Y 有了三元表达式 ...

  7. python基础(三)编码,深浅copy

    编码,深浅copy encode,decode在python2中使用的一些迷糊,python3中更容易理解 要理解encode和decode,首先我们要明白编码,字符和二进制的相关概念,简单来说,计算 ...

  8. Python 集合 深浅copy

    一,集合. 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. ...

  9. 基础数据类型的补充和深浅copy

    一:关于str 的操作方法补充 1,s.isspace()   判断字符串是否只由空格组成,是,为True,否则,为False. s = ' ' #只能是以至少一个空格组成的字符串(全空格) prin ...

随机推荐

  1. 9.4 翻译系列:EF 6以及 EF Core中的NotMapped特性(EF 6 Code-First系列)

    原文链接:http://www.entityframeworktutorial.net/code-first/notmapped-dataannotations-attribute-in-code-f ...

  2. 云服务器 - 安装zookeeper单机环境

    由于电脑中病毒,被人当做肉鸡挖矿了...所以很多东西都要重装, 之前没有写过zk如何安装,所以安装的时候顺便来记录一下分享出来 第一步上传zk安装包到服务器,如图: 解压: tar -zxvf zoo ...

  3. 微信小程序场景值

    场景值 基础库 1.1.0 开始支持,低版本需做兼容处理 当前支持的场景值有: 场景值ID 说明 1001 发现栏小程序主入口 1005 顶部搜索框的搜索结果页 1006 发现栏小程序主入口搜索框的搜 ...

  4. Android开发(十六)——Android listview onItemClick事件失效的原因

    参考: Android listview onItemClick事件失效的原因.http://blog.csdn.net/wangchun8926/article/details/8793178

  5. github建库不成功,不能用SVN上传

    说明(2017-12-7 11:37:35): 1. 之前用SVN向gihub提交代码没有一点问题,昨天新建了一个仓库,结果死活提交不上去,以为是SVN的问题,折腾了一天都没弄好. 2. github ...

  6. Android Launcher分析和修改12——Widget列表信息收集

    很久没写Launcher分析的文章,最近实在太忙.今天七夕本来是想陪女朋友逛街 ,碰巧打台风呆在家里,就继续写一篇文章.今天主要是讲一下Launcher里面的Widget列表,这方面信息比较多,今天重 ...

  7. 【iCore1S 双核心板_ARM】例程四:USART通信实验——通过命令控制LED

    实验原理: 开发板上自带一片CH340芯片,完成本实验电脑需要安装CH340驱动, CH340的TXD连接STM32的GPIO(PB6),CH340的RXD连接STM32的 GPIO(PB7),通过串 ...

  8. Linux查看文件总的数据行数,并按行拆分

    先利用 wc -l BLM.txt       读出 BLM.txt 文件一共有多少行. 再 1. 以行数拆分 -l 参数: split –l 50 原始文件 拆分后文件名前缀 例:以50行对文件进行 ...

  9. Gsoap编译

    gSOAP编译工具提供了一个SOAP/XML 关于C/C++ 语言的实现,从而让C/C++语言开发web服务或客户端程序的工作变得轻松了很多.gSOAP支持大多数平台,包括嵌入式系统和小系统. 你首先 ...

  10. Oracle Grid 11.2.0.4 安装是出现“[INS-41112] Specified network interface doesnt maintain connectivity across cluster”错误

    最新文章:Virson's Blog 安装Oracle 11.2.0.4 的RAC,在Grid 安装时报错: [INS-41112]Specified network interface doesnt ...