2019.4.4 S21  day07笔记总结

一、深浅拷贝

  • 1.copy.copy()     浅拷贝

    deep.copy()    深拷贝

  • 2.一般情况

    • 1.str/int/bool 是不可变类型,他们的深浅拷贝都是一样的,就是在内存中新开辟空间来存储。

      应该每次都拷贝一份,但由于小数据池,未拷贝,所有存储地址一样。

    • 2.list/dict/set 是可变类型

      • 浅拷贝:只拷贝到第一层(即空壳,里面元素的地址不会改变。)

      • 深拷贝:拷贝所有数据(可变的)(找到所有可变层的数据层拷贝一份,里面可变层的地址也会改变。

      • 应该每次都拷贝一份,地址不一样(但由于小数据池,未拷贝)。

      • 只有出现嵌套时,深拷贝才有意义,没有时就和浅拷贝的意义一样(只拷贝第一层)。

      • 总结:浅拷贝:只拷贝到第一层

        深拷贝:拷贝嵌套层次中所有的可变类型(可变就拷贝,不可变就不拷贝)。

  • 3.特殊情况

    a.元组不可变

    例:v1 = (1,2,3)

    imfort copy

    v2 = copy.copy(v1)

    print(id(v1),id(v2))   # v1、v2地址一样

    v3 = copy.deepcopy(v1)

    print(id(v1),id(v3))   # v1、v3地址一样

    b.元组不可变,但元组中的列表/字典/集合都是可变的,元组中就存在了可变类型。

    例:v1 = (1,2,3,[1,2,3],4)

    imfort copy

    v2 = copy.copy(v1)

    print(id(v1),id(v2))   # v1、v2地址一样

    v3 = copy.deepcopy(v1)

    print(id(v1),id(v3))   # v1、v3地址不一样

    元组中有可变的,深拷贝拷贝到可变层。

    总结:拷贝只针对可变类型:再创造一份

    不可变类型不会拷贝(再创造一份出来,都是用同一个地址~同时指向一个地址)

二、文件操作

1.打开

  • 1.读取 r

    打开文件

    file_object = open('log.txt',mode = 'r',encoding = 'utf-8')

    '#  log.txt' 文件路径   encoding = 'utf-8' 存储时的方式,用什么方式存储就用什么方式读取

    读取内容

    content= file_object.read()

    print(content)

    关闭文件

    file_object.close()

    r 只读不能写,文件不存在则报错。

  • 2.写入 w

    打开文件

    file_object = open('log.txt',mode = 'w',encoding = 'utf-8')

    写入内容

    file_object.write('李忠伟')

    关闭文件

    file_objet.close()

    w 只写不能读

    w 要慎重使用,使用 w 打开文件时是先清空文件再写入内容的。一般用于新建文件(文件不存在则新建)。

  • 3.追加 a

    打开文件

    file_object = open('log.txt',mode = 'a',encoding = 'utf-8')

    写内容

    file_object.write('你好')

    关闭文件

    file_objet.close()

    a 只追加不能读,只在文件内容的最后面追加。

    文件不存在则新建

  • 4.可读可写 r+

    打开文件

    file_object = open('log.txt',mode = 'r+',encoding = 'utf-8')

    file_object.seek(3)     # 把光标移到第3个字节的位置

    file_object.write('999')

    读取内容

    content= file_object.read()

    print(content)

    file_object.write('666')

    关闭文件

    file_object.close()

    1.读取

    2.写入时:根据光标的位置,从当前光标位置开始进行写入操作(可能会将光标后其他的文字覆盖)

  • 5.可读可写 w+

    file_object = open('log.txt',mode = 'w+',encoding = 'utf-8')

    data = file_object.read()

    print(data)   # 文件是空的

    file_object.write('alex')   # a

    file_object.seek(0)         #  b

    file_object.read()           #  c

    '# a+b+c这三步:a 写完后光标在最后面,想要进行 c 读取,需要在 c 前加入 b 将光标跳到0

    print(data)

    file_object.close()

    写入时会将文件清空,读取时需要调整光标的位置。

  • 6.可读可写 a+

    file_object = open('log.txt',mode = 'a+',encoding = 'utf-8')

    file_object.seek(0)

    data = file_object.read()

    print(data)

    file_object.seek(0)

    file_object.write('666')

    file_object.close()

  • 7.总结:

    • r 只能读  (* *)

    • w 只能写   (* *)

    • a  只能追加    (*)

    • r+

      读:默认从0的光标开始读,也可以通过seek调整光标的位置。

      写:从光标所在的位置开始写,也可以通过seek调整光标的位置。

    • w+

      读:默认光标永远在写入的最后或0(打开清空了还没写入时在0的位置),也可以通过seek调整光标的位置。

      写:先清空

    • a+

      读:默认光标在最后,也可以通过seek调整光标的位置,然后再去读取。

      写:永远写到最后

2.操作

  • 1.读操作

    file_object = open('log.txt',mode = 'r',encoding = 'utf-8')

    data = file_object.read()         # 读取文件的所有内容到内存

    data = file_object.read(2)       # 从当前光标所在的位置向后读取文件两个字符

    data_list = file_object.readlines()      # 读取文件的所有内容到内存,并按照每一行进行分割到列表中。 (每行结尾会隐藏着一个换行符 \n)

    如果以后读取一个特别大的文件:

    方式一:start = 0

    while True:

    data = file_object.read(2)

    print(data)

    file_object.close()   # 最后一直在循环空,终止条件不好设定。

    方式二:for line in file_object:

    line = line.strip()  # 打印完后每行都存在一个换行符,strip 不但能去除空白,也能去除换行符\n

    print(line)       (*****)

  • 2.写操作

    file_object = open('log.txt',mode = 'w',encoding = 'utf-8')

    file_object.write('你好')            #  '你好小黑'写在一行

    file_object.write('你好\n')         #  '你好' 与 '小黑' 写成两行

    file_object.write('小黑')

    file_object.close()

    写完后一定要记得关闭(close)文件,如果没关闭就相当于写的东西直接到内存了。

    关闭文件(close)就强制将内存刷到硬盘上了

  • 总结:文件操作和数据类型的结合使用

python day07笔记总结的更多相关文章

  1. Web Scraping with Python读书笔记及思考

    Web Scraping with Python读书笔记 标签(空格分隔): web scraping ,python 做数据抓取一定一定要明确:抓取\解析数据不是目的,目的是对数据的利用 一般的数据 ...

  2. python学习笔记整理——字典

    python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...

  3. VS2013中Python学习笔记[Django Web的第一个网页]

    前言 前面我简单介绍了Python的Hello World.看到有人问我搞搞Python的Web,一时兴起,就来试试看. 第一篇 VS2013中Python学习笔记[环境搭建] 简单介绍Python环 ...

  4. python学习笔记之module && package

    个人总结: import module,module就是文件名,导入那个python文件 import package,package就是一个文件夹,导入的文件夹下有一个__init__.py的文件, ...

  5. python datetime笔记

    python datetime笔记 http://mint-green.diandian.com/post/2011-09-09/4892024 获取当前时间,并通过字符串输出. 格式为:%Y-%m- ...

  6. python学习笔记(六)文件夹遍历,异常处理

    python学习笔记(六) 文件夹遍历 1.递归遍历 import os allfile = [] def dirList(path): filelist = os.listdir(path) for ...

  7. python学习笔记--Django入门四 管理站点--二

    接上一节  python学习笔记--Django入门四 管理站点 设置字段可选 编辑Book模块在email字段上加上blank=True,指定email字段为可选,代码如下: class Autho ...

  8. python学习笔记--Django入门0 安装dangjo

    经过这几天的折腾,经历了Django的各种报错,翻译的内容虽然不错,但是与实际的版本有差别,会出现各种奇葩的错误.现在终于找到了解决方法:查看英文原版内容:http://djangobook.com/ ...

  9. python学习笔记(一)元组,序列,字典

    python学习笔记(一)元组,序列,字典

随机推荐

  1. Visual Studio安装Visual Assist的办法(兼容VS2010至VS2017)

    Visual Assist可以说是一个码代码的高效帮手,有了它,敲起代码速度杠杠的,但是有时候安装破解老是出问题,这一次,我自己尝试了几次,跟着网上的教程做了做,改了改,结合之前安装的经验,最后总算安 ...

  2. Excel文件上传,高亮错误的行和列

    /// <summary> /// Excel模板写入错误信息 /// </summary> /// <param name="fileName"&g ...

  3. 机器学习实战ch04 关于python版本所支持的文本格式问题

    函数定义中: def spamTest(): docList=[]; classList = []; fullText =[] for i in range(1,26):# print('cycle ...

  4. 工控随笔_09_西门子_S7-200 Smart与V20 USS通信USS_RPM_R利用轮询的方式通讯异常

    前两天处理过一个故障,是S7-200 Smart与V20的USS通讯,设备厂家在程序里面利 用USS_RPM _R程序循环轮询5个V20设备读取频率和电流值等信息. 图 USS_RPM_R读取信息 上 ...

  5. ARC085E MUL

    https://atcoder.jp/contests/arc085/tasks/arc085_c 题目大意 略 解法 最小割即可. 直接建图有负边,但是因为我们知道最后在割上的边数一定为 \(N\) ...

  6. python之路——23

    复习 1.类定义 函数--方法--动态属性 必须传self 变量--类属性--静态属性 __init__方法--初始化方法2.实例化 1.使用:对象 = 类() 2.实例和对象没有区别 3.对象调用方 ...

  7. Oracle数据库ORA-01109 数据库未打开

    引致 https://blog.csdn.net/colinmok/article/details/39504879?locationNum=11&fps=1  感谢! 在plsql创建了2表 ...

  8. C语言数据结构基础学习笔记——树

    树是一种一对多的逻辑结构,树的子树之间没有关系. 度:结点拥有的子树数量. 树的度:树中所有结点的度的最大值. 结点的深度:从根开始,自顶向下计数. 结点的高度:从叶结点开始,自底向上计数. 树的性质 ...

  9. docker安装elasticsearch及head插件

    使用 Docker 拉取ElasticSearch镜像 docker pull elasticsearch:7.0.0 查看镜像 ID docker images 运行 docker run -e E ...

  10. scrapy使用指南

    创建scrapy项目: scrapy startproject 项目名 cd到项目名下 scrapy genspider 爬虫名 www.baidu.com(网站网址) 之后按照提示创建爬虫文件(官方 ...