每天一篇总结,今天学习了大概有深浅拷贝,元组类型,字典类型与集合类型。第一次感觉有点难度,需要花费多点时间来掌握。

深浅拷贝,分为值拷贝、浅拷贝、深拷贝。

ls = [1, 'abc', [10]]

值拷贝:ls1 = ls  ==> ls1直接将ls中存放的地址拿过来

值拷贝的具体表现: ls1直接将ls中存放的地址拿过来。当ls内部的值发生任何变化时,ls1与ls中存放的地址时一致的,因此ls1必定随之变化。

浅拷贝:ls2 = ls.copy()

浅拷贝后,ls2是新开辟空间来存放ls中存放的地址,但列表中的地址都是直接从ls列表中拿来。因此ls内部的可变类型值发生改变,ls2会随之变化;ls2内部的不可变类型值地址还是与原来地址相连,因此不会变化。

深拷贝:ls3 = deepcopy(ls)

深拷贝后,ls3是新开辟空间来存放ls中存放的地址,但由于pycharm的优化机制,不改变类型数据地址不变,但是列表中的地址是需要新开辟空间来存放地址的。最后的结果:ls内部的所有类型的值发生改变,ls3都不会随之变化。

元组类型:

元组:可以理解为不可变的列表
   1.值可以为任意类型
   2.可以存放多个值 - 可以进行成员运算
   3.可以存放重复的值 - 可以计算成员出现的次数
   4.有序存储 - 可以通过索引取值,可以切片

元组的常用操作:

1.索引取值
  print(t1[1], type(t1[1]))
  print(t1[-3])

2.运算(拼接)
  print((1, 2) + (2, 3))

3.长度
  print(len(t1))

4.切片
  print((2, 1, 3)[::-1])

5.成员运算
  print(True in t1)
  print(False in t1) False == 0, t1中如果有0或False,该结果都是True

6.for循环
  for obj in t1:
  print(obj, end=" ")
  print()

元组的使用方法:count  |  index

print(t1.count(0)) 对象0在元组中出现的次数

print(t1.index(123, 4, len(t1))) 对象0在区间4~末尾第一次出现的索引

字典类型:

字典概念:

1.容器(集合):存放多个值的变量
  2.单列容器(系统中的单列容器很多):list | tuple
  3.双列容器(map):只有dict,存放数据 成对出现,dict存放数据采用 key-value键值对方式

字典的须知:

  1. 字典中的key可以为什么类型:key必须为不可变类型
  2. key是取value的唯一依据,key一旦被确定,就需要唯一确定(不能被改变)
  3. 字典中的value可以为什么类型:value可以为任意类型
  4. value是用来存放世间所有存在的数据

key要确保唯一性,不能重复,值可以重复,并且可以被改变 => 字典为可变类型

dic = {'a': 10, 1: 20, True: 30, (): 40} 1和True都是1,key具有唯一性,所以只保留最后一次值
print(dic) {'a': 10, 1: 30, (): 40}

字典的定义:

1.空字典
  d1 = {}
  d2 = dict()
2.用map映射创建字典
  d3 = dict({'a': 1, 'b': 1})
  print(d3)
3.用关键字赋值方式
  d4 = dict(name='Bob', age=18) 参数=左侧的名字就是合法的变量名,都会被转化为字符串形式的key
  print(d4)
4. 创建有多个key值采用默认值的方式: 默认值不写默认None,也可以自定义
  d5 = {}.fromkeys('abc', 0)
  print(d5)

字典的常用操作:

dic = {'a': 1, 'b': 2}
print(dic)

1.增: 字典名[key] = 值 => key已存在就是修改值,不存在就是新增值
  dic['c'] = 3
  print(dic)
2.改
  dic['c'] = 30
  print(dic)
3.查:字典名[key]
  print(dic['c']) 只能查找已有的key,没有崩溃
