网站建设资讯

NEWS

网站建设资讯

【python基础】python文件操作最重要的个人总结

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

【python基础】python文件操作最重要的个人总结

参考http://c.biancheng.net/view/2544.html

【python基础】python文件操作最重要的个人总结

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变成了xxh556789
            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


新闻标题:【python基础】python文件操作最重要的个人总结
文章出自:http://njwzjz.com/article/gjccdj.html