python学习day09

with 上下文管理

使用with…as 关键字
上下文管理的语句块并不会开启新的作用域
with语句块执行完的时候,会自动关闭文件对象

为了避免打开文件后忘记关闭,可以通过管理上下文,即:
with open('log','r') as f:
    ...
如此方式,当with代码块执行完毕时,内部会自动关闭并释放文件资源。
打开多个文件:
with open('yesterday','r',encoding='utf-8') as f,\
        open('yesterday2','r',encoding='utf-8') as f2:
  ...
# 例子:打开单个文件yesterday2文件内容:
1:www.runoob.com
2:www.runoob.com
3:www.runoob.com
4:www.runoob.com
7:www.runoob.com
# 代码
with open('yesterday2','r',encoding='utf-8') as f:
    for line in f:
        print(line.strip())
# 执行结果
1:www.runoob.com
2:www.runoob.com
3:www.runoob.com
4:www.runoob.com
7:www.runoob.com


# 注解:
with open('yesterday2','r',encoding='utf-8') as f:   
# 等同于
f=open('yesterday2','r',encoding='utf-8')
f.close()
# 例子:打开多个文件
yesterday文件内容:
f1:www.runoob.com
f1:www.runoob.com
f1:www.runoob.com
f1:www.runoob.com
f1:www.runoob.com
yesterday2文件内容:
f2:www.runoob.com
f2:www.runoob.com
f2:www.runoob.com
f2:www.runoob.com
f2:www.runoob.com

# 代码
with open('yesterday','r',encoding='utf-8') as f,\
        open('yesterday2','r',encoding='utf-8') as f2:
    for line in f:
        print(line.strip())
    for line2 in f2:
        print(line2.strip())
# 执行结果
f1:www.runoob.com
f1:www.runoob.com
f1:www.runoob.com
f1:www.runoob.com
f1:www.runoob.com
f2:www.runoob.com
f2:www.runoob.com
f2:www.runoob.com
f2:www.runoob.com
f2:www.runoob.com

file对象读写文件的方法

file.read()

file.read([size]) 从文件读取指定的字节数,如果未给定或为负则读取所有。(仅限于文件比较小的时候使用)
//概述
read() 方法用于从文件读取指定的字节数,如果未给定或为负则读取所有。
//语法
read() 方法语法如下:
fileObject.read(); 
//参数
size -- 从文件中读取的字节数。
//返回值
返回从字符串中读取的字节。
//实例
以下实例演示了 read() 方法的使用:
文件 runoob.txt 的内容如下:
这是第一行
这是第二行
这是第三行
这是第四行
这是第五行
循环读取文件的内容:
#!/usr/bin/python3
# 打开文件
fo = open("runoob.txt", "r+")
print ("文件名为: ", fo.name)
line = fo.read(10)    #从头开始读取,一共读取10个字节
print ("读取的字符串: %s" % (line))
# 关闭文件
fo.close()
以上实例输出结果为:
文件名为:  runoob.txt
读取的字符串: 这是第一行
这是第二

详解

file.readline()

file.readline([size]) 读取整行,包括 "\n" 字符。
//概述
readline() 方法用于从文件读取整行,包括 "\n" 字符。如果指定了一个非负数的参数,则返回指定大小的字节数,包括 "\n" 字符。

//语法
readline() 方法语法如下:
fileObject.readline(); 
//参数
size -- 从文件中读取的字节数。
//返回值
返回从字符串中读取的字节。
//实例
以下实例演示了 readline() 方法的使用:
文件 runoob.txt 的内容如下:
1:www.runoob.com
2:www.runoob.com
3:www.runoob.com
4:www.runoob.com
5:www.runoob.com
循环读取文件的内容:
# 打开文件
fo = open("runoob.txt", "r+")
print ("文件名为: ", fo.name)
line = fo.readline()
print ("读取第一行 %s" % (line))
line = fo.readline(5)
print ("读取的字符串为: %s" % (line))

# 关闭文件
fo.close()
以上实例输出结果为:
文件名为:  runoob.txt
读取第一行 1:www.runoob.com
读取的字符串为: 2:www

file.readlines()

