day7 基础数据类型&集合&深浅拷贝
基础数据类型汇总:
#!/usr/bin/env python
# -*- coding:utf-8 -*- '''
str int
'''
# str
s = ' a'
print(s.isspace()) '''
list:
'''
li_st = [11, 22, 33, 44, 55]
for i in range(len(li_st)): # range()也是顾头不顾尾
del li_st[i] #del操作会更新列表 删掉所有偶数
for i in li_st:
if i % 2 == 0:
del li_st[li_st.index(i)]
print(li_st) dic = {'k1': 'v1', 'k2': 'v2', 'a3': 'v3'}
dic1 = {}
#循环字典过程中,不能删除字典的键值对;
for i in dic:
if 'k' in i:
del dic[i] 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是false:
# 0 '' [] () {} set() # 元组 如果元组里面只有一个元素且不加 逗号, 则此元素是什么类型,就是什么类型
tu1 = (1)
tu2 = (1,)
print(tu1,type(tu1))
print(tu2,type(tu2))
集合:
#!/usr/bin/env python
# -*- coding:utf-8 -*- '''
集合:
可变的数据类型;可以增删改查
储存元素必须是不可变的数据类型
无序,不重复,
{}
''' set1 = set({1, 2, 3})
set2 = {1, 2, 3, [1, 2, 3], {'name': 'alex'}} #报错,集合中的元素必须是可哈希的
print(set1)
print(set2) set1 = {'alex', 'wusir', 'ritian', 'egon', 'barry', 'barry'}
# 集合建立时可以重复元素,会在建立过程中自动去重操作
# 增
# add
set1.add('godress')
print(set1)
update
set1.update('abc')
print(set1) # 删
# pop 随机删除,集合为空的时候报错
name = set1.pop( )
print(name)
print(set1) # remove 按元素删除,元素不存在报错
set1.remove('barry')
print(set1) # 清空列表
set1.clear()
print(set1) # del 删除整个集合
del set1
print(set1) # 查
# 只能用for循环查询
for i in set1:
print(i) # 集合运算
set1 = {1, 2, 3, 4, 5}
set2 = {4, 5, 6, 7, 8}
set3 = set1 & set2
# 交集
print(set1 & set2)
print(set1.intersection(set2)) # 反交集
print(set1 ^ set2)
print(set1.symmetric_difference(set2)) # 并集
print(set1 | set2)
print(set1.union(set2)) # 差集
print(set1 - set2)
print(set1.difference(set2)) # 子集
set4 = {1, 2}
set5 = {1, 2, 3}
print(set4 < set5)
print(set4.issubset(set5)) # 超集
set4 = {1, 2}
set5 = {1, 2, 3}
print(set5 > set4)
print(set5.issuperset(set4)) # 将集合变为不可变数据类型,即只读集合
s = frozenset('barry')
print(s, type(s))
# 只能查询
for i in s:
print(i)
深浅拷贝:
#!/usr/bin/env python
# -*- coding:utf-8 -*- # 赋值
# l1 = [1, 2, 3, ['a', 'b', 'c']]
# l2 = l1
# print('original L1:', l1)
# print('original L2:', l2)
#
# l2[3][0] = 'k'
# print('changed L2:', l2)
# print('changed L1:', l1)
# 因为赋值操作是直接把两个变量(L1,L2)同时指向同一个内存地址,所以动一发而牵全身 # 浅拷贝
# l1 = [1, 2, 3, ['a', 'b', 'c']]
# l2 = l1.copy()
# print('original L1:', l1)
# print('original L2:', l2)
#
# l2[0] = 4
# l2[3][1] = 'k'
# print('changed L2:', l2)
# print('changed L1:', l1)
# 浅拷贝:将拷贝对象的值拷贝到另一个内存地址,但是拷贝对象的子代仍是和原来指向同一个内存地址 # 深拷贝
# import copy
# l1 = [1, 2, 3, ['a', 'b', 'c']]
# l2 = copy.deepcopy(l1)
# print('original L1:', l1)
# print('original L2:', l2)
# l2[0] = 4
# l2[3][1] = 'k'
# print('changed L2:', l2)
# print('changed L1:', l1)
# print(l2 is l1)
# 深拷贝,将拷贝对象的值全部重新拷贝到新的内存地址里
day7 基础数据类型&集合&深浅拷贝的更多相关文章
- Python基础知识(六)------小数据池,集合,深浅拷贝
Python基础知识(六)------小数据池,集合,深浅拷贝 一丶小数据池 什么是小数据池: 小数据池就是python中一种提高效率的方式,固定数据类型使用同一个内存地址 代码块 : 一个文 ...
- python学习打卡 day07 set集合,深浅拷贝以及部分知识点补充
本节的主要内容: 基础数据类型补充 set集合 深浅拷贝 主要内容: 一.基础数据类型补充 字符串: li = ["李嘉诚", "麻花藤", "⻩海峰 ...
- 巨蟒python全栈开发-第7天 基本数据类型补充&深浅拷贝
1.基本数据类型补充 2.深浅拷贝 DAY7-基本数据类型(基本数据类型补充&深浅拷贝) 本节主要内容: 1.补充基础数据类型 (1)join方法 (2)split方法 (3)列表不能在循环时 ...
- 6.Python初窥门径(小数据池,集合,深浅拷贝)
Python(小数据池,集合,深浅拷贝) 一.小数据池 什么是小数据池 小数据池就是python中一种提高效率的方式,固定数据类型,使用同一个内存地址 小数据池 is和==的区别 == 判断等号俩边的 ...
- python基础数据类型--集合(set)
python基础数据类型--集合(set) 集合是一个数学概念由一个或多个确定的元素所构成的整体叫做集合 集合中的三个特征 1.确定性(元素必须死可hash) 2.互异性(去重) 3.无序性(集合中的 ...
- 基础数据类型补充 set集合 深浅拷贝
一.基础数据类型补充 1. "拼接字符串".join(可迭代对象) 可迭代对象为列表时,输出列表元素与拼接字符串的拼接 li = ['张三', '李四', '王五', '赵四'] ...
- Python基础学习Day7 基础数据类型的扩展 集合 深浅copy
一.基础数据类型的扩展 1.1GBK ---> UTF - 8 # str --->bytes s1 = '太白' # 字符串是unicode编码 b1 = s1.encode('gbk' ...
- python day- 7 进本数据类型的先关知识点 set集合 深浅拷贝
一.基本数据类型相关知识 1.str. join()函数 关于字符串 a = "我爱北京" b = a.join("真的") 将&q ...
- Day7--Python--基础数据类型补充,集合,深浅拷贝
一.基础数据类型补充 1.join() 把列表中的每一项(必须是字符串)用字符串拼接 与split()相反 lst = ["汪峰", "吴君如", " ...
随机推荐
- qt creator源码全方面分析(2-1)
目录 coding-style.html 提交代码 二进制兼容性和源代码兼容性 代码构造 格式化 利用标识符 空格 大括号 圆括号 换行符 声明 命名空间 模式与实践 命名空间 传递文件名 插件扩展点 ...
- 自己封装的一个Ajax小框架
在经历了Jsp实训的惨痛教训后,特意花了点时间学习Ajax,学完后自我感觉良好,于是写了如下一个小框架: /** * frameAjax * * 参数: * paramsObj: Json * req ...
- 第3章 JDK并发包(四)
3.2.5 自定义线程创建:ThreadFactory 线程池的主要作用是为了线程复用,也就是避免了线程的频繁创建. ThreadFactory是一个接口,它只有一个方法,用来创建线程: Thread ...
- Python原来这么好学-1.2节: 在Linux中安装python
这是一本教同学们彻底学通Python的高质量学习教程,认真地学习每一章节的内容,每天只需学好一节,帮助你成为一名卓越的Python程序员: 本教程面向的是零编程基础的同学,非科班人士,以及有一定编程水 ...
- C++:重载前置++/--返回引用,重载后置++/--返回临时对象
标准库中iterator对++/--的重载代码如下: _Myiter& operator++() { // preincrement ++*(_Mybase *)this; return (* ...
- 大话IDL编程之函数功能调用(envi_doit、ENVIRaster、ENVITask)
2020年2月1日.好长时间没更新博客,还真有点不习惯.受新型冠性病毒的影响,平时街上熙熙攘攘的人流了无踪影,2020的春节竟然来的如此冷清.为响应“呆在家里就是做贡献的号召”,在家一宅就是十多天.闲 ...
- Linux7种运行模式
1)在超级权限下(#)vim /etc/inittab 2)文件内容模式的理解: 0 代表:关机模式(此模式 linux是关机状态) 1 代表:单用户模式(例如root的密码忘记了,可以在该模式下完成 ...
- 用Java反射输出对象的所有属性的值
获取对象的类类型 Class cls = obj.getClass(); 用类类型获取属性数组 getFields()获取的是共有属性 getDeclaredFields()可以获取所有属性 Fiel ...
- 使用sass语法生成自己的css的样式库
前言 先说一下 sass 和 scss的区别 sass 是一种缩进语法(即没有花括号和分号,只使用换行 缩进的方式去区别子元素,PS:这是我个人的理解) scss 是css-like语法 (它的语法 ...
- qt creator源码全方面分析(2-0)
目录 Extending Qt Creator Manual 生成领域特定的代码和模板 代码片段 文件和项目模板 自定义向导 支持其他文件类型 MIME类型 高亮和缩进 自定义文本编辑器 其他自定义编 ...