有默认值的查询:有key取出对应value,没有返还默认值,默认值可以自定义
  print(dic.get('d', 'http://www.baidu.com'))

4.删
  print(dic)

5.清空
  dic.clear()
  pop(k)删除指定key的value并返还删除的value
  res = dic.pop('a')
  从dic末尾删除,返还(key, value)形成的元组
res = dic.popitem()
print(dic, res)

其他的方法:

1.更新: a有值覆盖,c没被新操作,带下来,b为新增,增加并赋值

dic = {'a': 1, 'c': 2}
d = {'a': 10, 'b': 20}
dic.update(d)
print(dic) {'a': 10, 'c': 2, 'b': 20}

2.带默认值的新增: 新增key,key已有,啥事不干,没有添加key,值就是第二个参数

dic.setdefault('z', 100)
print(dic)

字典的循环:

1.直接循环,就是循环得到key
   for k in dic:
   print(k)

2.循环keys
  print(dic.keys())
   for k in dic.keys():
   print(k)

3.循环values
   print(dic.values())
   for v in dic.values():
  print(v)

同时循环key和value (key, value)
  print(dic.items())
  a, b = (1, 2)
  print(a, b)
  for res in dic.items():
  print(res)
  重点:
  for k, v in dic.items():
  print(k, v)

解压赋值
  a, _, _, b = (1, 2, 3, 4)

集合类型:

s=set()

此为空集合,虽然集合都是用{}表示,但是{}代表的是空字典。

集合概念:

  1. 1.set为可变类型 - 可增可删
  2. 2.set为去重存储 - set中不能存放重复数据
  3. 3.set为无序存储 - 不能索引取值
  4. 4.set为单列容器 - 没有取值的key
  5. 总结:set不能取值

集合的使用方法:

1.增

s.add('1')
s.add('2')
s.add('1')
print(s)
s.update({'2', '3'})
print(s)

2.删

res = s.pop()
print(res)
s.remove('1')
print(s)
s.clear()
print(s)

集合set运算:

1.交集:两个都有 &
py = {'a', 'b', 'c', 'egon'}
lx = {'x', 'y', 'z', 'egon'}
print(py & lx)
print(py.intersection(lx))

2.合集:两个的合体 |
print(py | lx)
print(py.union(lx))

3. 对称交集:抛出共有的办法的合体 ^
print(py ^ lx)
print(py.symmetric_difference(lx))

4. 差集:独有的
print(py - lx)
print(py.difference(lx))

5. 比较:前提一定是包含关系
s1 = {'1', '2'}
s2 = {'2'}
print(s1 < s2)

初学python之路-day06的更多相关文章

  1. 初学python之路-day12

    本篇补上字符串的比较:按照从左往右比较每一个字符,通过字符对应的ascii进行比较 一.函数默认值的细节 # 如果函数的默认参数的默认值为变量,在所属函数定义阶段一执行就被确定为当时变量存放的值 a ...

  2. 初学python之路-day10

    基础部分先告一段落,今天开始学习函数. 一.函数:完成 特定 功能的代码块,作为一个整体,对其进行特定的命名,该名字就代表函数         -- 现实中:很多问题要通过一些工具进行处理 => ...

  3. 初学python之路-day08前期总结

    # 1# 计算机原理:控制器 运算器 存储器 input设备 output设备 IO流# 三大核心:CPU 内存 硬盘 # 内存分布:栈区 与 堆区# 如二进制与十进制的转换,如1111转成十进制为1 ...

  4. 初学python之路-day08

    #学习了编码后,还要了解三种字符串.# 一.# 普通字符串:u''以字符作为输出单位,# print(u'abc') # 用于显示abc# # 二进制字符串:b'' 二进制字符串以字节作为输出单位# ...

  5. 初学python之路-day07-字符编码

    今天的博客主要关于字符编码,并对前几天学习的数据类型做些总结. 学习字符编码的目的:解决乱码问题. 应用程序打开文本文件的三步骤  1.打开应用程序  2.将数据加载到内存中  3.cpu将内存中的数 ...

  6. 初学python之路-day04

    每天一篇总结,今天学习的是有关于流程控制的知识. 流程控制,顾名思义,在计算机运行中,程序是被某种控制方式按照某种流程或者规律来执行的.而python程序的运行,肯定也是按照某种规律在执行.这些规律可 ...

  7. 初学python之路-day03

    我在前面的文章提到了变量的概念,这里详细介绍下变量的命名.变量名,只能是字母.数字及下划线 "_" 任意组成,而且不能以数字开头.在命名变量时,尽量避免与系统关键词重名,如:'an ...

  8. 初学python之路-day02

    python,诞生于1989年的圣诞,Guido van Rossum为了打发无聊,因此发明了python,并且开放了其源代码,使得这门语言在随后的几十年的发展的越来越广.现今,2.x版本已经在2.7 ...

  9. 初学python之路-day01

    第一天学习python,先了解到了进制之间的转换关系. 如二进制与十进制的转换,如1111转成十进制为15,1111从左向右可看出2^3+2^2+2^1+2^0为8+4+2+1=15.记住前8位1的二 ...

