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 = ["汪峰", "吴君如", " ...
随机推荐
- C语言创建文件夹
问题需求:在程序中需要使用文件夹时,一般可以先在程序目录或某一路径下创建一个文件夹,然后使用该文件夹. 这种方法比较麻烦,需提前创建文件夹. 使用C语言创建文件夹的代码可以如下: #include & ...
- k8s基本命令
kubernetes 常用命令 通过yaml文件创建: kubectl create -f xxx.yaml (不建议使用,无法更新,必须先delete) kubectl apply -f xxx.y ...
- P4语言环境安装(一)前端编译器p4c、后端编译器p4c-bm2-ss
这个P4安装环境是在2020-2-8安装的,安装环境卡了我好几天,把遇到的问题记录下来,有需要的同学可以参考一下,要是说错了或者有问题的话,评论或mail:guidoahead@163.com联系我都 ...
- Arduino系列之LCD1602模块使用方法(一)
下面我将简单介绍LCD1602模块的使用方法: 1602液晶显示器(1602 Liquid Crystal Display,此后简称1602 LCD)是一种常见的字符液晶显示器,因其能显示16*2个字 ...
- 7、EIGRP
EIGRP Cisco私有协议1.高级距离矢量路由协议(混杂型hybrid)单播和组播结合,组播更新地址: 224.0.0.10 2.最快速收敛 (使用Diffusing Update 算法(DUAL ...
- 【大白话系列】MySQL 学习总结 之 初步了解 MySQL Server 的 binlog 组件
一.上节回顾 上节我们讲到,建议将 redo log 的刷盘策略设置为1:即提交事务时,强制将 redo log buffer 里的 redo log 刷入到磁盘后才算事务提交成功. 但是我们都知道, ...
- js笔记(2)--第一天记录
---恢复内容开始--- 模仿了网站的一个常见小功能,开关灯小功能. 代码: <!DOCTYPE html> <html lang="en"> <he ...
- POJ_1050_最大子矩阵
http://poj.org/problem?id=1050 这道题是最大子串的扩展,遍历过每一个子矩阵就好了,期间用了最大子串的方法. #include<iostream> #inclu ...
- 曹工说Spring Boot源码(18)-- Spring AOP源码分析三部曲,终于快讲完了 (aop:config完整解析【下】)
写在前面的话 相关背景及资源: 曹工说Spring Boot源码(1)-- Bean Definition到底是什么,附spring思维导图分享 曹工说Spring Boot源码(2)-- Bean ...
- JAVA中的约瑟夫环和猴子王问题
今天在书上(书名< java程序设计经典300例 >李源编著)看了一个有趣的问题,那就是java版的约瑟夫问题,想必大一的小伙伴们早就用c写过了吧 今天我在复习一下 首先问题是这样的n个人 ...