初学python之路-day08
#学习了编码后,还要了解三种字符串。# 一、# 普通字符串: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的更多相关文章
- 初学python之路-day08前期总结
# 1# 计算机原理:控制器 运算器 存储器 input设备 output设备 IO流# 三大核心:CPU 内存 硬盘 # 内存分布:栈区 与 堆区# 如二进制与十进制的转换,如1111转成十进制为1 ...
- 初学python之路-day12
本篇补上字符串的比较:按照从左往右比较每一个字符,通过字符对应的ascii进行比较 一.函数默认值的细节 # 如果函数的默认参数的默认值为变量,在所属函数定义阶段一执行就被确定为当时变量存放的值 a ...
- 初学python之路-day10
基础部分先告一段落,今天开始学习函数. 一.函数:完成 特定 功能的代码块,作为一个整体,对其进行特定的命名,该名字就代表函数 -- 现实中:很多问题要通过一些工具进行处理 => ...
- 初学python之路-day07-字符编码
今天的博客主要关于字符编码,并对前几天学习的数据类型做些总结. 学习字符编码的目的:解决乱码问题. 应用程序打开文本文件的三步骤 1.打开应用程序 2.将数据加载到内存中 3.cpu将内存中的数 ...
- 初学python之路-day04
每天一篇总结,今天学习的是有关于流程控制的知识. 流程控制,顾名思义,在计算机运行中,程序是被某种控制方式按照某种流程或者规律来执行的.而python程序的运行,肯定也是按照某种规律在执行.这些规律可 ...
- 初学python之路-day03
我在前面的文章提到了变量的概念,这里详细介绍下变量的命名.变量名,只能是字母.数字及下划线 "_" 任意组成,而且不能以数字开头.在命名变量时,尽量避免与系统关键词重名,如:'an ...
- 初学python之路-day02
python,诞生于1989年的圣诞,Guido van Rossum为了打发无聊,因此发明了python,并且开放了其源代码,使得这门语言在随后的几十年的发展的越来越广.现今,2.x版本已经在2.7 ...
- 初学python之路-day01
第一天学习python,先了解到了进制之间的转换关系. 如二进制与十进制的转换,如1111转成十进制为15,1111从左向右可看出2^3+2^2+2^1+2^0为8+4+2+1=15.记住前8位1的二 ...
- Python之路Day08
文件操作 open() -- 打开 open通过Python控制操作系统打开文件 f=open('文件路径',mode='r',encoding='utf-8') mode -- 不写就默认是r f ...
随机推荐
- angular-nvd3初体验
<!DOCTYPE html> <html lang="en" ng-app="myApp"> <head> <met ...
- kettle变量(var变量)
设置变量/set varibale 1.定义变量(子转换): 原始数据 设置获取变量:点击获取字段,自动获取变量名称和字段名称 引用变量: 输出: kettle.properties 文件存储在.ke ...
- 【pytorch】pytorch-LSTM
pytorch-LSTM() torch.nn包下实现了LSTM函数,实现LSTM层.多个LSTMcell组合起来是LSTM. LSTM自动实现了前向传播,不需要自己对序列进行迭代. LSTM的用到的 ...
- Spring框架知识整理
Spring框架主要构成 Spring框架主要有7个模块: 1.Spring AOP:面向切面编程思想,同时也提供了事务管理. 2.Spring ORM:提供了对Hibernate.myBatis的支 ...
- Linux C Socket简单实例与详细注释
最近做的东西与socket十分紧密,所以很好奇它具体是如何实现的,以前也有了解过,但是又忘记了,于是把它记录下来,以便日后查看. 服务器端:server.c #include <sys/type ...
- python并发编程之多进程基础知识点
1.操作系统 位于硬件与应用软件之间,本质也是一种软件,由系统内核和系统接口组成 和进程之间的关系是: 进程只能由操作系统创建 和普通软件区别: 操作系统是真正的控制硬件 应用程序实际在调用操作系统提 ...
- <TCP/IP原理> (二) OSI模型和TCP/IP协议族
1.OSI参考模型 1)作用 2)各层的名称和功能 2.对分层网络协议体系的理解 1)不同节点:层次组成不同,作用不同 2)横向理解:虚通信.对等实体.协议.PDU 3)纵向理解:封装与解封.服务.接 ...
- Spring Boot整合Elasticsearch
Spring Boot整合Elasticsearch Elasticsearch是一个全文搜索引擎,专门用于处理大型数据集.根据描述,自然而然使用它来存储和搜索应用程序日志.与Logstash和K ...
- 洛谷P3159 交换棋子 神奇的网络流
神奇的建模...原题链接 如果你真的把交换看成交换,就\(GG\)了.首先我们要把交换看成是白棋的移动. 然后,很容易的就想到建模的大致思路:建立超级源点S和超级汇点T,从S向初始局面每个白棋所在的格 ...
- Struts2 返回 json 格式数据
最近由于工作原因,没时间更新,那些没能看到的同学,很抱歉了,话不多说,继续写~~ 关于json的返回需要用到一个工具包来将书转换为json格式,在此用到的jar包为: import net.sf.js ...