ascii码转换成字符:ord(str)

字符串转换成ascii:chr(int)

三种字符串

1、普通字符串  --以字符作为输出单位

  print(u'abc')  显示给用户看的字符串

2、二进制字符串  --以字节作为输出单位

  print(b'\xe4\xbd\x95\xe8\x8b\x8f\xe5\x81\xa5')   用于传输用

3、原义字符串  --以字符作为输出单位,所有普通字符串以原义输出

print('run\tagain\nstop')

print(r'run\tagain\nstop')     取消转义    不会自动换行,保持原字符串

文件操作的三步骤

1、打开文件  硬盘空间被操作系统持有,文件对象被应用程序持有

  f = open('a.txt','r',encoding='utf-8')

2、对文件进行操作  

  date = f.read()

3、关闭文件  释放文件(释放操作系统对硬盘空间的持有)

  f.close()

文件基本的读

f = open('a.txt','r',encoding='utf-8')

date = f.read()    -->一次性把所有文件都读出来

date = f.read(10)   -->一次读十个字符 

date = f.readline()    -->一次读一行

date = f.readlines()  -->分行一次性读出来,换行标识作为换行依据,存在同一个列表里。

f.close()

文件基本的写

w = open('a.txt','w',encoding='utf-8')

w.write('abc')    -->直接写入文件

w.flush()         -->将文件保存到文件夹

w.write('opq\nrst')   -->遇到换行标识就会自动换行

w.writelines(list)      -->一次添加多行,多行内容必须添加在同一个列表里,并且要标上标识符\n

w.close()      -->1、将文件保存到内存中   2、释放硬盘空间

with…open()语法

为了整合优化文件资源的打开与释放

  --再with的缩进内操作文件,一旦退出缩进,就会释放硬盘空间

part1:

with open('a.txt','r',encoding='utf-8') as f:

  date = f.read()  #进行一些对文件的操作指令

#一旦退出缩进,硬盘空间就被释放

part2

with open('a.txt','r',encoding='utf-8') as f,open('b.txt','r',encoding='utf-8') as v:  #同时打开两个文件

  #对两个文件的操作

part3:

with open('a.txt','r',encoding='utf-8') as f:

  with open('b.txt','r',encoding='utf-8') as v:

    date = f.read()

    date = v.read()

  date = f.read()  #可以进行操作

  date = v.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:可读可写,文件存在则在文件内容末尾追加写,文件不存在就先创建再写,文件操作采用字节方式

文件操作编码问题

1、在t模式下:文件保存采用什么编码,打开就用什么编码打开,不然会出现乱码,如果不写编码,就会用系统默认编码

  所以t模式下一定要指定编码--什么编码写,什么编码打开

2、在b模式下:硬盘文件保存的是二进制的字符串形式,写入也是提前编写好的二进制文件,电脑可以识别编码

  所以b模式下不需要去指定编码

文件的复制

with open('a.txt','r',encoding='utf-8') as rf:  #通过采用字符操作复制

  with open('b.txt','w',encoding='utf-8') as wf:

    for line in rf

      wf.write(line)  #可以把a文件一行一行的读出来并复制到b文件里

with open('a.txt','rb') as rf:  #通过采用字节操作复制

  with open('b.txt','wb') as wf:

    for line in rf

      wf.write(line)

游标操作

只有在r模式下才可以进行游标操作(游标操作的是字节)

with open('a.txt','rb') as rb:

  date = rb.read(10)

  f.seek(2,0)   #seek(offset,whence)    offset   前面的是游标移动的字节数,正数表示向后移动,负号表示向前移动。  

        逗号后面的数字在b模式下可以为0、1、2

        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 文件操作

    2019.4.8 S21 day08笔记总结 一.进制 对于计算机而言无论是文件存储 / 网络传输数据本质上都是:二进制(010101010101),如:电脑上存储视频/图片/文件都是二进制: QQ/ ...

  2. python day08作业答案

    1. a f=open('11.txt','r',encoding='utf-8') a=f.read() print(a) f.flush() f.close() b. f=open('11.txt ...

  3. python day08作业

  4. 铁乐学Python_day08_文件操作

    一.[基本的文件操作] 参数: 1.文件路径: 2.编码方式: 3.执行动作:(打开方式)只读,只写,追加,读写,写读! #1. 打开文件,得到文件句柄并赋值给一个变量 f = open('E:/Py ...

  5. Python面向对象进阶和socket网络编程-day08

    写在前面 上课第八天,打卡: 为什么坚持?想一想当初: 一.面向对象进阶 - 1.反射补充 - 通过字符串去操作一个对象的属性,称之为反射: - 示例1: class Chinese: def __i ...

  6. python开发学习-day08(socket高级、socketserver、进程、线程)

    s12-20160305-day08 *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: ...

  7. day08 python文件操作

    day08 python   一.文件操作     1.文件操作的函数         open(文件名, mode=模式, encoding=字符集)       2.模式: r, w, a, r+ ...

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

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

  9. 初学python之路-day08

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

随机推荐

  1. #Java学习之路——基础阶段二(第一篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

  2. asp.net core导出导入excel

    使用NPOI导入导出excel,已经封装好Action可以直接调用 导出 效果图 使用方法 定义导出实体 class Student { public int Id { get; set; } pub ...

  3. Python基础(解压序列)

    解压序列: a,b=(1,2) # a,b=[1,2] print(a,b) #输出结果:1 2 #获取第一个值和最后一个值 a,*_,c=(1,2,3,4,5,6,7,8,9) print(a) p ...

  4. sersync自动化同步部署

    目录 0. 前提: 1. 部署rsync server服务 1.1 配置rsync配置文件 1.2 rsync配置文件说明: 1.3 创建密码文件修改权限600 1.4 创建提示文件(可有可无) 1. ...

  5. .NET Core微服务之基于App.Metrics+InfluxDB+Grafana实现统一性能监控

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.关于App.Metrics+InfluxDB+Grafana 1.1 App.Metrics App.Metrics是一款开源的支持. ...

  6. 从零开始学习PYTHON3讲义(十二)画一颗心送给你

    (内容需要,本讲使用了大量在线公式,如果因为转帖网站不支持公式无法显示的情况,欢迎访问原始博客.) <从零开始PYTHON3>第十二讲 上一节课我们主要讲解了数值计算和符号计算.数值计算的 ...

  7. 深入学习ThreadLocal原理

    上文我们学习了ThreadLocal的基本用法以及基本原理,ThreadLocal中的方法并不多,基本用到的也就get.set.remove等方法,但是其核心逻辑还是在定义在ThreadLocal内部 ...

  8. asp.netcore 深入了解配置文件加载过程

    前言     配置文件中程序运行中,担当着不可或缺的角色:通常情况下,使用 visual studio 进行创建项目过程中,项目配置文件会自动生成在项目根目录下,如 appsettings.json, ...

  9. Generator和Async

    引言 接触过Ajax请求的会遇到过异步调用的问题,为了保证调用顺序的正确性,一般我们会在回调函数中调用,也有用到一些新的解决方案如Promise相关的技术. 在异步编程中,还有一种常用的解决方案,它就 ...

  10. 微信公众号开发C#系列-5、用户和用户组管理-支持同步

    1.概述 眼前时下流行的经济有个叫粉丝经济,粉丝带动收益.一个好运营良好的公众号肯定会有一大批的粉丝团,如何挖掘粉丝来产生效益,是微信营销的关键.微信公众号后台本身提供了粉丝(用户)与用户分组的管理, ...