python day08

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')) # 人

上一篇:Maven项目中,系统设置的CLASSPATH环境变量问题


下一篇:SQL: 某个时间段范围内,产品有价格,且求平均数