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. 通用Mapper简单使用

    通用Mapper 1.通用Mapper的使用 1.0.实体类 @Table(name = "tb_user") public class User { @Id @Generated ...

  2. Linux系统编程——Daemon进程

    目录 Daemon进程介绍 前提知识 Daemon进程的编程规则 Daemon进程介绍 Daemon运行在后台也称作"后台服务进程". 它是没有控制终端与之相连的进程.它独立与控制 ...

  3. Java中的io流学习(了解四大基类和基本步骤)

    Java中io流四大基类及io流操作四大基本步骤 io流:(input/output)即输入输出流.面向对象的思想之一是面向接口编程,面向父类编程,也就是多态.所以学好基类(父类)很重要. 分类 按处 ...

  4. 实现Linux下od -tx -tc XXX的功能

    实现Linux下od -tx -tc XXX的功能 一.od命令 (1)功能 od命令用于将指定文件内容以八进制.十进制.十六进制.浮点格式或ASCII编码字符方式显示,通常用于显示或查看文件中不能直 ...

  5. 2、Netty基础

    一.前言 主要包含下面内容: 初识 Netty: 使用 Java NIO 搭建简单的客户端与服务端实现网络通讯: 使用 Netty 搭建简单的客户端与服务端实现网络通讯: Netty 底层操作与 Ja ...

  6. nmcli配置ipv6

    nmcli配置ipv6 作者:Eric 微信:loveoracle11g [root@racooler ~]# nmcli connection show eno16777736 | grep ipv ...

  7. 02-Tomcat服务器安装

    由于使用的是解压绿色版,所以解压就可以使用,如下图显示 启动成功

  8. 《深度探索C++对象模型》读书笔记(一)

    前言 今年中下旬就要找工作了,我计划从现在就开始准备一些面试中会问到的基础知识,包括C++.操作系统.计算机网络.算法和数据结构等.C++就先从这本<深度探索C++对象模型>开始.不同于& ...

  9. Spring Boot 集成 logback日志

    application.properties 配置logback.xml 路径注:如果logback.xml在默认的 src/main/resources 目录下则不需要配置application.p ...

  10. JAVA相关技术

    开发服务器环境: 1.Linux系统 CentOS 6.5\7 2.JDK1.8 3.tomcat 9 4.mysql 5.7 开发环境: 1.开发集成工具:idea 2.构建工具maven 仓库暂时 ...