随机推荐

  1. NodeJS脚本启动工具总结

    1. 使用npm 2. 使用pm2 安装: npm install pm2 -g 启动: NODE_ENV=test pm2 start newsCrawler.js 停止: pm2 stop new ...

  2. [2019.03.16]使用DOM操作函数和CSS选择器来针对已有的HTML进行只凭JS的改动

    刚入职的时候看到公司用的HTML日志生成工具附带的Panel,工具不够用,找个Fail还要找半天,于是自己琢磨着添砖加瓦.以前也是个半吊子前端工程师,现在可倒好,想要改页面却连页面生成的模板在哪里都不 ...

  3. .Net Core 环境下构建强大且易用的规则引擎

    本文源码: https://github.com/jonechenug/ZHS.Nrules.Sample 1. 引言 1.1 为什么需要规则引擎 在业务的早期时代,也许使用硬编码或者逻辑判断就可以满 ...

  4. openstack虚拟机内核崩溃问题解决

    openstack对接的kvm虚拟化环境,创建虚拟机后无法进如系统,一直卡在call Trace . 解决办法: 更改配置文件的cpu-model,libvirt_cpu_mode = custom ...

  5. CAN通信帧ID如何设定?

    CAN总线ID是包含在报文帧中的. 1.主要用作CAN总线的仲裁使用,所以一般来说网络上的每个节点(向总线上发送)的ID应该有所不同.ID值越低,报文优先级越高,在两组不同ID报文同时上线时候,仲裁机 ...

  6. yii2 gridview默认排序

    Yii2 GridView 使用起来很方便,但是默认排序很是个问题,数据默认按 主键 正序排列 但是在使用过程中,大多数数据默认是 倒序才符合正常思维的. 第一次 的解决方法是在 直接为 Model添 ...

  7. 升级AndroidStudio3.4问题汇总

    1.Could not get unknown property 'bootClasspath' for object of type org.gradle.api.tasks.compile.Com ...

  8. P4180 严格次小生成树[BJWC2010] Kruskal,倍增

    题目链接\(Click\) \(Here\). 题意就是要求一个图的严格次小生成树.以前被题面吓到了没敢做,写了一下发现并不难. 既然要考虑次小我们就先考虑最小.可以感性理解到一定有一种次小生成树,可 ...

  9. LA4080/UVa1416 Warfare And Logistics 最短路树

    题目大意: 求图中两两点对最短距离之和 允许你删除一条边,让你最大化删除这个边之后的图中两两点对最短距离之和. 暴力:每次枚举删除哪条边,以每个点为源点做一次最短路,复杂度\(O(NM^2logN)\ ...

  10. 011 Socket定义客户端

    引入命名空间: using System.Net; using System.Net.Sockets; using System.Threading;