file.readlines([sizeint]) 读取所有行并返回列表,若给定sizeint>0,返回总和大约为sizeint字节的行, 实际读取值可能比 sizeint 较大, 因为需要填充缓冲区。(仅限于文件比较小的时候使用)
//概述
readlines() 方法用于读取所有行(直到结束符 EOF)并返回列表,该列表可以由 Python 的 for... in ... 结构进行处理。 如果碰到结束符 EOF 则返回空字符串。
如果碰到结束符 EOF 则返回空字符串。
语法
readlines() 方法语法如下:
fileObject.readlines( );
//参数
无。
//返回值
返回列表,包含所有的行。
//实例
以下实例演示了 readlines() 方法的使用:
文件 runoob.txt 的内容如下:
1:www.runoob.com
2:www.runoob.com
3:www.runoob.com
4:www.runoob.com
5:www.runoob.com
循环读取文件的内容:
实例(Python 3.0+)
#!/usr/bin/python3
# 打开文件
fo = open("runoob.txt", "r")
print ("文件名为: ", fo.name)
for line in fo.readlines():                          #依次读取每行  
    line = line.strip()                             #去掉每行头尾空白  
    print ("读取的数据为: %s" % (line))
# 关闭文件
fo.close()
以上实例输出结果为:
文件名为:  runoob.txt
读取的数据为: 1:www.runoob.com
读取的数据为: 2:www.runoob.com
读取的数据为: 3:www.runoob.com
读取的数据为: 4:www.runoob.com
读取的数据为: 5:www.runoob.com

详解

file.readable()

readable   判断文件是否可读
//代码
f=open("yesterday",'r+')  #文件句柄
print(f.readable())
f.close()
//执行结果
True

file.write()

file.write(str) 将字符串写入文件,返回的是写入的字符长度。
//概述
write() 方法用于向文件中写入指定字符串。
在文件关闭前或缓冲区刷新前,字符串内容存储在缓冲区中,这时你在文件中是看不到写入的内容的。
如果文件打开模式带 b,那写入文件内容时,str (参数)要用 encode 方法转为 bytes 形式,否则报错:TypeError: a bytes-like object is required, not 'str'//语法
write() 方法语法如下:
fileObject.write( [ str ])
//参数
str -- 要写入文件的字符串。
//返回值
返回的是写入的字符长度。
//实例
文件 runoob.txt 的内容如下:
1:www.runoob.com
2:www.runoob.com
3:www.runoob.com
4:www.runoob.com
5:www.runoob.com
以下实例演示了 write() 方法的使用:
#!/usr/bin/python3
# 打开文件
fo = open("runoob.txt", "r+")
print ("文件名: ", fo.name)
str = "6:www.runoob.com"
# 在文件末尾写入一行
fo.seek(0, 2)
line = fo.write( str )
# 读取文件所有内容
fo.seek(0,0)
for index in range(6):
    line = next(fo)
    print ("文件行号 %d - %s" % (index, line))
# 关闭文件
fo.close()
以上实例输出结果为:
文件行号 0 - 1:www.runoob.com
文件行号 1 - 2:www.runoob.com
文件行号 2 - 3:www.runoob.com
文件行号 3 - 4:www.runoob.com
文件行号 4 - 5:www.runoob.com
文件行号 5 - 6:www.runoob.com
查看文件内容:
$ cat runoob.txt 
1:www.runoob.com
2:www.runoob.com
3:www.runoob.com
4:www.runoob.com
5:www.runoob.com
6:www.runoob.com

file.writelines()

file.writelines(sequence) 向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。
//概述
writelines() 方法用于向文件中写入一序列的字符串。
这一序列字符串可以是由迭代对象产生的,如一个字符串列表。
换行需要制定换行符 \n。
//语法
writelines() 方法语法如下:
fileObject.writelines( [ str ])
//参数
str -- 要写入文件的字符串序列。
//返回值
该方法没有返回值。
//实例
以下实例演示了 writelines() 方法的使用:
#!/usr/bin/python3
# 打开文件
fo = open("test.txt", "w")
print ("文件名为: ", fo.name)
seq = ["菜鸟教程 1\n", "菜鸟教程 2"]
fo.writelines( seq )
# 关闭文件
fo.close()
以上实例输出结果为:
文件名为:  test.txt
查看文件内容:
菜鸟教程 1
菜鸟教程 2

file.writeable()

writable   判断文件是否可写
//代码
f=open("yesterday",'r+')  #文件句柄
print(f.writable())
f.close()
//执行结果
True

file.close()关闭文件

