#学习了编码后,还要了解三种字符串。# 一、# 普通字符串:u''以字符作为输出单位,# print(u'abc')  # 用于显示abc# # 二进制字符串:b'' 二进制字符串以字节作为输出单位# print(b'abc')#b'abc'# # # 原义字符串:r''以字符作为输出单位,所有在普通字符串中能被转义的符号在这都原样输出# print(u'a\tb\nc')# #a   b# #c# print(r'a\tb\nc')#a\tb\nc# # print(r'F:\python\1.三种字符串.py')#F:\python\1.三种字符串.py## # 二、文件操作的三步骤# # 1.打开文件: 硬盘空间被操作系统持有,文件对象被应用程序持有# f = open('source.txt', 'r', encoding='utf-8')# ## # 2.操作文件# data = f.read()#读  当然还有写  f.write# ## # 3.释放文件:释放操作系统对硬盘空间的持有# f.close()# # 三、基础的写# wf = open('target.txt', 'w', encoding='utf-8')## wf.write('123\n')  # 一次写一条,行必须用\n标识# wf.write('456\n')# wf.flush()  # 向操作系统发送一条将内存中写入的数据刷新到硬盘# wf.write('789\n')# wf.writelines(['abc\n', 'def\n', 'xyz\n'])  # 一次写多行,行必须用\n标识## wf.close()  # 1.将内存中写入的数据刷新到硬盘 2.释放硬盘空间

# 四、with...open语法# 优化整合了文件资源的打开与释放#     -- 在with的缩进内可以操作文件对象,一旦取消缩进,资源就被释放了

# part1# as起别名,rf持有文件资源的变量# with open('target.txt', 'r', encoding='utf-8') as rf:# 文件操作的具体代码# 缩进一旦取消缩进,资源就被释放了

# part2# with open('target.txt', 'r', encoding='utf-8') as rf1, open('target1.txt', 'r', encoding='utf-8') as rf2:#     print(rf1.read())#     print(rf2.read())## # print(rf1.read())  # 报错# # print(rf2.read())  # 报错### # part3# with open('target.txt', 'r', encoding='utf-8') as rf1:#     with open('target1.txt', 'r', encoding='utf-8') as rf2:#         print(rf1.read())#         print(rf2.read())#     # print(rf1.read())  # 可以操作#     # print(rf2.read())  # 不可以操作# 五、文件的操作模式# 主模式:r | w | a | x#     -- 主模式只能选取一个,规定着主要的操作方式# 从模式:t | b | +#     -- 从模式也必须出现,但个数不一定是一个,为主模式额外添加功能## r: 读,必须有# w: 清空写,可有可无# a: 追加写,可有可无# x:创建写,必须无## t:默认,按字符操作# b:按字节操作# +:可读可写## # rt: 文件必须提前存在,不存在报错,文件操作采用字符形式 - 简写为 r# # wt: 文件可以存在,也可以不存在,存在则清空后写入,不存在新建后写入,文件操作采用字符形式 - 简写为 w# # at: 文件可以存在,也可以不存在,存在在之前内容的末尾追加写入,不存在新建后写入,文件操作采用字符形式 - 简写为 a## # rb: 文件必须提前存在,不存在报错,文件操作采用字节形式# # wb: 文件可以存在,也可以不存在,存在则清空后写入,不存在新建后写入,文件操作采用字节形式# # ab: 文件可以存在,也可以不存在,存在在之前内容的末尾追加写入,不存在新建后写入,文件操作采用字节形式## # r+t:文件必须存在的可读可写,默认从头开始替换写,按字符操作# # w+t:文件存在清空不存在创建的可读可写,按字符操作# # a+t:文件存在追加不存在创建的可读可写,按字符操作## # r+b:文件必须存在的可读可写,默认从头开始替换写,按字节操作# # w+b:文件存在清空不存在创建的可读可写,按字节操作# # a+b:文件存在追加不存在创建的可读可写,按字节操作

# 六、文件的操作编码问题# t模式下:原文件采用什么编码,你就选取什么编码操作,如果不选取,默认跟操作系统保持一致#  -- t模式下一定要指定编码## b模式下:硬盘的数据就是二进制,且能根据内容识别出编码,写入时的数据也是通过某种编码提前处理好的,所有在操作时,没有必要再去规定编码## #七、文件的复制# # 文本文件的复制:可以t也可以b# with open('target.txt', 'r', encoding='utf-8') as rf:#     with open('target2.txt', 'w', encoding='utf-8') as wf:#         for line in rf:#             wf.write(line)## with open('target.txt', 'rb') as rf:#     with open('target3.txt', 'wb') as wf:#         for line in rf:#             wf.write(line)

