1.Python,write()和writelines()的区别
f = open("a.txt", 'a')
f.write("write写入一行新数据")
f.write("write写入一行新数据")
f.write("write写入一行新数据")
f.writelines("writelines写入一行新数据")
f.writelines("writelines写入一行新数据")
f.close()
''' 输出结果是: write写入一行新数据write写入一行新数据write写入一行新数据write写入一行新数据write写入一行新数据write写入一行新数据writelines写入一行新数据writelines写入一行新数据 '''
#(1)使用 writelines() 函数向文件中写入多行数据时,不会自动给各行添加换行符。所以上面看到的依然是没有换行的
#(2)注意,写入函数只有 write() 和 writelines() 函数,而没有名为 writeline 的函数。
#(3)那么Python,write()和writelines()有什么区别呢?参见https://blog.csdn.net/Zhongjie1986/article/details/91448373
'''
file.write(str)的参数是一个字符串,就是你要写入文件的内容.
file.writelines(sequence)的参数是序列,比如列表,它会迭代帮你写入文件。当然writelines()函数的参数也可以是一个字符串,用法跟write()函数类似。
'''
f = open("b.txt", 'a')
#f.write(['hello','how','a']) #f.write(['hello','how','a'])报错:TypeError: write() argument must be str, not list
f.writelines(['hello\n','how','a'])
f.close()
#(4)注意,在使用 write() 向文件中写入数据,需保证使用 open() 函数是以 r+、w、w+、a 或 a+ 的模式打开文件,
# 否则执行 write() 函数会抛出 io.UnsupportedOperation 错误。参考open时候的模式
#(5)总结一般我们需要写入文件时候,就有write()就行了,除非有特殊序列要写的,可以考虑下writelines()
2.open()学习mode指定了文件的打开模式
参考https://baijiahao.baidu.com/s?id=1618831950256096192&wfr=spider&for=pc
参考http://c.biancheng.net/view/2544.html
3.r+和w+都是以读写方式来打开文件。r+和w+方式不同之处
#a.txt和a2.txt里面内容都是123456789 r+和w+都是以读写方式来打开文件。现在来比较r+和w+方式不同之处 f = open("a.txt", 'r+') f2 = open("a2.txt", 'w+') f.write("xxh") f2.write("xxh") f.close() f2.close() ''' 得出的结果 a.txt里面内容由123456789变成了xxh456789 a2.txt里面内容由123456789变成了xxh 所以r+和w+都是以读写方式来打开文件。r+和w+方式不同是 r+ (读写方式),打开文件后,既可以从头读取文件内容,也可以从开头向文件中写入新的内容,写入的新内容会覆盖文件中等长度的原有内容。 w+ (读写方式),打开文件后,会对原有内容进行清空,并对该文件有读写权限。 '''
也就是说w+一定会先清空文本内所有内容,再给你读写这个文件名!下面用readlines也测试了一下,发现真的是w+打开open文件之后,你想readlines发现已经空了,读取不出来了!
''' a.txt和a2.txt里面内容都是 123456789 987 654 321 # r+和w+都是以读写方式来打开文件。现在来比较r+和w+方式不同之处 ''' f = open("a.txt", 'r+') f2 = open("a2.txt", 'w+') print(f.readlines()) print(f2.readlines()) f.close() f2.close() ''' 得出的结果 ['123456789\n', '987\n', '654\n', '321'] [] '''
4.open(filename,mode)其中filename可以是目录+文件名或者直接文件名
直接文件名即当一个需要打开的文件名称不带路径时,open函数会在Python程序运行的当前目录寻找该文件!
5.python读取文件的几个函数read()和readline()和readlines()区别。
read()按字节(字符)读取文件
readline()和readlines()函数:按行读取文件(其中 readline() 函数用于读取一行内容,而 readlines() 函数用于读取文件内的所有行。)
(1)使用 read() 函数读取文件时,如果文件过大,则一次读取全部内容到内存,容易造成内存不足,而相比每次限制读取字符(或字节)的个数,更推荐大家使用逐行读取文件的方式。
(2)read()里面可以加一个size,如果省略,则默认一次性读取所有内容。
''' a.txt里面内容 123456789 987 654 321 ''' f = open("a.txt", 'r+') print(f.readline()) f.close() ---------------------------------------- 输出是 123456789 ---------------------------------------- f = open("a.txt", 'r+') print(f.readlines()) f.close() ---------------------------------------- 输出是 ['123456789\n', '987\n', '654\n', '321'] ---------------------------------------- f = open("a.txt", 'r+') print(f.read()) f.close() ---------------------------------------- 输出是 123456789 987 654 321 ---------------------------------------- f = open("a.txt", 'r+') print(f.read(1)) f.close() ---------------------------------------- 输出是 1 ----------------------------------------
看上面,我们看到readlines输出是序列,每一行作为序列的一个元素,所以我们一般读取文件都是用f.readlines()来,之后用for循环遍历序列,如下:
for words in f.readlines(): print(words) 输出是: 123456789 987 654 321