file.close() 关闭文件。关闭后文件不能再进行读写操作。
//概述
close() 方法用于关闭一个已打开的文件。关闭后的文件不能再进行读写操作, 否则会触发 ValueError 错误。 close() 方法允许调用多次。
当 file 对象,被引用到操作另外一个文件时,Python 会自动关闭之前的 file 对象。 使用 close() 方法关闭文件是一个好的习惯。
//语法
close() 方法语法如下:
fileObject.close();
//参数
无
//返回值
该方法没有返回值。
//实例
以下实例演示了 close() 方法的使用:
#!/usr/bin/python3
# 打开文件
fo = open("runoob.txt", "wb")
print("文件名为: ", fo.name)
# 关闭文件
fo.close()
以上实例输出结果为:
文件名为:  runoob.txt

file.closed()

file.closed   判断文件是否关闭
//代码
f=open("yesterday",'r+')  #文件句柄
f.close()
print(f.closed)
//执行结果
True

file.flush()

file.flush() 刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。
//概述
flush() 方法是用来刷新缓冲区的,即将缓冲区中的数据立刻写入文件,同时清空缓冲区,不需要是被动的等待输出缓冲区写入。
一般情况下,文件关闭后会自动刷新缓冲区,但有时你需要在关闭前刷新它,这时就可以使用 flush() 方法。
//语法
flush() 方法语法如下:
fileObject.flush();
//参数
无
//返回值
该方法没有返回值。
//实例
以下实例演示了 flush() 方法的使用:
#!/usr/bin/python3
# 打开文件
fo = open("runoob.txt", "wb")
print ("文件名为: ", fo.name)
# 刷新缓冲区
fo.flush()
# 关闭文件
fo.close()
以上实例输出结果为:
文件名为:  runoob.txt

mode详解

控制文件读写内容的格式:(t模式和b模式)

  1. t模式(默认的内容格式)只能打开文本文件

    读写都是以str(Unicode)为单位的
    文本文件
    必须为open()指定encoding='utf-8'
    
  2. b模式(bytes)

     二进制方式,读写文件都是以bytes/二进制为单位的
    
      可以针对所有文件(文本文件,图片,视频。。。)
    
      不能指定encodingcabs
    
      注意:b模式打开没有encoding编码这一说
    

总结:b模式和t模式对比
  1、在操作纯文本文件方面t模式帮我们省去了解码环节,b模式则需要我们手动编码与解码,所以在操作纯文本文件方面t模式更加方便
  2、针对非文本文件(图片、视频,音频。。)只能使用b模式

  
文件操作模式

模式描述
+打开一个文件进行更新(可读可写)。
r以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
rb以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。一般用于非文本文件如图片等。
r+打开一个文件用于读写。文件指针将会放在文件的开头。如果原先有内容,执行写会把原先内容覆盖
rb+以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。
w打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。
w+打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb+以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。
a打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
ab以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
a+打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

**+不能单独使用,必须配合r、w、a使用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕业设计,基于SpringBoot+Vue+MySQL开发的纺织品企业财务管理系统,源码+数据库+毕业论文+视频演示 在如今社会上,关于信息上面的处理,没有任何一个企业或者个人会忽视,如何让信息急速传递,并且归档储存查询,采用之前的纸张记录模式已经不符合当前使用要求了。所以,对纺织品企业财务信息管理的提升,也为了对纺织品企业财务信息进行更好的维护,纺织品企业财务管理系统的出现就变得水到渠成不可缺少。通过对纺织品企业财务管理系统的开发,不仅仅可以学以致用,让学到的知识变成成果出现,也强化了知识记忆,扩大了知识储备,是提升自我的一种很好的方法。通过具体的开发,对整个软件开发的过程熟练掌握,不论是前期的设计,还是后续的编码测试,都有了很深刻的认知。 纺织品企业财务管理系统通过MySQL数据库与Spring Boot框架进行开发,纺织品企业财务管理系统能够实现对财务人员,员工,收费信息,支出信息,薪资信息,留言信息,报销信息等信息的管理。 通过纺织品企业财务管理系统对相关信息的处理,让信息处理变的更加的系统,更加的规范,这是一个必然的结果。已经处理好的信息,不管是用来查找,还是分析,在效率上都会成倍的提高,让计算机变得更加符合生产需要,变成人们不可缺少的一种信息处理工具,实现了绿色办公,节省社会资源,为环境保护也做了力所能及的贡献。 关键字:纺织品企业财务管理系统,薪资信息,报销信息;SpringBoot
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值