## # 非文本文件只能采用b模式操作,不需要指定编码 - 因为根本不涉及编码解码过程# with open('001.mp4', 'rb') as rf:#     with open('002.mp4', 'wb') as wf:#         for line in rf:#             wf.write(line)# #九、 游标操作## ```python# # 1.游标操作的是字节,所有只能在b模式下进行操作# # 2.游标操作可以改变操作位置,r模式下可以改变位置进行操作,所有主模式选择r模式# # 3.seek(offset, whence):# #       -- offset为整数就是往后偏移多少个字节,负数就是往前偏移多少个字节# #       -- whence:0代表将游标置为开头,1代表从当前位置,2代表将游标置为末尾### # 你是日本人# with open('target.txt', 'rb') as f:#     # 先读6个字节#     data = f.read(6)#     print(data.decode('utf-8'))  # 你是#     # 将游标从头开始往后偏移3个字节#     f.seek(3, 0)#     data = f.read(6)#     print(data.decode('utf-8'))  # 是日#     # 从当前游标位置往前偏移3个字节#     f.seek(-3, 1)#     data = f.read(3)#     print(data.decode('utf-8'))  # 日##     f.seek(-3, 2)#     data = f.read(3)#     print(data.decode('utf-8'))  # 人

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

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

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

  2. 初学python之路-day12

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

  3. 初学python之路-day10

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

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

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

  5. 初学python之路-day04

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

  6. 初学python之路-day03

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

  7. 初学python之路-day02

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

  8. 初学python之路-day01

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

  9. Python之路Day08

    文件操作 open() -- 打开 open通过Python控制操作系统打开文件 f=open('文件路径',mode='r',encoding='utf-8') mode -- 不写就默认是r f ...

随机推荐

  1. mac 开发环境安装

    0: 安装brew : mac终端输入: /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/ ...

  2. 科学地增加postgresql最大连接数

    PG配置文件路径 /etc/postgresql/9.3/main/postgresql.conf 首先如何查看最大连接数 This SQL will help you select max_conn ...

  3. PAT 甲级真题题解(63-120)

    2019/4/3 1063 Set Similarity n个序列分别先放进集合里去重.在询问的时候,遍历A集合中每个数,判断下该数在B集合中是否存在,统计存在个数(分子),分母就是两个集合大小减去分 ...

  4. CF235B Let's Play Osu! 期望DP

    貌似是一道很裸的期望\(DP\).直接说思路: 设\(f[i]\)表示到\(i\)位置时的期望分数,但是只有\(f[i]\)的话我们发现是无法转移的,我们还需要知道到\(i\)位置时的期望连续长度,于 ...

  5. [BJOI2019]奥术神杖(分数规划+AC自动机+DP)

    题解:很显然可以对权值取对数,然后把几何平均值转为算术平均值,然后很显然是分数规划.先对每个模式串建立AC自动机,每个节点w[i],sz[i]分别表示以其为前缀的字符串,然后再二分最优解k,然后w[i ...

  6. GWAS基因芯片数据预处理:质量控制(quality control)

    一.数据为什么要做质量控制 比起表观学研究,GWAS研究很少有引起偏差的来源,一般来说,一个人的基因型终其一生几乎不会改变的,因此很少存在同时影响表型又影响基因型的变异.但即便这样,我们在做GWAS时 ...

  7. jstl标签库需要两个包jstl.jar和standard.jar

    要使用jstl的标签库,将文件复制到WEB-INF/lib目录下,需要在jsp源文件的首部加入如下声明语句(一般放在page语句之后) 核心(core)   <%@ taglib uri=&qu ...

  8. linux系统裁剪

    linux系统裁剪 1.简介 最近为了更加了解linux系统的启动过程,通过对系统进行裁剪的的方式来了解整个启动流程.这里记录下过程. 2.环境介绍 vmware12 + centos6.5 + xs ...

  9. Ansible-基础

    Ansible架构 Inventory   主机清单,可以对主机分组 ansible-hoc   ansible的命令,适用临时场景 ansible-playbook   ansible是一个场景的集 ...

  10. Redies安装,修配置,设置密码,

    Redies下载路径:https://github.com/MicrosoftArchive/redis/releases 我下的是Redis-x64-3.2.100.msi 下载后安装,一步一步操作 ...